Commit eb9aef0a authored by Kevin Modzelewski's avatar Kevin Modzelewski

hasattr() returns False if an Exception is thrown.

parent b0a8f2fd
...@@ -368,7 +368,14 @@ Box* hasattr(Box* obj, Box* _str) { ...@@ -368,7 +368,14 @@ Box* hasattr(Box* obj, Box* _str) {
} }
BoxedString* str = static_cast<BoxedString*>(_str); BoxedString* str = static_cast<BoxedString*>(_str);
Box* attr = getattrInternal(obj, str->s, NULL); Box* attr;
try {
attr = getattrInternal(obj, str->s, NULL);
} catch (Box* e) {
if (isSubclass(e->cls, Exception))
return False;
throw;
}
Box* rtn = attr ? True : False; Box* rtn = attr ? True : False;
return rtn; return rtn;
...@@ -444,7 +451,7 @@ extern "C" { ...@@ -444,7 +451,7 @@ extern "C" {
BoxedClass* BaseException, *Exception, *StandardError, *AssertionError, *AttributeError, *GeneratorExit, *TypeError, BoxedClass* BaseException, *Exception, *StandardError, *AssertionError, *AttributeError, *GeneratorExit, *TypeError,
*NameError, *KeyError, *IndexError, *IOError, *OSError, *ZeroDivisionError, *ValueError, *UnboundLocalError, *NameError, *KeyError, *IndexError, *IOError, *OSError, *ZeroDivisionError, *ValueError, *UnboundLocalError,
*RuntimeError, *ImportError, *StopIteration, *Warning, *SyntaxError, *OverflowError, *DeprecationWarning, *RuntimeError, *ImportError, *StopIteration, *Warning, *SyntaxError, *OverflowError, *DeprecationWarning,
*MemoryError, *LookupError, *EnvironmentError, *ArithmeticError, *BufferError; *MemoryError, *LookupError, *EnvironmentError, *ArithmeticError, *BufferError, *KeyboardInterrupt, *SystemExit;
} }
Box* exceptionNew1(BoxedClass* cls) { Box* exceptionNew1(BoxedClass* cls) {
...@@ -735,6 +742,8 @@ void setupBuiltins() { ...@@ -735,6 +742,8 @@ void setupBuiltins() {
MemoryError = makeBuiltinException(StandardError, "MemoryError"); MemoryError = makeBuiltinException(StandardError, "MemoryError");
BufferError = makeBuiltinException(StandardError, "BufferError"); BufferError = makeBuiltinException(StandardError, "BufferError");
/*NotImplementedError=*/makeBuiltinException(RuntimeError, "NotImplementedError"); /*NotImplementedError=*/makeBuiltinException(RuntimeError, "NotImplementedError");
KeyboardInterrupt = makeBuiltinException(BaseException, "KeyboardInterrupt");
SystemExit = makeBuiltinException(BaseException, "SystemExit");
repr_obj = new BoxedFunction(boxRTFunction((void*)repr, UNKNOWN, 1)); repr_obj = new BoxedFunction(boxRTFunction((void*)repr, UNKNOWN, 1));
builtins_module->giveAttr("repr", repr_obj); builtins_module->giveAttr("repr", repr_obj);
......
# hasattr() swallows all most (but not all) exceptions
import __builtin__
class C(object):
def __getattr__(self, attr):
raise getattr(__builtin__, attr)()
c = C()
print hasattr(c, 'a')
c.a = 1
print hasattr(c, 'a')
print hasattr(c, 'ZeroDivisionError')
print hasattr(c, 'RuntimeError')
print hasattr(c, 'SystemError')
try:
print hasattr(c, 'KeyboardInterrupt')
except KeyboardInterrupt:
print "caught KeyboardInterrupt"
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment