This issue tracker has been migrated to GitHub, and is currently read-only.
For more information, see the GitHub FAQs in the Python's Developer Guide.

Author jacobidiego
Recipients jacobidiego
Date 2010-07-10.19:30:07
SpamBayes Score 0.11673145
Marked as misclassified No
Message-id <1278790209.67.0.359453381678.issue9218@psf.upfronthosting.co.za>
In-reply-to
Content
I am currently working with buffer in an USB device and pyusb.
So when i read from a buffer endpoint i get an array.Array() list.
I handle this chunk of data with a thread to send a receive the information that i need. In this thread i load a list with all the information that is read from the USB device, and another layer with pop this information from the threads buffer.

The thing i found is that, to pop a variable chunk of data from this buffer without copying it and deleting the elements, i have to pop one element at the time.

    def get_chunk(self, size):
        for x in range(size):
            yield self.recv_buffer.pop()

I guess that it would be improved if i can just pop a defined number of elements, like this:

pop self.recv_buffer[:size]
or
self.recv_buffer.pop(,-size)

That would be... "pop from the last element minus size to the last element"
in that way there is only one memory transaction.
The new list points to the old memory address and the recv_buffer is advanced to a new address. Data is not moved.

note that i like the idea of using "pop" as the "del" operator for lists

thanks.
Diego
History
Date User Action Args
2010-07-10 19:30:09jacobidiegosetrecipients: + jacobidiego
2010-07-10 19:30:09jacobidiegosetmessageid: <1278790209.67.0.359453381678.issue9218@psf.upfronthosting.co.za>
2010-07-10 19:30:08jacobidiegolinkissue9218 messages
2010-07-10 19:30:07jacobidiegocreate