- 09 Jan, 2015 15 commits
-
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
Apparently we can run quite well in the presence of GC bugs. (We were scanning most extension objects using our Pyston scanner instead of the conservative one.) I am both relieved and terrified.
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
And now things work!
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
Use operator new() to get access to tp_alloc in a C++-ish way. Instead of passing the object's class to the constructor, pass it to new(). We need to do this since the class gets to pick how the object gets allocated, including how large it will end up being. Unfortunately it looks like defining an operator new on a subclass hides the operator new from a superclass, even if they have different signatures. Macros to the rescue.
-
Kevin Modzelewski authored
Add a PYSTON_NOEXCEPT define that gets defined to "noexcept" in C++ mode, and to the empty string in C mode. I don't think 'extern "C"' implies noexcept. This is partly for better performance when we know that a function cannot throw an exception, but also as an annotation for us since the exception model is the main difference between C land and Pyston land. Vim substitution: %s/\(\<PyAPI_FUNC\>(.*).*(\([^)]\|\n\)*)\);/\1 PYSTON_NOEXCEPT;/gc - This will catch almost all cases, except for functions not marked with PyAPI_FUNC and function definitions that have extra paretheses (in comments, usually)
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
We're starting to have more functionality from CPython than we wrote ourselves -- I think this is a good thing, but we should switch Pyston code to calling it rather than supporting duplicates. After I finish adding this stuff I'll try to clean things up a bit.
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
Most involved was the recursion checking stuff: switch to providing the C API thread state rather than our internal one, since they are mostly the same. The recursion checking code doesn't mean much while most stuff doesn't use it, but hey at least it's supported now.
-
- 08 Jan, 2015 24 commits
-
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
Supposed to call type->tp_alloc(type) instead of PyObject_New Adding Py_TPFLAGS_BASETYPE and checking it
-
Kevin Modzelewski authored
And some install instructions on how to get a pre-built debug build, and to put the sources where the Pyston make system expects them.
-
Kevin Modzelewski authored
Add a hook to tell us what functions are taking a long time to JIT (spoiler: still sre_parse.py::_parse)
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
Special case {int,float,long}.__new__({int,float,str}) for rewriting.
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
float.__new__(cls) can return something that is not an instance of cls Disable rewriting of float.__new__ and int.__new__ in this changeset
-
Kevin Modzelewski authored
If cls is int, and the argument has an __int__ method that returns a subclass of int (that is not an int), then int.__new__ will return that. Will need to make the typeCall rewriting criteria tighter.
-
Kevin Modzelewski authored
I thought it was just an implementation detail, but it has observable effects from Python.
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
Was tricky to find a way to do this while still allowing rewriting. Right now we only attempt rewriting for a whitelisted set of __new__ functions where __new__(cls) always returns an instance of cls.
-
Kevin Modzelewski authored
It's more efficient since __new__ ends up being harder for the JIT to handle than __init__. It's also more correct, though hopefully no one relies on this.
-
- 07 Jan, 2015 1 commit
-
-
Kevin Modzelewski authored
-