1. 20 Feb, 2018 1 commit
  2. 04 Oct, 2017 1 commit
    • Damien George's avatar
      all: Remove inclusion of internal py header files. · a3dc1b19
      Damien George authored
      Header files that are considered internal to the py core and should not
      normally be included directly are:
          py/nlr.h - internal nlr configuration and declarations
          py/bc0.h - contains bytecode macro definitions
          py/runtime0.h - contains basic runtime enums
      Instead, the top-level header files to include are one of:
          py/obj.h - includes runtime0.h and defines everything to use the
              mp_obj_t type
          py/runtime.h - includes mpstate.h and hence nlr.h, obj.h, runtime0.h,
              and defines everything to use the general runtime support functions
      Additional, specific headers (eg py/objlist.h) can be included if needed.
  3. 05 Sep, 2017 1 commit
  4. 29 Aug, 2017 1 commit
  5. 13 Aug, 2017 1 commit
    • Javier Candeira's avatar
      all: Raise exceptions via mp_raise_XXX · 35a1fea9
      Javier Candeira authored
        - Changed: ValueError, TypeError, NotImplementedError
        - OSError invocations unchanged, because the corresponding utility
          function takes ints, not strings like the long form invocation.
        - OverflowError, IndexError and RuntimeError etc. not changed for now
          until we decide whether to add new utility functions.
  6. 09 Aug, 2017 1 commit
  7. 31 Jul, 2017 1 commit
  8. 05 Apr, 2017 1 commit
  9. 29 Mar, 2017 1 commit
    • Damien George's avatar
      py: Convert mp_uint_t to size_t for tuple/list accessors. · 6213ad7f
      Damien George authored
      This patch changes mp_uint_t to size_t for the len argument of the
      following public facing C functions:
      These functions take a pointer to the len argument (to be filled in by the
      function) and callers of these functions should update their code so the
      type of len is changed to size_t.  For ports that don't use nan-boxing
      there should be no change in generate code because the size of the type
      remains the same (word sized), and in a lot of cases there won't even be a
      compiler warning if the type remains as mp_uint_t.
      The reason for this change is to standardise on the use of size_t for
      variables that count memory (or memory related) sizes/lengths.  It helps
      builds that use nan-boxing.
  10. 23 Mar, 2017 1 commit
  11. 16 Feb, 2017 3 commits
  12. 14 Aug, 2016 1 commit
  13. 12 Aug, 2016 1 commit
  14. 11 Jan, 2016 3 commits
  15. 03 Jan, 2016 1 commit
  16. 29 Nov, 2015 2 commits
  17. 11 Oct, 2015 1 commit
  18. 03 Sep, 2015 1 commit
  19. 12 May, 2015 1 commit
    • Damien George's avatar
      py: Convert hash API to use MP_UNARY_OP_HASH instead of ad-hoc function. · c2a4e4ef
      Damien George authored
      Hashing is now done using mp_unary_op function with MP_UNARY_OP_HASH as
      the operator argument.  Hashing for int, str and bytes still go via
      fast-path in mp_unary_op since they are the most common objects which
      need to be hashed.
      This lead to quite a bit of code cleanup, and should be more efficient
      if anything.  It saves 176 bytes code space on Thumb2, and 360 bytes on
      The only loss is that the error message "unhashable type" is now the
      more generic "unsupported type for __hash__".
  20. 16 Apr, 2015 1 commit
    • Damien George's avatar
      py: Overhaul and simplify printf/pfenv mechanism. · 7f9d1d6a
      Damien George authored
      Previous to this patch the printing mechanism was a bit of a tangled
      mess.  This patch attempts to consolidate printing into one interface.
      All (non-debug) printing now uses the mp_print* family of functions,
      mainly mp_printf.  All these functions take an mp_print_t structure as
      their first argument, and this structure defines the printing backend
      through the "print_strn" function of said structure.
      Printing from the uPy core can reach the platform-defined print code via
      two paths: either through mp_sys_stdout_obj (defined pert port) in
      conjunction with mp_stream_write; or through the mp_plat_print structure
      which uses the MP_PLAT_PRINT_STRN macro to define how string are printed
      on the platform.  The former is only used when MICROPY_PY_IO is defined.
      With this new scheme printing is generally more efficient (less layers
      to go through, less arguments to pass), and, given an mp_print_t*
      structure, one can call mp_print_str for efficiency instead of
      mp_printf("%s", ...).  Code size is also reduced by around 200 bytes on
      Thumb2 archs.
  21. 27 Feb, 2015 1 commit
  22. 20 Jan, 2015 1 commit
  23. 01 Jan, 2015 1 commit
  24. 17 Sep, 2014 1 commit
  25. 30 Aug, 2014 2 commits
  26. 29 Aug, 2014 1 commit
  27. 13 Aug, 2014 1 commit
  28. 03 Jul, 2014 1 commit
  29. 05 Jun, 2014 1 commit
    • Damien George's avatar
      py: Small changes to objstr.c, including a bug fix. · 11de8399
      Damien George authored
      Some small fixed:
      - Combine 'x' and 'X' cases in str format code.
      - Remove trailing spaces from some lines.
      - Make exception messages consistently begin with lower case (then
      needed to change those in objarray and objtuple so the same
      constant string data could be used).
      - Fix bug with exception message having %c instead of %%c.
  30. 01 Jun, 2014 1 commit
    • Damien George's avatar
      Rename bultins config variables to MICROPY_PY_BUILTINS_*. · fb510b3b
      Damien George authored
      This renames:
      See issue #35 for discussion.
  31. 25 May, 2014 2 commits
  32. 24 May, 2014 1 commit
  33. 21 May, 2014 1 commit