Commit 43ec5ae1 authored by Jim Fulton's avatar Jim Fulton

Added machinery so that module names as replacements in __module_aliases__.

This makes it easier for a package to replace an different package with itself
while it is being imported.
parent bacec447
...@@ -85,8 +85,8 @@ ...@@ -85,8 +85,8 @@
__doc__='''Application support __doc__='''Application support
$Id: Application.py,v 1.83 1998/12/30 01:43:22 amos Exp $''' $Id: Application.py,v 1.84 1999/01/21 22:48:18 jim Exp $'''
__version__='$Revision: 1.83 $'[11:-2] __version__='$Revision: 1.84 $'[11:-2]
import Globals,Folder,os,regex,sys,App.Product, App.ProductRegistry import Globals,Folder,os,regex,sys,App.Product, App.ProductRegistry
...@@ -351,7 +351,7 @@ def open_bobobase(): ...@@ -351,7 +351,7 @@ def open_bobobase():
return Bobobase return Bobobase
def import_products(): def import_products(_st=type('')):
# Try to import each product, checking for and catching errors. # Try to import each product, checking for and catching errors.
path_join=os.path.join path_join=os.path.join
product_dir=path_join(SOFTWARE_HOME,'Products') product_dir=path_join(SOFTWARE_HOME,'Products')
...@@ -363,6 +363,8 @@ def import_products(): ...@@ -363,6 +363,8 @@ def import_products():
product_names.sort() product_names.sort()
global_dict=globals() global_dict=globals()
silly=('__doc__',) silly=('__doc__',)
modules=sys.modules
have_module=modules.has_key
for product_name in product_names: for product_name in product_names:
package_dir=path_join(product_dir, product_name) package_dir=path_join(product_dir, product_name)
...@@ -376,13 +378,14 @@ def import_products(): ...@@ -376,13 +378,14 @@ def import_products():
product=__import__(pname, global_dict, global_dict, silly) product=__import__(pname, global_dict, global_dict, silly)
if hasattr(product, '__module_aliases__'): if hasattr(product, '__module_aliases__'):
for k, v in product.__module_aliases__: for k, v in product.__module_aliases__:
if not sys.modules.has_key(k): if not have_module(k):
sys.modules[k]=v if type(v) is _st and have_module(v): v=modules[v]
modules[k]=v
except: except:
f=StringIO() f=StringIO()
traceback.print_exc(100,f) traceback.print_exc(100,f)
f=f.getvalue() f=f.getvalue()
try: sys.modules[pname].__import_error__=f try: modules[pname].__import_error__=f
except: pass except: pass
def install_products(app): def install_products(app):
......
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