optimizations and handling of extra spaces

This commit is contained in:
Joe Shochet 2004-07-23 18:47:11 +00:00
parent b035fd8349
commit 39e98b2870

View File

@ -5,33 +5,37 @@ import os
def findClassInModule(module, className, visited):
# Make sure you have not already visited this module
# to prevent recursion
if module in visited:
if visited.has_key(module):
return None
# Ok, clear to proceed, add this module to the visited list
visited.append(module)
visited[module] = 1
# print ('visiting: ' + `module`)
# Look in this module for classes and other modules
for key in module.__dict__.keys():
value = module.__dict__[key]
# If this is a class
if ((key != "_") and (type(value) == types.ClassType)):
# See if the name matches
if value.__name__ == className:
# It does! We found our class
return [value, module.__dict__]
# Its a module, recursively look into its namespace
elif (type(value) == types.ModuleType):
ret = findClassInModule(value, className, visited)
# If that recursion found it, return the goodies
if ret:
return ret
# Otherwise keep looking
# First see if we are in the dict at this level
classObj = module.__dict__.get(className)
if classObj and (type(classObj) == types.ClassType):
return [classObj, module.__dict__]
# Now filter out all the modules and iterate through them
moduleList = filter(lambda value: type(value) == types.ModuleType, module.__dict__.values())
for moduleObj in moduleList:
ret = findClassInModule(moduleObj, className, visited)
# If that recursion found it, return the goodies
if ret:
return ret
# Well, after all that we did not find anything
return None
# Find a class named className somewhere in this namespace
def findClass(namespace, className):
# First see if we are in the namespace
classObj = namespace.get(className)
if classObj and (type(classObj) == types.ClassType):
return [classObj, namespace]
for key in namespace.keys():
value = namespace[key]
# If we found a class, see if it matches classname
@ -42,7 +46,7 @@ def findClass(namespace, className):
return [value, namespace]
# Look in all the modules in this namespace
elif (type(value) == types.ModuleType):
ret = findClassInModule(value, className, [])
ret = findClassInModule(value, className, {})
# If we found it return the goodies
if ret:
return ret
@ -51,47 +55,37 @@ def findClass(namespace, className):
return None
def rebindClass(builtins, filename):
def rebindClass(builtinGlobals, filename):
file = open(filename, 'r')
lines = file.readlines()
curLine = 0
found = 0
foundLine = -1
foundChar = -1
for i in range(len(lines)):
line = lines[i]
if (line[0:6] == 'class '):
classHeader = line[6:]
# Chop off the "class " syntax and strip extra whitespace
classHeader = line[6:].strip()
# Look for a open paren if it does inherit
parenLoc = classHeader.find('(')
if parenLoc > 0:
className = classHeader[:parenLoc]
print 'Rebinding class name: ' + className
found = 1
foundLine = i
foundChar = parenLoc
else:
# Look for a colon if it does not inherit
colonLoc = classHeader.find(':')
if colonLoc > 0:
className = classHeader[:colonLoc]
# print 'found className: ' + className
found = 1
foundLine = i
foundChar = colonLoc
if not found:
print 'error: className not found'
return
else:
print 'error: className not found'
return
print 'Rebinding class name: ' + className
break
# Store the original real class
res = findClass(builtins, className)
res = findClass(builtinGlobals, className)
if res:
realClass, realNameSpace = res
else:
# print ('Warning: could not find class, defining new class in builtins: ' + className)
# Now execute that class def
# execfile(filename, builtins)
# execfile(filename, builtinGlobals)
print ('Warning: Finder could not find class, try importing the file first')
# Remove that temp file
file.close()
@ -104,12 +98,7 @@ def rebindClass(builtins, filename):
file.close()
os.remove(filename)
res = findClass(realNameSpace, className)
if res:
tmpClass, tmpNameSpace = res
else:
print ('Internal error redefining class: could not find temp class')
return
tmpClass = realNameSpace[className]
# Copy the functions that we just redefined into the real class
copyFuncs(tmpClass, realClass)
@ -117,6 +106,8 @@ def rebindClass(builtins, filename):
# Now make sure the original class is in that namespace, not our temp one
realNameSpace[className] = realClass
print (' Finished rebind')
def copyFuncs(fromClass, toClass):
# Copy the functions from fromClass into toClass dictionary