[Bf-blender-cvs] [5ec1d709e77] blender2.8: WM: use Python bytecode cache to run presets
Campbell Barton
noreply at git.blender.org
Thu Nov 15 08:46:01 CET 2018
Commit: 5ec1d709e7717537b9f60e4b9ea997c56f6c5c15
Author: Campbell Barton
Date: Thu Nov 15 18:42:23 2018 +1100
Branches: blender2.8
https://developer.blender.org/rB5ec1d709e7717537b9f60e4b9ea997c56f6c5c15
WM: use Python bytecode cache to run presets
Key-maps can be very large, avoid parsing on every startup.
===================================================================
M release/scripts/modules/bpy_extras/keyconfig_utils.py
M release/scripts/startup/bl_operators/presets.py
===================================================================
diff --git a/release/scripts/modules/bpy_extras/keyconfig_utils.py b/release/scripts/modules/bpy_extras/keyconfig_utils.py
index 316884e3fe1..51f1980f519 100644
--- a/release/scripts/modules/bpy_extras/keyconfig_utils.py
+++ b/release/scripts/modules/bpy_extras/keyconfig_utils.py
@@ -514,7 +514,7 @@ def keyconfig_module_from_preset(name, preset_reference_filename=None):
preset_path = bpy.utils.preset_find(name, "keyconfig")
# module name isn't used or added to 'sys.modules'.
- mod_spec = importlib.util.spec_from_file_location("__bl_keymap__", preset_path)
+ mod_spec = importlib.util.spec_from_file_location("__main__", preset_path)
mod = importlib.util.module_from_spec(mod_spec)
mod_spec.loader.exec_module(mod)
return mod
diff --git a/release/scripts/startup/bl_operators/presets.py b/release/scripts/startup/bl_operators/presets.py
index 5ff8f6f591c..9b83ee92ab4 100644
--- a/release/scripts/startup/bl_operators/presets.py
+++ b/release/scripts/startup/bl_operators/presets.py
@@ -245,9 +245,14 @@ class ExecutePreset(Operator):
if hasattr(preset_class, "reset_cb"):
preset_class.reset_cb(context)
- # execute the preset using script.python_file_run
if ext == ".py":
- bpy.ops.script.python_file_run(filepath=filepath)
+ import importlib.util
+ mod_spec = importlib.util.spec_from_file_location("__main__", filepath)
+ try:
+ mod_spec.loader.exec_module(importlib.util.module_from_spec(mod_spec))
+ except Exception as ex:
+ self.report({'ERROR'}, "Failed to executge the preset: " + repr(ex))
+
elif ext == ".xml":
import rna_xml
rna_xml.xml_file_run(context,
More information about the Bf-blender-cvs
mailing list