2013-09-11 15:18:49 +00:00
|
|
|
cdef python_op(int op, object a, object b):
|
|
|
|
if op == 0:
|
|
|
|
return a < b
|
|
|
|
elif op == 1:
|
|
|
|
return a <= b
|
|
|
|
elif op == 2:
|
|
|
|
return a == b
|
|
|
|
elif op == 3:
|
|
|
|
return a >= b
|
|
|
|
elif op == 4:
|
|
|
|
return a > b
|
|
|
|
elif op == 5:
|
|
|
|
return a != b
|
|
|
|
|
2015-05-01 21:57:22 +00:00
|
|
|
|
2013-09-11 15:18:49 +00:00
|
|
|
cdef class ByteArray:
|
|
|
|
cdef LocalRef _jobject
|
|
|
|
cdef long _size
|
2015-12-10 12:11:25 +00:00
|
|
|
cdef unsigned char *_buf
|
|
|
|
cdef unsigned char[:] _arr
|
2013-09-11 15:18:49 +00:00
|
|
|
|
|
|
|
def __cinit__(self):
|
|
|
|
self._size = 0
|
|
|
|
self._buf = NULL
|
|
|
|
self._arr = None
|
|
|
|
|
2015-05-01 21:57:22 +00:00
|
|
|
|
|
|
|
|
2013-09-11 15:18:49 +00:00
|
|
|
def __dealloc__(self):
|
|
|
|
cdef JNIEnv *j_env
|
|
|
|
if self._buf != NULL:
|
|
|
|
j_env = get_jnienv()
|
2015-12-10 12:11:25 +00:00
|
|
|
j_env[0].ReleaseByteArrayElements(
|
|
|
|
j_env, self._jobject.obj, <jbyte *>self._buf, 0)
|
2013-09-11 15:18:49 +00:00
|
|
|
self._buf = NULL
|
|
|
|
self._jobject = None
|
|
|
|
|
|
|
|
cdef void set_buffer(self, JNIEnv *env, jobject obj, long size, jbyte *buf):
|
|
|
|
if self._buf != NULL:
|
|
|
|
raise Exception('Cannot call set_buffer() twice.')
|
|
|
|
self._jobject = LocalRef()
|
|
|
|
self._jobject.create(env, obj)
|
|
|
|
self._size = size
|
2015-12-10 12:11:25 +00:00
|
|
|
self._buf = <unsigned char *><signed char *>buf
|
2017-04-12 13:59:07 +00:00
|
|
|
if size:
|
|
|
|
self._arr = <unsigned char[:size]>self._buf
|
2013-09-11 15:18:49 +00:00
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return '<ByteArray size={} at 0x{}>'.format(
|
|
|
|
self._size, id(self))
|
|
|
|
|
|
|
|
def __len__(self):
|
|
|
|
return self._size
|
|
|
|
|
2015-05-01 21:57:22 +00:00
|
|
|
def __getitem__(self, index):
|
|
|
|
cdef long xx
|
|
|
|
if isinstance(index, slice):
|
|
|
|
val = []
|
2017-04-12 13:59:07 +00:00
|
|
|
if self._size:
|
|
|
|
(start, stop, step) = index.indices(len(self._arr))
|
|
|
|
for x in range(start, stop, step):
|
|
|
|
xx = x
|
|
|
|
val.append(self._arr[xx])
|
2015-05-01 21:57:22 +00:00
|
|
|
return val
|
|
|
|
else:
|
|
|
|
xx = index
|
|
|
|
return self._arr[xx]
|
|
|
|
|
|
|
|
def __getslice__(self, long i, long j):
|
2017-04-12 13:59:07 +00:00
|
|
|
if self._size:
|
|
|
|
return self._arr[i:j]
|
|
|
|
return []
|
2013-09-11 15:18:49 +00:00
|
|
|
|
|
|
|
def __richcmp__(self, other, op):
|
|
|
|
cdef ByteArray b_other
|
|
|
|
if isinstance(other, (list, tuple)):
|
|
|
|
return python_op(op, self.tolist(), other)
|
|
|
|
elif isinstance(other, ByteArray):
|
|
|
|
b_other = other
|
|
|
|
return python_op(op, self.tostring(), other.tostring())
|
|
|
|
else:
|
|
|
|
return False
|
|
|
|
|
|
|
|
def tolist(self):
|
|
|
|
return list(self[:])
|
|
|
|
|
|
|
|
def tostring(self):
|
|
|
|
return self._buf[:self._size]
|