(original) (raw)
On Jan 9, 2016, at 16:17, Blake Griffith <blake.a.griffith@gmail.com> wrote:
A little update, I got ^, &, and | working for bytearrays. You can view the diff here:
https://github.com/python/cpython/compare/master...cowlicks:bitwise-bytes?expand=1
How does it look?Joe, is this how I should allocate the arrays? Am I freeing them properly?Am I checking the input enough?After some feedback, I'll probably add bitshifting and negation. Then work on bytes objects.Does this warrant a pep?
Personally, I'd just make the case for the feature on the tracker issue. If one of the core devs thinks it needs a PEP, or further discussion on this list or -ideas, they'll say so there.
At present, it seems like there's not much support for the idea, but I think that's at least partly because people want to see realistic use cases (that aren't server better by the existing bitarray/bitstring/etc. modules on PyPI, or using a NumPy array, or just using ints, etc.).
On Fri, Jan 8, 2016 at 2:08 AM, Cameron Simpson <cs@zip.com.au> wrote:The use case which springs immediately to my mind is cryptography. To encrypt a stream symmetrically you can go:On 07Jan2016 16:12, Python-Dev <python-dev@python.org> wrote:
On Jan 7, 2016, at 15:57, Martin Panter <vadmium+py@gmail.com> wrote:
On 7 January 2016 at 22:26, Blake Griffith <blake.a.griffith@gmail.com> wrote:
I'm interested in adding the functionality to do something like:
b'\\x03'b'a' ^ b'b'
Instead of the good ol' TypeError.
I think both bytes and bytearray should support all the bitwise operations.
There is a bug open about adding this kind of functionality:
<https://bugs.python.org/issue19251>.
And it's in the needs patch stage, which makes it perfect for the OP: in addition to learning how to hack on builtin types, he can also learn the other parts of the dev process. (Even if the bug is eventually rejected, as seems likely given that it sat around for three years with no compelling use case and then Guido added a "very skeptical" comment.)
cleartext-bytes ^ cryptographicly-random-bytes-from-cipher
so with this one could write:
def crypted(byteses, crypto\_source):
''' Accept an iterable source of bytes objects and a preprimed source of crypto bytes, yield encrypted versions of the bytes objects.
'''
for bs in byteses:
cbs = crypto\_source.next\_bytes(len(bs))
yield bs ^ cbs
Cheers,
Cameron Simpson <cs@zip.com.au>
\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_
Python-Dev mailing list
Python-Dev@python.org
https://mail.python.org/mailman/listinfo/python-dev
Unsubscribe: https://mail.python.org/mailman/options/python-dev/blake.a.griffith%40gmail.com