]> git.ipfire.org Git - thirdparty/Python/cpython.git/commit
Merge from py3k branch:
authorAmaury Forgeot d'Arc <amauryfa@gmail.com>
Tue, 13 Nov 2007 21:54:28 +0000 (21:54 +0000)
committerAmaury Forgeot d'Arc <amauryfa@gmail.com>
Tue, 13 Nov 2007 21:54:28 +0000 (21:54 +0000)
commit0d75f09177cea068ad9eec438ff6425e6c2355fc
tree6b8fce0fb8905c98039bbef0c8c18f96e1526881
parent0288cb0ba8f98119e0badad583e43e2ae7778877
Merge from py3k branch:
Correction for issue1265 (pdb bug with "with" statement).

When an unfinished generator-iterator is garbage collected, PyEval_EvalFrameEx
is called with a GeneratorExit exception set.  This leads to funny results
if the sys.settrace function itself makes use of generators.
A visible effect is that the settrace function is reset to None.
Another is that the eventual "finally" block of the generator is not called.

It is necessary to save/restore the exception around the call to the trace
function.

This happens a lot with py3k: isinstance() of an ABCMeta instance runs
    def __instancecheck__(cls, instance):
        """Override for isinstance(instance, cls)."""
        return any(cls.__subclasscheck__(c)
                   for c in {instance.__class__, type(instance)})
which lets an opened generator expression each time it returns True.

Backport candidate, even if the case is less frequent in 2.5.
Lib/test/test_trace.py
Misc/NEWS
Python/ceval.c