Skip to content
Snippets Groups Projects
  1. Jul 18, 2017
    • Alexander Steffen's avatar
      all: Unify header guard usage. · 299bc625
      Alexander Steffen authored
      The code conventions suggest using header guards, but do not define how
      those should look like and instead point to existing files. However, not
      all existing files follow the same scheme, sometimes omitting header guards
      altogether, sometimes using non-standard names, making it easy to
      accidentally pick a "wrong" example.
      
      This commit ensures that all header files of the MicroPython project (that
      were not simply copied from somewhere else) follow the same pattern, that
      was already present in the majority of files, especially in the py folder.
      
      The rules are as follows.
      
      Naming convention:
      * start with the words MICROPY_INCLUDED
      * contain the full path to the file
      * replace special characters with _
      
      In addition, there are no empty lines before #ifndef, between #ifndef and
      one empty line before #endif. #endif is followed by a comment containing
      the name of the guard macro.
      
      py/grammar.h cannot use header guards by design, since it has to be
      included multiple times in a single C file. Several other files also do not
      need header guards as they are only used internally and guaranteed to be
      included only once:
      * MICROPY_MPHALPORT_H
      * mpconfigboard.h
      * mpconfigport.h
      * mpthreadport.h
      * pin_defs_*.h
      * qstrdefs*.h
      299bc625
  2. Jul 12, 2017
  3. Jul 09, 2017
  4. Jul 07, 2017
  5. Jul 05, 2017
  6. Jul 04, 2017
  7. Jul 03, 2017
  8. Jul 02, 2017
  9. Jun 30, 2017
  10. Jun 29, 2017
    • Damien George's avatar
      py/objnamedtuple: Simplify and remove use of alloca building namedtuple. · 265500c5
      Damien George authored
      Prior to this patch there were 2 paths for creating the namedtuple, one for
      when no keyword args were passed, and one when there were keyword args.
      And alloca was used in the keyword-arg path to temporarily create the array
      of elements for the namedtuple, which would then be copied to a
      heap-allocated object (the namedtuple itself).
      
      This patch simplifies the code by combining the no-keyword and keyword
      paths, and removing the need for the alloca by constructing the namedtuple
      on the heap before populating it.
      
      Heap usage in unchanged, stack usage is reduced, use of alloca is removed,
      and code size is not increased and is actually reduced by between 20-30
      bytes for most ports.
      265500c5
  11. Jun 28, 2017
    • Damien George's avatar
      py/builtinimport: Remove unreachable code for relative imports. · 2f7fad66
      Damien George authored
      The while-loop that calls chop_component will guarantee that level==-1 at
      the end of the loop.  Hence the code following it is unnecessary.
      
      The check for p==this_name will catch imports that are beyond the
      top-level, and also covers the case of new_mod_q==MP_QSTR_ (equivalent to
      new_mod_l==0) so that check is removed.
      
      There is also a new check at the start for level>=0 to guard against
      __import__ being called with bad level values.
      2f7fad66
  12. Jun 27, 2017
  13. Jun 26, 2017
  14. Jun 22, 2017
    • Damien George's avatar
      py/compile: Optimise emitter label indices to save a word of heap. · d94bc675
      Damien George authored
      Previous to this patch, a label with value "0" was used to indicate an
      invalid label, but that meant a wasted word (at slot 0) in the array of
      label offsets.  This patch adjusts the label indices so the first one
      starts at 0, and the maximum value indicates an invalid label.
      d94bc675
    • Damien George's avatar
      py/compile: Fix bug with break/continue in else of optimised for-range. · 4c5f1083
      Damien George authored
      This patch fixes a bug whereby the Python stack was not correctly reset if
      there was a break/continue statement in the else black of an optimised
      for-range loop.
      
      For example, in the following code the "j" variable from the inner for loop
      was not being popped off the Python stack:
      
          for i in range(4):
              for j in range(4):
                  pass
              else:
                  continue
      
      This is now fixed with this patch.
      4c5f1083
  15. Jun 15, 2017
  16. Jun 14, 2017
  17. Jun 13, 2017
  18. Jun 09, 2017
  19. Jun 07, 2017
  20. Jun 04, 2017
  21. Jun 02, 2017
  22. Jun 01, 2017
    • Damien George's avatar
      py/modbuiltins: Add core-provided version of input() function. · bc76302e
      Damien George authored
      The implementation is taken from stmhal/input.c, with code added to handle
      ctrl-C.  This built-in is controlled by MICROPY_PY_BUILTINS_INPUT and is
      disabled by default.  It uses readline() to capture input but this can be
      overridden by defining the mp_hal_readline macro.
      bc76302e
  23. May 29, 2017
Loading