Commit dc1f5073 authored by Jim Fulton's avatar Jim Fulton

Improved algorithm for calling objects.

parent eeca8a44
...@@ -54,8 +54,8 @@ ...@@ -54,8 +54,8 @@
__doc__='''Python implementations of document template some features __doc__='''Python implementations of document template some features
$Id: pDocumentTemplate.py,v 1.19 1998/09/16 20:19:12 jim Exp $''' $Id: pDocumentTemplate.py,v 1.20 1998/09/17 10:12:20 jim Exp $'''
__version__='$Revision: 1.19 $'[11:-2] __version__='$Revision: 1.20 $'[11:-2]
import string, sys, types import string, sys, types
from string import join from string import join
...@@ -64,7 +64,7 @@ StringType=type('') ...@@ -64,7 +64,7 @@ StringType=type('')
TupleType=type(()) TupleType=type(())
isFunctionType={} isFunctionType={}
for name in ['BuiltinFunctionType', 'BuiltinMethodType', 'ClassType', for name in ['BuiltinFunctionType', 'BuiltinMethodType', 'ClassType',
'FunctionType', 'LambdaType', 'MethodType']: 'FunctionType', 'LambdaType', 'MethodType', 'UnboundMethodType']:
try: isFunctionType[getattr(types,name)]=1 try: isFunctionType[getattr(types,name)]=1
except: pass except: pass
...@@ -76,6 +76,14 @@ except: pass ...@@ -76,6 +76,14 @@ except: pass
isFunctionType=isFunctionType.has_key isFunctionType=isFunctionType.has_key
isSimpleType={}
for n in dir(types):
if (n[-4:]=='Type' and n != 'InstanceType' and
not isFunctionType(getattr(types, n))):
isSimpleType[getattr(types, n)]=1
isSimpleType=isSimpleType.has_key
class InstanceDict: class InstanceDict:
validate=None validate=None
...@@ -151,33 +159,24 @@ class TemplateDict: ...@@ -151,33 +159,24 @@ class TemplateDict:
except: pass except: pass
def __getitem__(self,key,call=1, def __getitem__(self,key,call=1,
simple={ simple=isSimpleType,
type(''): 1, type(0): 1, type(0.0): 1, isFunctionType=isFunctionType,
type([]): 1, type(()): 1, ):
}.has_key):
v=self.dicts[key] v=self.dicts[key]
if call and not simple(type(v)): if call and not simple(type(v)):
if hasattr(v,'isDocTemp') and v.isDocTemp: if hasattr(v,'isDocTemp') and v.isDocTemp: return v(None, self)
v=v(None, self) elif isFunctionType(type(v)): return v()
else: else:
try: return v() try: return v()
except AttributeError, ev: except AttributeError, ev:
try: try:
tb=sys.exc_traceback tb=sys.exc_traceback
if hasattr(sys, 'exc_info'): tb=sys.exc_info()[2] if hasattr(sys, 'exc_info'): tb=sys.exc_info()[2]
if isFunctionType(type(v)):
raise AttributeError, ev, tb
if hasattr(v,'__call__'): if hasattr(v,'__call__'):
raise AttributeError, ev, tb raise AttributeError, ev, tb
finally: tb=None finally: tb=None
except TypeError, ev: except TypeError: pass
try:
tb=sys.exc_traceback
if hasattr(sys, 'exc_info'): tb=sys.exc_info()[2]
if isFunctionType(type(v)):
raise AttributeError, ev, tb
finally: tb=None
return v return v
......
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