summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Lib/pyclbr.py44
1 files changed, 26 insertions, 18 deletions
diff --git a/Lib/pyclbr.py b/Lib/pyclbr.py
index cf93f3e..cb4125f 100644
--- a/Lib/pyclbr.py
+++ b/Lib/pyclbr.py
@@ -65,13 +65,22 @@ class Class:
def _addmethod(self, name, lineno):
self.methods[name] = lineno
-def readmodule(module, path = []):
+def readmodule(module, path=[], inpackage=0):
'''Read a module file and return a dictionary of classes.
Search for MODULE in PATH and sys.path, read and parse the
module and return a dictionary with one entry for each class
found in the module.'''
+ i = string.rfind(module, '.')
+ if i >= 0:
+ # Dotted module name
+ package = module[:i]
+ submodule = module[i+1:]
+ parent = readmodule(package, path, inpackage)
+ child = readmodule(submodule, parent['__path__'], 1)
+ return child
+
if _modules.has_key(module):
# we've seen this module before...
return _modules[module]
@@ -83,21 +92,20 @@ def readmodule(module, path = []):
# search the path for the module
f = None
- suffixes = imp.get_suffixes()
- for dir in path + sys.path:
- for suff, mode, type in suffixes:
- file = os.path.join(dir, module + suff)
- try:
- f = open(file, mode)
- except IOError:
- pass
- else:
- # found the module
- break
- if f:
- break
- if not f:
- raise IOError, 'module ' + module + ' not found'
+ if inpackage:
+ try:
+ f, file, (suff, mode, type) = \
+ imp.find_module(module, path)
+ except ImportError:
+ f = None
+ if f is None:
+ fullpath = path + sys.path
+ f, file, (suff, mode, type) = imp.find_module(module, fullpath)
+ if type == imp.PKG_DIRECTORY:
+ dict = {'__path__': [file]}
+ _modules[module] = dict
+ # XXX Should we recursively look for submodules?
+ return dict
if type != imp.PY_SOURCE:
# not Python source, can't do anything with this module
f.close()
@@ -130,7 +138,7 @@ def readmodule(module, path = []):
try:
# recursively read the
# imported module
- d = readmodule(n, path)
+ d = readmodule(n, path, inpackage)
except:
print 'module',n,'not found'
pass
@@ -142,7 +150,7 @@ def readmodule(module, path = []):
names = string.splitfields(res.group('imp'), ',')
try:
# recursively read the imported module
- d = readmodule(mod, path)
+ d = readmodule(mod, path, inpackage)
except:
print 'module',mod,'not found'
continue