summaryrefslogtreecommitdiff
path: root/lib/sqlalchemy/util/_preloaded.py
diff options
context:
space:
mode:
authormike bayer <mike_mp@zzzcomputing.com>2020-11-04 16:06:53 +0000
committerGerrit Code Review <gerrit@bbpush.zzzcomputing.com>2020-11-04 16:06:53 +0000
commite87fd72324e824d069351157b41485b0589cb41d (patch)
tree9c653ce778d95c83dc5302a41029b7cc6736630a /lib/sqlalchemy/util/_preloaded.py
parentb0e6dccfb60cb900e327ae8ff6632e8c3339c53d (diff)
parentf016c1ac7f93d2f759aff53ec1494658efd7b496 (diff)
downloadsqlalchemy-e87fd72324e824d069351157b41485b0589cb41d.tar.gz
Merge "Reduce import time overhead"
Diffstat (limited to 'lib/sqlalchemy/util/_preloaded.py')
-rw-r--r--lib/sqlalchemy/util/_preloaded.py12
1 files changed, 9 insertions, 3 deletions
diff --git a/lib/sqlalchemy/util/_preloaded.py b/lib/sqlalchemy/util/_preloaded.py
index 1a833a963..e267c008c 100644
--- a/lib/sqlalchemy/util/_preloaded.py
+++ b/lib/sqlalchemy/util/_preloaded.py
@@ -35,8 +35,9 @@ class _ModuleRegistry:
name. Example: ``sqlalchemy.sql.util`` becomes ``preloaded.sql_util``.
"""
- def __init__(self, prefix="sqlalchemy"):
+ def __init__(self, prefix="sqlalchemy."):
self.module_registry = set()
+ self.prefix = prefix
def preload_module(self, *deps):
"""Adds the specified modules to the list to load.
@@ -52,8 +53,13 @@ class _ModuleRegistry:
specified path.
"""
for module in self.module_registry:
- key = module.split("sqlalchemy.")[-1].replace(".", "_")
- if module.startswith(path) and key not in self.__dict__:
+ if self.prefix:
+ key = module.split(self.prefix)[-1].replace(".", "_")
+ else:
+ key = module
+ if (
+ not path or module.startswith(path)
+ ) and key not in self.__dict__:
compat.import_(module, globals(), locals())
self.__dict__[key] = sys.modules[module]