summaryrefslogtreecommitdiffstatshomepage
path: root/py/obj.h
diff options
context:
space:
mode:
authorPaul Sokolovsky <pfalcon@users.sourceforge.net>2014-05-25 21:21:57 +0300
committerPaul Sokolovsky <pfalcon@users.sourceforge.net>2014-05-25 21:21:57 +0300
commitde4b9329f99794dc2025a7f9aa203811a156b3c4 (patch)
treecda613e8734bd7821f5ab1380558c103e8f2bbcb /py/obj.h
parentff4b6daa4f446094361c6bd4cfa557f0ad2565fc (diff)
downloadmicropython-de4b9329f99794dc2025a7f9aa203811a156b3c4.tar.gz
micropython-de4b9329f99794dc2025a7f9aa203811a156b3c4.zip
py: Refactor slice helpers, preparing to support arbitrary slicing.
Diffstat (limited to 'py/obj.h')
-rw-r--r--py/obj.h10
1 files changed, 9 insertions, 1 deletions
diff --git a/py/obj.h b/py/obj.h
index 611873d2ea..6bcebcf6ef 100644
--- a/py/obj.h
+++ b/py/obj.h
@@ -563,8 +563,16 @@ typedef struct _mp_obj_static_class_method_t {
const mp_obj_t *mp_obj_property_get(mp_obj_t self_in);
// sequence helpers
+
+// slice indexes resolved to particular sequence
+typedef struct {
+ machine_uint_t start;
+ machine_uint_t stop;
+ machine_int_t step;
+} mp_bound_slice_t;
+
void mp_seq_multiply(const void *items, uint item_sz, uint len, uint times, void *dest);
-bool mp_seq_get_fast_slice_indexes(machine_uint_t len, mp_obj_t slice, machine_uint_t *begin, machine_uint_t *end);
+bool mp_seq_get_fast_slice_indexes(machine_uint_t len, mp_obj_t slice, mp_bound_slice_t *indexes);
#define mp_seq_copy(dest, src, len, item_t) memcpy(dest, src, len * sizeof(item_t))
#define mp_seq_cat(dest, src1, len1, src2, len2, item_t) { memcpy(dest, src1, (len1) * sizeof(item_t)); memcpy(dest + (len1), src2, (len2) * sizeof(item_t)); }
bool mp_seq_cmp_bytes(int op, const byte *data1, uint len1, const byte *data2, uint len2);