Sjoerd Mullender:

When printing missing modules, also print the module they were
imported from.
diff --git a/Tools/freeze/hello.py b/Tools/freeze/hello.py
index f978acc..31d8445 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 e406c6a..5c05c3a 100644
--- a/Tools/freeze/modulefinder.py
+++ b/Tools/freeze/modulefinder.py
@@ -220,6 +220,7 @@
             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 @@
                         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 @@
                     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 @@
         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():