1. 25 Jun, 2014 5 commits
  2. 24 Jun, 2014 7 commits
  3. 23 Jun, 2014 5 commits
  4. 20 Jun, 2014 1 commit
  5. 19 Jun, 2014 3 commits
    • Marius Wachtler's avatar
      GC: Register None · eb04bcde
      Marius Wachtler authored
      eb04bcde
    • Marius Wachtler's avatar
      Implement chained comparisons · 8580c891
      Marius Wachtler authored
      8580c891
    • Kevin Modzelewski's avatar
      Implement closures · ddabda9a
      Kevin Modzelewski authored
      Implementation is pretty straightforward for now:
      - find all names that get accessed from a nested function
      - if any, create a closure object at function entry
      - any time we set a name accessed from a nested function,
        update its value in the closure
      - when evaluating a functiondef that needs a closure, attach
        the created closure to the created function object.
      
      Closures are currently passed as an extra argument before any
      python-level args, which I'm not convinced is the right strategy.
      It's works out fine but it feels messy to say that functions
      can have different C-level calling conventions.
      It felt worse to include the closure as part of the python-level arg
      passing.
      Maybe it should be passed after all the other arguments?
      
      Closures are currently just simple objects, on which we set and get
      Python-level attributes.  The performance (which I haven't tested)
      relies on attribute access being made fast through the hidden-class
      inline caches.
      
      There are a number of ways that this could be improved:
      - be smarter about when we create the closure object, or when we
        update it.
      - not create empty pass-through closures
      - give the closures a pre-defined shape, since we know at irgen-time
        what names can get set.  could probably avoid the inline cache
        machinery and also have better code.
      ddabda9a
  6. 18 Jun, 2014 5 commits
  7. 17 Jun, 2014 9 commits
  8. 11 Jun, 2014 4 commits
  9. 10 Jun, 2014 1 commit
    • Kevin Modzelewski's avatar
      Change stack crawling to not be based on unwinding · d8c0bbd8
      Kevin Modzelewski authored
      We always want to crawl the entire stack, and it's
      possible to determine the extents of the stack, so just
      do a scan over the entire memory range.
      
      Also, change the way the interpreter keeps track of its roots;
      we don't really need to associate the roots with a specific
      interpreter frame.
      
      This should hopefully clear up the weirdness about libunwind
      trying to unwind through the pthreads assembly code, and potentially
      also make stack crawling faster.
      d8c0bbd8