| Age | Commit message (Collapse) | Author | 
|---|
|  |  | 
|  |  | 
|  | __bool__() and __len__() are just the same as __neg__() or __invert__(),
and require efficient dispatching implementation (not requiring search/lookup).
type->unary_op() is just the right choice for this short of adding
standalone virtual method(s) to already big mp_obj_type_t structure. | 
|  |  | 
|  | Can now have null bytes in strings.  Can define ROM qstrs per port using
qstrdefsport.h | 
|  | Change state layout in VM so the stack starts at state[0] and grows
upwards.  Locals are at the top end of the state and number downwards.
This cleans up a lot of the interface connecting the VM to C: now all
functions that take an array of Micro Python objects are in order (ie no
longer in reverse).
Also clean up C API with keyword arguments (call_n and call_n_kw
replaced with single call method that takes keyword arguments).  And now
make_new takes keyword arguments.
emitnative.c has not yet been changed to comply with the new order of
stack layout. | 
|  |  | 
|  | added zip() | 
|  | This is useful because tuple is closest analog of C static array. | 
|  |  | 
|  |  | 
|  |  | 
|  | conflict fun.
Conflicts:
	py/obj.h
	py/objbool.c
	py/objboundmeth.c
	py/objcell.c
	py/objclass.c
	py/objclosure.c
	py/objcomplex.c
	py/objdict.c
	py/objexcept.c
	py/objfun.c
	py/objgenerator.c
	py/objinstance.c
	py/objmodule.c
	py/objrange.c
	py/objset.c
	py/objslice.c | 
|  | It's not really about that, though; it's about me figuring out a sane
way forward for keyword-argument functions (and function
metadata). But it's useful as is, and shouldn't break any existing
code, so here you have it; I'm going to park it in my mind for a bit
while sorting out the rest of the dict branch. | 
|  | ian-v-cplusplus
Conflicts:
	py/objcomplex.c | 
|  |  | 
|  |  | 
|  |  | 
|  | Now much more inline with how CPython does types. | 
|  | A big change.  Micro Python objects are allocated as individual structs
with the first element being a pointer to the type information (which
is itself an object).  This scheme follows CPython.  Much more flexible,
not necessarily slower, uses same heap memory, and can allocate objects
statically.
Also change name prefix, from py_ to mp_ (mp for Micro Python). |