On Thu, Nov 20, 2014 at 4:09 PM, Steven D'Aprano <st...@pearwood.info> wrote: > StopIteration is not a singleton class. > > py> e1 = StopIteration() > py> e2 = StopIteration() > py> e1 is e2 > False > > It it were, you couldn't support "return value" from generators, since > the return value gets turned into the argument for StopIteration.
Clearly so. Also, the special case is for StopIteration, not for its type (just as there is for None, and not NoneType). > Nor is it a singleton itself: StopIteration (the class) is an instance of > type, and there are *many* instances of type: > > > py> all(isinstance(T, type) for T in [int, float, str, bool, > ... Exception, StopIteration, dict, type]) > True Indeed; however, there is a fixed pointer PyExc_StopIteration at the C level, so in a sense, there can be only one StopIteration. Even if you shadow the name with a subclass, C code will still raise and look for the original. > I cannot imagine what they mean by calling StopIteration a singleton. Okay, so I'm not the only one finds this strange! >> Why is StopIteration marshallable but no other exception is? Or, if they >> are marshallable, why does this one get special handling? > > No idea. But you can marshal StopIteration itself, but not StopIteration > instances: > > py> marshal.dumps(StopIteration) > 'S' > py> marshal.dumps(StopIteration()) > Traceback (most recent call last): > File "<stdin>", line 1, in <module> > ValueError: unmarshallable object Under what circumstances would you marshal an exception type? I don't use the module at all, I only happened upon it (its docs, to be precise) by grepping across files. ChrisA -- https://mail.python.org/mailman/listinfo/python-list