- Sep 21, 2017
-
-
Damien George authored
The vstr argument to the calls to vstr_add_len are dynamically allocated (ie fixed_buf=false) and so vstr_add_len will never return NULL. So there's no need to check for it. Any out-of-memory errors are raised by the call to m_renew in vstr_ensure_extra.
-
Damien George authored
The aim of this patch is to rewrite the functions that create exception instances (mp_obj_exception_make_new and mp_obj_new_exception_msg_varg) so that they do not call any functions that may raise an exception. Otherwise it's possible to create infinite recursion with an exception being raised while trying to create an exception object. The two main things that are done to accomplish this are: 1. Change mp_obj_new_exception_msg_varg to just format the string, then call mp_obj_exception_make_new to actually create the exception object. 2. In mp_obj_exception_make_new and mp_obj_new_exception_msg_varg try to allocate all memory first using functions that don't raise exceptions If any of the memory allocations fail (return NULL) then degrade gracefully by trying other options for memory allocation, eg using the emergency exception buffer. 3. Use a custom printer backend to conservatively format strings: if it can't allocate memory then it just truncates the string. As part of this rewrite, raising an exception without a message, like KeyError(123), will now use the emergency buffer to store the arg and traceback data if there is no heap memory available. Memory use with this patch is unchanged. Code size is increased by: bare-arm: +136 minimal x86: +124 unix x64: +72 unix nanbox: +96 stm32: +88 esp8266: +92 cc3200: +80
-
- Sep 19, 2017
-
-
Paul Sokolovsky authored
An issue was due to incorrectly taking size of default strip characters set.
-
- Sep 18, 2017
-
-
Damien George authored
-
Damien George authored
-
- Sep 17, 2017
-
-
Paul Sokolovsky authored
This allows user classes to implement __abs__ special method, and saves code size (104 bytes for x86_64), even though during refactor, an issue was fixed and few optimizations were made: * abs() of minimum (negative) small int value is calculated properly. * objint_longlong and objint_mpz avoid allocating new object is the argument is already non-negative.
-
- Sep 13, 2017
-
-
Damien George authored
-
Damien George authored
Variable arguments in a macro should take at least 1 argument.
-
- Sep 12, 2017
-
-
Damien George authored
As a pointer (const char *) it takes up an extra word of storage which is in RAM.
-
ASM authored
Tested using Clang on self-hosted Termux environment https://termux.com/.
-
- Sep 10, 2017
-
-
Paul Sokolovsky authored
If, for class X, X.__add__(Y) doesn't exist (or returns NotImplemented), try Y.__radd__(X) instead. This patch could be simpler, but requires undoing operand swap and operation switch to get non-confusing error message in case __radd__ doesn't exist.
-
Paul Sokolovsky authored
Defaults of 4096 and 5 respectively are too high to esp8266, causing out of memory with a database beyond couple of pages.
-
Damien George authored
Reduces code size by about 10 bytes.
-
- Sep 07, 2017
-
-
Paul Sokolovsky authored
This is to allow to place reverse ops immediately after normal ops, so they can be tested as one range (which is optimization for reverse ops introduction in the next patch).
-
Paul Sokolovsky authored
Originally, there were grouped in blocks of 5, to make it easier e.g. to assess and numeric code of each. But now it makes more sense to group it by semantics/properties, and then split in chunks still, which usually leads to chunks of ~6 ops.
-
Paul Sokolovsky authored
After recent refactorings to mp_binary_op_t, and make it future refactoring proof for now, at the cost of extra element in the array.
-
Paul Sokolovsky authored
It starts a dichotomy of mp_binary_op_t values which can't appear in the bytecode. Another reason to move it is to VALUES of OP_* and OP_INPLACE_* nicely adjacent. This also will be needed for OP_REVERSE_*, to be soon introduced.
-
Paul Sokolovsky authored
This is to allow to encode arithmetic operations more efficiently, in preparation to introduction of __rOP__ method support.
-
- Sep 06, 2017
-
-
Paul Sokolovsky authored
Should raise TypeError, unless it's (in)equality comparison.
-
tll authored
This patch adds a function utf8_check() to check for a valid UTF-8 encoded string, and calls it when constructing a str from raw bytes. The feature is selectable at compile time via MICROPY_PY_BUILTINS_STR_UNICODE_CHECK and is enabled if unicode is enabled. It costs about 110 bytes on Thumb-2, 150 bytes on Xtensa and 170 bytes on x86-64.
-
Damien George authored
Also renames "stmhal" to "stm32" in documentation and everywhere else.
-
- Sep 05, 2017
-
-
Paul Sokolovsky authored
Should raise TypeError, unless it's (in)equality comparison.
-
- Sep 04, 2017
-
-
Paul Sokolovsky authored
If __iop__ is not defined, call __op__ instead. This is desired behavior for immutable types, __iop__ needs to be defined only for mutable types.
-
Damien George authored
-
Damien George authored
IEEE floating point is specified such that a comparison of NaN with itself returns false, and Python respects these semantics. This patch makes uPy also have these semantics. The fix has a minor impact on the speed of the object-equality fast-path, but that seems to be unavoidable and it's much more important to have correct behaviour (especially in this case where the wrong answer for nan==nan is silently returned).
-
- Sep 02, 2017
-
-
Paul Sokolovsky authored
These are now returned as "operation not supported" instead of raising TypeError. In particular, this fixes equality for float vs incompatible types, which now properly results in False instead of exception. This also paves the road to support reverse operation (e.g. __radd__) with float objects. This is achieved by introducing mp_obj_get_float_maybe(), similar to existing mp_obj_get_int_maybe().
-
- Sep 01, 2017
-
-
Damien George authored
"b" on Thumb might not be long enough for the jump to nlr_push_tail so it must be done indirectly.
-
Damien George authored
They are not used by any component and take up valuable flash space.
-
Damien George authored
Prior to this patch, the size of the buffer given to pack_into() was checked for being too small by using the count of the arguments, not their actual size. For example, a format spec of '4I' would only check that there was 4 bytes available, not 16; and 'I' would check for 1 byte, not 4. The pack() function is ok because its buffer is created to be exactly the correct size. The fix in this patch calculates the total size of the format spec at the start of pack_into() and verifies that the buffer is large enough. This adds some computational overhead, to iterate through the whole format spec. The alternative is to check during the packing, but that requires extra code to handle alignment, and the check is anyway not needed for pack(). So to maintain minimal code size the check is done using struct_calcsize.
-
Damien George authored
Prior to this patch, the size of the buffer given to unpack/unpack_from was checked for being too small by using the count of the arguments, not their actual size. For example, a format spec of '4I' would only check that there was 4 bytes available, not 16; and 'I' would check for 1 byte, not 4. This bug is fixed in this patch by calculating the total size of the format spec at the start of the unpacking function. This function anyway needs to calculate the number of items at the start, so calculating the total size can be done at the same time.
-
Damien George authored
This patch makes a repeat counter behave the same as repeating the typecode, when there are not enough args. For example: struct.pack('2I', 1) now behave the same as struct.pack('II', 1).
-
- Aug 31, 2017
-
-
Damien George authored
-
Damien George authored
Maps are always allocated "statically" and (de)initialised via mp_map_init and mp_map_deinit.
-
Damien George authored
-
- Aug 30, 2017
-
-
Paul Sokolovsky authored
Now traces more explicitly thru the lookup process.
-
Paul Sokolovsky authored
-
Damien George authored
This comment style is no longer used because the docs are written by hand, not generated.
-
- Aug 29, 2017
-
-
Paul Sokolovsky authored
NotImplemented means "try other fallbacks (like calling __rop__ instead of __op__) and if nothing works, raise TypeError". As MicroPython doesn't implement any fallbacks, signal to raise TypeError right away.
-
Damien George authored
The unary-op/binary-op enums are already defined, and there are no arithmetic tricks used with these types, so it makes sense to use the correct enum type for arguments that take these values. It also reduces code size quite a bit for nan-boxing builds.
-
Damien George authored
Using gcc -Wpedantic will warn that #define of defined() is non-portable and this patch fixes this.
-