diff --git a/Tools/freeze/hello.py b/Tools/freeze/hello.py index f978acc883c..31d84457ddb 100644 --- a/Tools/freeze/hello.py +++ b/Tools/freeze/hello.py @@ -1 +1,2 @@ print 'Hello world...' +import fooblurg diff --git a/Tools/freeze/modulefinder.py b/Tools/freeze/modulefinder.py index e406c6aeec6..5c05c3a26e2 100644 --- a/Tools/freeze/modulefinder.py +++ b/Tools/freeze/modulefinder.py @@ -220,6 +220,7 @@ def import_module(self, partname, fqname, parent): return m if self.badmodules.has_key(fqname): self.msgout(3, "import_module -> None") + self.badmodules[fqname][parent.__name__] = None return None try: fp, pathname, stuff = self.find_module(partname, @@ -279,7 +280,7 @@ def scan_code(self, co, m): self.import_hook(name, m) except ImportError, msg: self.msg(2, "ImportError:", str(msg)) - self.badmodules[name] = None + self.badmodules[name] = {m.__name__:None} elif op == IMPORT_FROM: name = co.co_names[oparg] assert lastname is not None @@ -289,7 +290,7 @@ def scan_code(self, co, m): except ImportError, msg: self.msg(2, "ImportError:", str(msg)) fullname = lastname + "." + name - self.badmodules[fullname] = None + self.badmodules[fullname] = {m.__name__:None} else: lastname = None for c in co.co_consts: @@ -361,7 +362,9 @@ def report(self): for key in keys: # ... but not if they were explicitely excluded. if key not in self.excludes: - print "?", key + mods = self.badmodules[key].keys() + mods.sort() + print "?", key, "from", string.join(mods, ', ') def test():