[Zope-dev] Re: hasattr implementation for Zope?
    Tim Peters 
    tim.peters at gmail.com
       
    Fri May 27 09:19:19 EDT 2005
    
    
  
[Tres Seaver]
[...]
> - -1.  Python's 'hasattr' semantics are *broken by definition*, and will
> never be fixed (because of backward compatibility).  Non-Zope Python
> programmers will *not* expect or want exceptions raised from 'hasattr'.
>
> As a local patch, this isn't too bad (one could even package it as a
> do-nothing-after-initialization product).  However, no redistributed
> product code should rely on the presence of a patched 'hasattr', but
> should use the 3 argument getattr instead.
OTOH, defining & importing a utility function-- say, safehasattr()
--would make it all explicit.  That's what ZODB does.  I certainly
agree that changing the behavior of a builtin function by magic is at
best highly dubious practice.
    
    
More information about the Zope-Dev
mailing list