Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCampbell Barton <ideasman42@gmail.com>2015-01-23 08:20:37 +0300
committerCampbell Barton <ideasman42@gmail.com>2015-01-23 08:38:29 +0300
commit7733bd5efc8e90f85385e5a93066158a17b14a93 (patch)
tree175139f1a6ec9a3e4e89bb8ed8e09c8d2756a3b5 /release
parent783b4cd1ca22de57c98ebcfaeec7a20936a9a621 (diff)
PyAPI: avoid scanning all addons on startup
Gives small speedup
Diffstat (limited to 'release')
-rw-r--r--release/scripts/modules/addon_utils.py13
-rw-r--r--release/scripts/modules/bpy/utils.py9
2 files changed, 20 insertions, 2 deletions
diff --git a/release/scripts/modules/addon_utils.py b/release/scripts/modules/addon_utils.py
index d236a59059f..9ec6d249129 100644
--- a/release/scripts/modules/addon_utils.py
+++ b/release/scripts/modules/addon_utils.py
@@ -36,6 +36,15 @@ error_encoding = False
addons_fake_modules = {}
+# called only once at startup, avoids calling 'reset_all', correct but slower.
+def _initialize():
+ path_list = paths()
+ for path in path_list:
+ _bpy.utils._sys_path_ensure(path)
+ for addon in _user_preferences.addons:
+ enable(addon.module)
+
+
def paths():
# RELEASE SCRIPTS: official scripts distributed in Blender releases
addon_paths = _bpy.utils.script_paths("addons")
@@ -182,14 +191,16 @@ def modules_refresh(module_cache=addons_fake_modules):
def modules(module_cache=addons_fake_modules, refresh=True):
- if refresh:
+ if refresh or ((module_cache is addons_fake_modules) and modules._is_first):
modules_refresh(module_cache)
+ modules._is_first = False
mod_list = list(module_cache.values())
mod_list.sort(key=lambda mod: (mod.bl_info["category"],
mod.bl_info["name"],
))
return mod_list
+modules._is_first = True
def check(module_name):
diff --git a/release/scripts/modules/bpy/utils.py b/release/scripts/modules/bpy/utils.py
index dd771aff044..bf882db74d9 100644
--- a/release/scripts/modules/bpy/utils.py
+++ b/release/scripts/modules/bpy/utils.py
@@ -244,7 +244,14 @@ def load_scripts(reload_scripts=False, refresh_scripts=False):
test_register(mod)
# deal with addons separately
- _addon_utils.reset_all(reload_scripts)
+ _initialize = getattr(_addon_utils, "_initialize", None)
+ if _initialize is not None:
+ # first time, use fast-path
+ _initialize()
+ del _addon_utils._initialize
+ else:
+ _addon_utils.reset_all(reload_scripts)
+ del _initialize
# run the active integration preset
filepath = preset_find(_user_preferences.inputs.active_keyconfig,