| 
									
										
										
										
											2009-11-01 15:21:20 +00:00
										 |  |  | # ##### BEGIN GPL LICENSE BLOCK ##### | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | #  This program is free software; you can redistribute it and/or | 
					
						
							|  |  |  | #  modify it under the terms of the GNU General Public License | 
					
						
							|  |  |  | #  as published by the Free Software Foundation; either version 2 | 
					
						
							|  |  |  | #  of the License, or (at your option) any later version. | 
					
						
							| 
									
										
										
										
											2009-11-07 22:07:46 +00:00
										 |  |  | # | 
					
						
							| 
									
										
										
										
											2009-11-01 15:21:20 +00:00
										 |  |  | #  This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  | #  but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  | #  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  | #  GNU General Public License for more details. | 
					
						
							| 
									
										
										
										
											2009-11-07 22:07:46 +00:00
										 |  |  | # | 
					
						
							| 
									
										
										
										
											2009-11-01 15:21:20 +00:00
										 |  |  | #  You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  | #  along with this program; if not, write to the Free Software Foundation, | 
					
						
							| 
									
										
										
										
											2010-02-12 13:34:04 +00:00
										 |  |  | #  Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | 
					
						
							| 
									
										
										
										
											2009-11-01 15:21:20 +00:00
										 |  |  | # | 
					
						
							|  |  |  | # ##### END GPL LICENSE BLOCK ##### | 
					
						
							| 
									
										
										
										
											2009-10-31 20:16:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-31 03:15:37 +00:00
										 |  |  | # <pep8-80 compliant> | 
					
						
							| 
									
										
										
										
											2009-12-05 22:03:07 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-22 02:04:25 +00:00
										 |  |  | """
 | 
					
						
							| 
									
										
										
										
											2010-07-15 20:02:53 +00:00
										 |  |  | This module contains utility functions specific to blender but | 
					
						
							| 
									
										
										
										
											2012-07-04 15:04:38 +00:00
										 |  |  | not associated with blenders internal data. | 
					
						
							| 
									
										
										
										
											2010-01-22 02:04:25 +00:00
										 |  |  | """
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-31 03:15:37 +00:00
										 |  |  | __all__ = ( | 
					
						
							|  |  |  |     "blend_paths", | 
					
						
							|  |  |  |     "keyconfig_set", | 
					
						
							|  |  |  |     "load_scripts", | 
					
						
							|  |  |  |     "modules_from_path", | 
					
						
							|  |  |  |     "preset_find", | 
					
						
							|  |  |  |     "preset_paths", | 
					
						
							|  |  |  |     "refresh_script_paths", | 
					
						
							|  |  |  |     "register_class", | 
					
						
							|  |  |  |     "register_module", | 
					
						
							| 
									
										
										
										
											2012-08-25 14:07:51 +00:00
										 |  |  |     "register_manual_map", | 
					
						
							| 
									
										
										
										
											2012-08-25 14:18:54 +00:00
										 |  |  |     "unregister_manual_map", | 
					
						
							|  |  |  |     "manual_map", | 
					
						
							| 
									
										
										
										
											2011-07-31 03:15:37 +00:00
										 |  |  |     "resource_path", | 
					
						
							| 
									
										
										
										
											2012-07-29 01:02:25 +00:00
										 |  |  |     "script_path_user", | 
					
						
							|  |  |  |     "script_path_pref", | 
					
						
							| 
									
										
										
										
											2011-07-31 03:15:37 +00:00
										 |  |  |     "script_paths", | 
					
						
							|  |  |  |     "smpte_from_frame", | 
					
						
							|  |  |  |     "smpte_from_seconds", | 
					
						
							|  |  |  |     "unregister_class", | 
					
						
							|  |  |  |     "unregister_module", | 
					
						
							|  |  |  |     "user_resource", | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-11 13:56:58 +00:00
										 |  |  | from _bpy import register_class, unregister_class, blend_paths, resource_path | 
					
						
							| 
									
										
										
										
											2010-07-15 20:02:53 +00:00
										 |  |  | from _bpy import script_paths as _bpy_script_paths | 
					
						
							| 
									
										
										
										
											2010-12-18 07:22:52 +00:00
										 |  |  | from _bpy import user_resource as _user_resource | 
					
						
							| 
									
										
										
										
											2010-02-14 23:33:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-20 02:56:58 +00:00
										 |  |  | import bpy as _bpy | 
					
						
							|  |  |  | import os as _os | 
					
						
							|  |  |  | import sys as _sys | 
					
						
							| 
									
										
										
										
											2010-09-07 15:17:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-18 20:57:32 +00:00
										 |  |  | import addon_utils as _addon_utils | 
					
						
							| 
									
										
										
										
											2011-01-01 07:20:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-04 08:44:08 +00:00
										 |  |  | _script_module_dirs = "startup", "modules" | 
					
						
							| 
									
										
										
										
											2011-02-25 16:06:14 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-26 21:19:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-14 23:33:18 +00:00
										 |  |  | def _test_import(module_name, loaded_modules): | 
					
						
							| 
									
										
										
										
											2012-03-31 00:59:17 +00:00
										 |  |  |     use_time = _bpy.app.debug_python | 
					
						
							| 
									
										
										
										
											2011-02-27 14:16:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-14 23:33:18 +00:00
										 |  |  |     if module_name in loaded_modules: | 
					
						
							|  |  |  |         return None | 
					
						
							|  |  |  |     if "." in module_name: | 
					
						
							| 
									
										
										
										
											2011-07-31 03:15:37 +00:00
										 |  |  |         print("Ignoring '%s', can't import files containing " | 
					
						
							| 
									
										
										
										
											2011-09-19 14:00:42 +00:00
										 |  |  |               "multiple periods" % module_name) | 
					
						
							| 
									
										
										
										
											2010-02-14 23:33:18 +00:00
										 |  |  |         return None | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-27 14:16:32 +00:00
										 |  |  |     if use_time: | 
					
						
							|  |  |  |         import time | 
					
						
							|  |  |  |         t = time.time() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-14 23:33:18 +00:00
										 |  |  |     try: | 
					
						
							| 
									
										
										
										
											2010-02-16 13:13:22 +00:00
										 |  |  |         mod = __import__(module_name) | 
					
						
							| 
									
										
										
										
											2010-02-14 23:33:18 +00:00
										 |  |  |     except: | 
					
						
							| 
									
										
										
										
											2011-02-27 14:16:32 +00:00
										 |  |  |         import traceback | 
					
						
							| 
									
										
										
										
											2010-02-14 23:33:18 +00:00
										 |  |  |         traceback.print_exc() | 
					
						
							|  |  |  |         return None | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-27 14:16:32 +00:00
										 |  |  |     if use_time: | 
					
						
							| 
									
										
										
										
											2010-02-16 13:13:22 +00:00
										 |  |  |         print("time %s %.4f" % (module_name, time.time() - t)) | 
					
						
							| 
									
										
										
										
											2010-02-22 23:32:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-07 15:17:42 +00:00
										 |  |  |     loaded_modules.add(mod.__name__)  # should match mod.__name__ too | 
					
						
							| 
									
										
										
										
											2010-02-16 13:13:22 +00:00
										 |  |  |     return mod | 
					
						
							| 
									
										
										
										
											2010-02-14 23:33:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-22 23:32:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-13 04:52:56 +00:00
										 |  |  | def _sys_path_ensure(path): | 
					
						
							|  |  |  |     if path not in _sys.path:  # reloading would add twice | 
					
						
							|  |  |  |         _sys.path.insert(0, path) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-14 23:33:18 +00:00
										 |  |  | def modules_from_path(path, loaded_modules): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  |     Load all modules in a path and return them as a list. | 
					
						
							| 
									
										
										
										
											2010-02-16 15:01:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     :arg path: this path is scanned for scripts and packages. | 
					
						
							|  |  |  |     :type path: string | 
					
						
							| 
									
										
										
										
											2011-07-31 03:15:37 +00:00
										 |  |  |     :arg loaded_modules: already loaded module names, files matching these | 
					
						
							|  |  |  |        names will be ignored. | 
					
						
							| 
									
										
										
										
											2010-02-16 15:01:34 +00:00
										 |  |  |     :type loaded_modules: set | 
					
						
							|  |  |  |     :return: all loaded modules. | 
					
						
							|  |  |  |     :rtype: list | 
					
						
							| 
									
										
										
										
											2010-02-14 23:33:18 +00:00
										 |  |  |     """
 | 
					
						
							|  |  |  |     modules = [] | 
					
						
							| 
									
										
										
										
											2010-02-22 23:32:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-08 07:30:20 +00:00
										 |  |  |     for mod_name, mod_path in _bpy.path.module_names(path): | 
					
						
							| 
									
										
										
										
											2010-09-08 04:55:37 +00:00
										 |  |  |         mod = _test_import(mod_name, loaded_modules) | 
					
						
							| 
									
										
										
										
											2010-02-14 23:33:18 +00:00
										 |  |  |         if mod: | 
					
						
							|  |  |  |             modules.append(mod) | 
					
						
							| 
									
										
										
										
											2010-02-22 23:32:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-14 23:33:18 +00:00
										 |  |  |     return modules | 
					
						
							| 
									
										
										
										
											2010-09-07 15:17:42 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | _global_loaded_modules = []  # store loaded module names for reloading. | 
					
						
							|  |  |  | import bpy_types as _bpy_types  # keep for comparisons, never ever reload this. | 
					
						
							| 
									
										
										
										
											2010-02-15 10:54:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-14 23:33:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-28 11:48:06 +00:00
										 |  |  | def load_scripts(reload_scripts=False, refresh_scripts=False): | 
					
						
							| 
									
										
										
										
											2010-02-16 15:01:34 +00:00
										 |  |  |     """
 | 
					
						
							|  |  |  |     Load scripts and run each modules register function. | 
					
						
							| 
									
										
										
										
											2010-02-22 23:32:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-31 03:15:37 +00:00
										 |  |  |     :arg reload_scripts: Causes all scripts to have their unregister method | 
					
						
							|  |  |  |        called before loading. | 
					
						
							| 
									
										
										
										
											2010-02-16 15:01:34 +00:00
										 |  |  |     :type reload_scripts: bool | 
					
						
							| 
									
										
										
										
											2011-07-31 03:15:37 +00:00
										 |  |  |     :arg refresh_scripts: only load scripts which are not already loaded | 
					
						
							|  |  |  |        as modules. | 
					
						
							| 
									
										
										
										
											2010-02-16 15:01:34 +00:00
										 |  |  |     :type refresh_scripts: bool | 
					
						
							|  |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2012-03-31 00:59:17 +00:00
										 |  |  |     use_time = _bpy.app.debug_python | 
					
						
							| 
									
										
										
										
											2010-01-28 11:48:06 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-31 03:15:37 +00:00
										 |  |  |     prefs = _bpy.context.user_preferences | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-28 04:37:24 +00:00
										 |  |  |     if use_time: | 
					
						
							|  |  |  |         import time | 
					
						
							|  |  |  |         t_main = time.time() | 
					
						
							| 
									
										
										
										
											2010-01-28 11:48:06 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     loaded_modules = set() | 
					
						
							| 
									
										
										
										
											2010-02-22 23:32:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-15 10:54:51 +00:00
										 |  |  |     if refresh_scripts: | 
					
						
							|  |  |  |         original_modules = _sys.modules.values() | 
					
						
							| 
									
										
										
										
											2010-09-07 15:17:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-03 03:53:36 +00:00
										 |  |  |     if reload_scripts: | 
					
						
							|  |  |  |         _bpy_types.TypeMap.clear() | 
					
						
							| 
									
										
										
										
											2010-01-28 11:48:06 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-10-17 06:58:07 +00:00
										 |  |  |         # just unload, don't change user defaults, this means we can sync | 
					
						
							| 
									
										
										
										
											2011-07-31 03:15:37 +00:00
										 |  |  |         # to reload. note that they will only actually reload of the | 
					
						
							| 
									
										
										
										
											2011-10-17 06:58:07 +00:00
										 |  |  |         # modification time changes. This `won't` work for packages so... | 
					
						
							| 
									
										
										
										
											2011-07-31 03:15:37 +00:00
										 |  |  |         # its not perfect. | 
					
						
							|  |  |  |         for module_name in [ext.module for ext in prefs.addons]: | 
					
						
							| 
									
										
										
										
											2011-03-18 20:57:32 +00:00
										 |  |  |             _addon_utils.disable(module_name, default_set=False) | 
					
						
							| 
									
										
										
										
											2010-09-13 04:52:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-03 03:53:36 +00:00
										 |  |  |     def register_module_call(mod): | 
					
						
							|  |  |  |         register = getattr(mod, "register", None) | 
					
						
							|  |  |  |         if register: | 
					
						
							|  |  |  |             try: | 
					
						
							|  |  |  |                 register() | 
					
						
							|  |  |  |             except: | 
					
						
							| 
									
										
										
										
											2011-02-27 14:16:32 +00:00
										 |  |  |                 import traceback | 
					
						
							| 
									
										
										
										
											2010-08-03 03:53:36 +00:00
										 |  |  |                 traceback.print_exc() | 
					
						
							|  |  |  |         else: | 
					
						
							| 
									
										
										
										
											2011-07-31 03:15:37 +00:00
										 |  |  |             print("\nWarning! '%s' has no register function, " | 
					
						
							| 
									
										
										
										
											2011-09-19 14:00:42 +00:00
										 |  |  |                   "this is now a requirement for registerable scripts" % | 
					
						
							| 
									
										
										
										
											2011-07-31 03:15:37 +00:00
										 |  |  |                   mod.__file__) | 
					
						
							| 
									
										
										
										
											2010-08-03 03:53:36 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def unregister_module_call(mod): | 
					
						
							| 
									
										
										
										
											2010-08-02 02:55:12 +00:00
										 |  |  |         unregister = getattr(mod, "unregister", None) | 
					
						
							|  |  |  |         if unregister: | 
					
						
							|  |  |  |             try: | 
					
						
							|  |  |  |                 unregister() | 
					
						
							|  |  |  |             except: | 
					
						
							| 
									
										
										
										
											2011-02-27 14:16:32 +00:00
										 |  |  |                 import traceback | 
					
						
							| 
									
										
										
										
											2010-08-02 02:55:12 +00:00
										 |  |  |                 traceback.print_exc() | 
					
						
							| 
									
										
										
										
											2010-08-03 03:53:36 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-15 10:54:51 +00:00
										 |  |  |     def test_reload(mod): | 
					
						
							| 
									
										
										
										
											2010-12-22 21:39:48 +00:00
										 |  |  |         import imp | 
					
						
							| 
									
										
										
										
											2010-02-15 10:54:51 +00:00
										 |  |  |         # reloading this causes internal errors | 
					
						
							|  |  |  |         # because the classes from this module are stored internally | 
					
						
							|  |  |  |         # possibly to refresh internal references too but for now, best not to. | 
					
						
							|  |  |  |         if mod == _bpy_types: | 
					
						
							|  |  |  |             return mod | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-28 11:48:06 +00:00
										 |  |  |         try: | 
					
						
							| 
									
										
										
										
											2010-12-22 21:39:48 +00:00
										 |  |  |             return imp.reload(mod) | 
					
						
							| 
									
										
										
										
											2010-01-28 11:48:06 +00:00
										 |  |  |         except: | 
					
						
							| 
									
										
										
										
											2011-02-27 14:16:32 +00:00
										 |  |  |             import traceback | 
					
						
							| 
									
										
										
										
											2010-01-28 11:48:06 +00:00
										 |  |  |             traceback.print_exc() | 
					
						
							| 
									
										
										
										
											2010-02-22 23:32:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-14 23:33:18 +00:00
										 |  |  |     def test_register(mod): | 
					
						
							| 
									
										
										
										
											2010-02-15 10:54:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if refresh_scripts and mod in original_modules: | 
					
						
							|  |  |  |             return | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-14 23:33:18 +00:00
										 |  |  |         if reload_scripts and mod: | 
					
						
							|  |  |  |             print("Reloading:", mod) | 
					
						
							|  |  |  |             mod = test_reload(mod) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if mod: | 
					
						
							| 
									
										
										
										
											2010-08-03 03:53:36 +00:00
										 |  |  |             register_module_call(mod) | 
					
						
							|  |  |  |             _global_loaded_modules.append(mod.__name__) | 
					
						
							| 
									
										
										
										
											2010-02-22 23:32:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-28 11:48:06 +00:00
										 |  |  |     if reload_scripts: | 
					
						
							| 
									
										
										
										
											2010-06-09 19:12:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-03 03:53:36 +00:00
										 |  |  |         # module names -> modules | 
					
						
							| 
									
										
										
										
											2011-07-31 03:15:37 +00:00
										 |  |  |         _global_loaded_modules[:] = [_sys.modules[mod_name] | 
					
						
							|  |  |  |                                      for mod_name in _global_loaded_modules] | 
					
						
							| 
									
										
										
										
											2010-02-22 23:32:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-15 10:54:51 +00:00
										 |  |  |         # loop over and unload all scripts | 
					
						
							| 
									
										
										
										
											2010-08-03 03:53:36 +00:00
										 |  |  |         _global_loaded_modules.reverse() | 
					
						
							|  |  |  |         for mod in _global_loaded_modules: | 
					
						
							|  |  |  |             unregister_module_call(mod) | 
					
						
							| 
									
										
										
										
											2010-06-01 08:15:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-03 03:53:36 +00:00
										 |  |  |         for mod in _global_loaded_modules: | 
					
						
							|  |  |  |             test_reload(mod) | 
					
						
							| 
									
										
										
										
											2010-06-01 08:15:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-03 03:53:36 +00:00
										 |  |  |         _global_loaded_modules[:] = [] | 
					
						
							| 
									
										
										
										
											2010-02-15 10:54:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-16 09:31:58 +00:00
										 |  |  |     for base_path in script_paths(): | 
					
						
							| 
									
										
										
										
											2011-05-04 08:44:08 +00:00
										 |  |  |         for path_subdir in _script_module_dirs: | 
					
						
							| 
									
										
										
										
											2010-01-28 11:48:06 +00:00
										 |  |  |             path = _os.path.join(base_path, path_subdir) | 
					
						
							|  |  |  |             if _os.path.isdir(path): | 
					
						
							| 
									
										
										
										
											2010-09-13 04:52:56 +00:00
										 |  |  |                 _sys_path_ensure(path) | 
					
						
							| 
									
										
										
										
											2010-02-15 10:54:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-10-17 06:58:07 +00:00
										 |  |  |                 # only add this to sys.modules, don't run | 
					
						
							| 
									
										
										
										
											2010-04-16 09:31:58 +00:00
										 |  |  |                 if path_subdir == "modules": | 
					
						
							|  |  |  |                     continue | 
					
						
							| 
									
										
										
										
											2010-02-14 23:33:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-20 22:57:49 +00:00
										 |  |  |                 for mod in modules_from_path(path, loaded_modules): | 
					
						
							|  |  |  |                     test_register(mod) | 
					
						
							| 
									
										
										
										
											2010-02-15 10:54:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-29 04:16:55 +00:00
										 |  |  |     # deal with addons separately | 
					
						
							| 
									
										
										
										
											2011-03-18 20:57:32 +00:00
										 |  |  |     _addon_utils.reset_all(reload_scripts) | 
					
						
							| 
									
										
										
										
											2010-02-22 23:32:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-14 16:45:24 +00:00
										 |  |  |     # run the active integration preset | 
					
						
							| 
									
										
										
										
											2011-07-31 03:15:37 +00:00
										 |  |  |     filepath = preset_find(prefs.inputs.active_keyconfig, "keyconfig") | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-14 16:45:24 +00:00
										 |  |  |     if filepath: | 
					
						
							|  |  |  |         keyconfig_set(filepath) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-17 19:50:42 +00:00
										 |  |  |     if reload_scripts: | 
					
						
							|  |  |  |         import gc | 
					
						
							|  |  |  |         print("gc.collect() -> %d" % gc.collect()) | 
					
						
							| 
									
										
										
										
											2010-01-28 11:48:06 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-28 04:37:24 +00:00
										 |  |  |     if use_time: | 
					
						
							| 
									
										
										
										
											2010-07-26 09:09:53 +00:00
										 |  |  |         print("Python Script Load Time %.4f" % (time.time() - t_main)) | 
					
						
							| 
									
										
										
										
											2009-12-13 13:59:16 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-28 20:50:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-22 11:23:19 +00:00
										 |  |  | # base scripts | 
					
						
							| 
									
										
										
										
											2011-07-31 03:15:37 +00:00
										 |  |  | _scripts = _os.path.join(_os.path.dirname(__file__), | 
					
						
							|  |  |  |                          _os.path.pardir, | 
					
						
							|  |  |  |                          _os.path.pardir, | 
					
						
							|  |  |  |                          ) | 
					
						
							| 
									
										
										
										
											2010-01-22 02:04:25 +00:00
										 |  |  | _scripts = (_os.path.normpath(_scripts), ) | 
					
						
							| 
									
										
										
										
											2009-11-22 11:23:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-22 23:32:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-29 01:02:25 +00:00
										 |  |  | def script_path_user(): | 
					
						
							|  |  |  |     """returns the env var and falls back to home dir or None""" | 
					
						
							| 
									
										
										
										
											2012-06-29 08:33:13 +00:00
										 |  |  |     path = _user_resource('SCRIPTS') | 
					
						
							| 
									
										
										
										
											2012-07-29 01:02:25 +00:00
										 |  |  |     return _os.path.normpath(path) if path else None | 
					
						
							| 
									
										
										
										
											2010-02-22 23:32:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-29 01:02:25 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | def script_path_pref(): | 
					
						
							|  |  |  |     """returns the user preference or None""" | 
					
						
							|  |  |  |     path = _bpy.context.user_preferences.filepaths.script_directory | 
					
						
							|  |  |  |     return _os.path.normpath(path) if path else None | 
					
						
							| 
									
										
										
										
											2009-12-13 13:59:16 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-22 23:32:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-24 19:36:12 +00:00
										 |  |  | def script_paths(subdir=None, user_pref=True, check_all=False): | 
					
						
							| 
									
										
										
										
											2010-01-22 02:04:25 +00:00
										 |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2011-05-02 17:29:30 +00:00
										 |  |  |     Returns a list of valid script paths. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     :arg subdir: Optional subdir. | 
					
						
							|  |  |  |     :type subdir: string | 
					
						
							|  |  |  |     :arg user_pref: Include the user preference script path. | 
					
						
							|  |  |  |     :type user_pref: bool | 
					
						
							| 
									
										
										
										
											2011-11-24 19:36:12 +00:00
										 |  |  |     :arg check_all: Include local, user and system paths rather just the paths | 
					
						
							| 
									
										
										
										
											2011-07-31 03:15:37 +00:00
										 |  |  |        blender uses. | 
					
						
							| 
									
										
										
										
											2011-11-24 19:36:12 +00:00
										 |  |  |     :type check_all: bool | 
					
						
							| 
									
										
										
										
											2011-05-02 17:29:30 +00:00
										 |  |  |     :return: script paths. | 
					
						
							|  |  |  |     :rtype: list | 
					
						
							| 
									
										
										
										
											2010-01-22 02:04:25 +00:00
										 |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2009-11-30 22:32:04 +00:00
										 |  |  |     scripts = list(_scripts) | 
					
						
							| 
									
										
										
										
											2010-02-22 23:32:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-24 19:36:12 +00:00
										 |  |  |     if check_all: | 
					
						
							| 
									
										
										
										
											2011-05-02 17:29:30 +00:00
										 |  |  |         # all possible paths | 
					
						
							| 
									
										
										
										
											2011-07-31 03:15:37 +00:00
										 |  |  |         base_paths = tuple(_os.path.join(resource_path(res), "scripts") | 
					
						
							|  |  |  |                            for res in ('LOCAL', 'USER', 'SYSTEM')) | 
					
						
							| 
									
										
										
										
											2011-05-02 17:29:30 +00:00
										 |  |  |     else: | 
					
						
							|  |  |  |         # only paths blender uses | 
					
						
							|  |  |  |         base_paths = _bpy_script_paths() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-29 01:02:25 +00:00
										 |  |  |     for path in base_paths + (script_path_user(), script_path_pref()): | 
					
						
							| 
									
										
										
										
											2010-02-11 14:08:22 +00:00
										 |  |  |         if path: | 
					
						
							|  |  |  |             path = _os.path.normpath(path) | 
					
						
							|  |  |  |             if path not in scripts and _os.path.isdir(path): | 
					
						
							|  |  |  |                 scripts.append(path) | 
					
						
							| 
									
										
										
										
											2009-11-30 22:32:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-04 08:44:08 +00:00
										 |  |  |     if subdir is None: | 
					
						
							| 
									
										
										
										
											2009-11-30 22:32:04 +00:00
										 |  |  |         return scripts | 
					
						
							| 
									
										
										
										
											2009-11-22 11:23:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-18 06:55:51 +00:00
										 |  |  |     scripts_subdir = [] | 
					
						
							| 
									
										
										
										
											2009-11-30 22:32:04 +00:00
										 |  |  |     for path in scripts: | 
					
						
							| 
									
										
										
										
											2010-01-22 02:04:25 +00:00
										 |  |  |         path_subdir = _os.path.join(path, subdir) | 
					
						
							|  |  |  |         if _os.path.isdir(path_subdir): | 
					
						
							| 
									
										
										
										
											2012-01-18 06:55:51 +00:00
										 |  |  |             scripts_subdir.append(path_subdir) | 
					
						
							| 
									
										
										
										
											2010-02-14 23:33:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-18 06:55:51 +00:00
										 |  |  |     return scripts_subdir | 
					
						
							| 
									
										
										
										
											2009-11-22 11:23:19 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-04 08:44:08 +00:00
										 |  |  | def refresh_script_paths(): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  |     Run this after creating new script paths to update sys.path | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for base_path in script_paths(): | 
					
						
							|  |  |  |         for path_subdir in _script_module_dirs: | 
					
						
							|  |  |  |             path = _os.path.join(base_path, path_subdir) | 
					
						
							|  |  |  |             if _os.path.isdir(path): | 
					
						
							|  |  |  |                 _sys_path_ensure(path) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for path in _addon_utils.paths(): | 
					
						
							|  |  |  |         _sys_path_ensure(path) | 
					
						
							|  |  |  |         path = _os.path.join(path, "modules") | 
					
						
							|  |  |  |         if _os.path.isdir(path): | 
					
						
							|  |  |  |             _sys_path_ensure(path) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-22 11:23:19 +00:00
										 |  |  | def preset_paths(subdir): | 
					
						
							| 
									
										
										
										
											2010-09-13 04:52:56 +00:00
										 |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2010-08-02 02:55:12 +00:00
										 |  |  |     Returns a list of paths for a specific preset. | 
					
						
							| 
									
										
										
										
											2011-07-20 15:33:27 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     :arg subdir: preset subdirectory (must not be an absolute path). | 
					
						
							|  |  |  |     :type subdir: string | 
					
						
							|  |  |  |     :return: script paths. | 
					
						
							|  |  |  |     :rtype: list | 
					
						
							| 
									
										
										
										
											2010-09-13 04:52:56 +00:00
										 |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2010-09-15 13:41:38 +00:00
										 |  |  |     dirs = [] | 
					
						
							| 
									
										
										
										
											2011-11-24 19:36:12 +00:00
										 |  |  |     for path in script_paths("presets", check_all=True): | 
					
						
							| 
									
										
										
										
											2010-09-15 13:41:38 +00:00
										 |  |  |         directory = _os.path.join(path, subdir) | 
					
						
							| 
									
										
										
										
											2011-07-20 15:33:27 +00:00
										 |  |  |         if not directory.startswith(path): | 
					
						
							|  |  |  |             raise Exception("invalid subdir given %r" % subdir) | 
					
						
							|  |  |  |         elif _os.path.isdir(directory): | 
					
						
							| 
									
										
										
										
											2010-09-15 13:41:38 +00:00
										 |  |  |             dirs.append(directory) | 
					
						
							| 
									
										
										
										
											2011-12-30 08:39:40 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     # Find addons preset paths | 
					
						
							| 
									
										
										
										
											2012-06-10 00:22:18 +00:00
										 |  |  |     for path in _addon_utils.paths(): | 
					
						
							| 
									
										
										
										
											2011-12-30 08:39:40 +00:00
										 |  |  |         directory = _os.path.join(path, "presets", subdir) | 
					
						
							|  |  |  |         if _os.path.isdir(directory): | 
					
						
							|  |  |  |             dirs.append(directory) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-15 13:41:38 +00:00
										 |  |  |     return dirs | 
					
						
							| 
									
										
										
										
											2010-05-10 20:41:01 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def smpte_from_seconds(time, fps=None): | 
					
						
							| 
									
										
										
										
											2010-09-13 04:52:56 +00:00
										 |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2010-05-10 20:41:01 +00:00
										 |  |  |     Returns an SMPTE formatted string from the time in seconds: "HH:MM:SS:FF". | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-08 04:55:37 +00:00
										 |  |  |     If the *fps* is not given the current scene is used. | 
					
						
							| 
									
										
										
										
											2010-09-13 04:52:56 +00:00
										 |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2010-05-10 20:41:01 +00:00
										 |  |  |     import math | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if fps is None: | 
					
						
							|  |  |  |         fps = _bpy.context.scene.render.fps | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     hours = minutes = seconds = frames = 0 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if time < 0: | 
					
						
							| 
									
										
										
										
											2010-05-16 12:15:04 +00:00
										 |  |  |         time = - time | 
					
						
							| 
									
										
										
										
											2010-05-10 20:41:01 +00:00
										 |  |  |         neg = "-" | 
					
						
							|  |  |  |     else: | 
					
						
							|  |  |  |         neg = "" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-07 15:17:42 +00:00
										 |  |  |     if time >= 3600.0:  # hours | 
					
						
							| 
									
										
										
										
											2010-05-10 20:41:01 +00:00
										 |  |  |         hours = int(time / 3600.0) | 
					
						
							|  |  |  |         time = time % 3600.0 | 
					
						
							| 
									
										
										
										
											2011-10-17 06:58:07 +00:00
										 |  |  |     if time >= 60.0:  # minutes | 
					
						
							| 
									
										
										
										
											2010-05-10 20:41:01 +00:00
										 |  |  |         minutes = int(time / 60.0) | 
					
						
							|  |  |  |         time = time % 60.0 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     seconds = int(time) | 
					
						
							| 
									
										
										
										
											2010-06-09 19:12:03 +00:00
										 |  |  |     frames = int(round(math.floor(((time - seconds) * fps)))) | 
					
						
							| 
									
										
										
										
											2010-05-10 20:41:01 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     return "%s%02d:%02d:%02d:%02d" % (neg, hours, minutes, seconds, frames) | 
					
						
							| 
									
										
										
										
											2010-05-16 12:15:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-05-10 20:41:01 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | def smpte_from_frame(frame, fps=None, fps_base=None): | 
					
						
							| 
									
										
										
										
											2010-09-13 04:52:56 +00:00
										 |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2010-05-10 20:41:01 +00:00
										 |  |  |     Returns an SMPTE formatted string from the frame: "HH:MM:SS:FF". | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-08 04:55:37 +00:00
										 |  |  |     If *fps* and *fps_base* are not given the current scene is used. | 
					
						
							| 
									
										
										
										
											2012-05-28 16:06:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     :arg time: time in seconds. | 
					
						
							|  |  |  |     :type time: number or timedelta object | 
					
						
							|  |  |  |     :return: the frame. | 
					
						
							|  |  |  |     :rtype: float | 
					
						
							| 
									
										
										
										
											2010-09-13 04:52:56 +00:00
										 |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2010-05-10 20:41:01 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if fps is None: | 
					
						
							|  |  |  |         fps = _bpy.context.scene.render.fps | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if fps_base is None: | 
					
						
							|  |  |  |         fps_base = _bpy.context.scene.render.fps_base | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return smpte_from_seconds((frame * fps_base) / fps, fps) | 
					
						
							| 
									
										
										
										
											2010-09-13 04:52:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-28 16:06:38 +00:00
										 |  |  | def time_from_frame(frame, fps=None, fps_base=None): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  |     Returns the time from a frame number . | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     If *fps* and *fps_base* are not given the current scene is used. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     :arg frame: number. | 
					
						
							|  |  |  |     :type frame: the frame number | 
					
						
							|  |  |  |     :return: the time in seconds. | 
					
						
							|  |  |  |     :rtype: timedate.timedelta | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if fps is None: | 
					
						
							|  |  |  |         fps = _bpy.context.scene.render.fps | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if fps_base is None: | 
					
						
							|  |  |  |         fps_base = _bpy.context.scene.render.fps_base | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     from datetime import timedelta | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return timedelta((frame * fps_base) / fps) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def time_to_frame(time, fps=None, fps_base=None): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  |     Returns a float frame number from a time given in seconds or | 
					
						
							|  |  |  |     as a timedate.timedelta object. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     If *fps* and *fps_base* are not given the current scene is used. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     :arg time: time in seconds. | 
					
						
							|  |  |  |     :type time: number or a timedate.timedelta object | 
					
						
							|  |  |  |     :return: the frame. | 
					
						
							|  |  |  |     :rtype: float | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if fps is None: | 
					
						
							|  |  |  |         fps = _bpy.context.scene.render.fps | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if fps_base is None: | 
					
						
							|  |  |  |         fps_base = _bpy.context.scene.render.fps_base | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     from datetime import timedelta | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if isinstance(time, timedelta): | 
					
						
							|  |  |  |         time = time.total_seconds() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return (time / fps_base) * fps | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-10 16:20:01 +00:00
										 |  |  | def preset_find(name, preset_path, display_name=False, ext=".py"): | 
					
						
							| 
									
										
										
										
											2010-09-14 16:45:24 +00:00
										 |  |  |     if not name: | 
					
						
							|  |  |  |         return None | 
					
						
							| 
									
										
										
										
											2011-01-01 07:20:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-14 04:58:25 +00:00
										 |  |  |     for directory in preset_paths(preset_path): | 
					
						
							| 
									
										
										
										
											2011-01-01 07:20:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-14 04:58:25 +00:00
										 |  |  |         if display_name: | 
					
						
							|  |  |  |             filename = "" | 
					
						
							|  |  |  |             for fn in _os.listdir(directory): | 
					
						
							| 
									
										
										
										
											2012-01-10 16:20:01 +00:00
										 |  |  |                 if fn.endswith(ext) and name == _bpy.path.display_name(fn): | 
					
						
							| 
									
										
										
										
											2010-09-14 04:58:25 +00:00
										 |  |  |                     filename = fn | 
					
						
							|  |  |  |                     break | 
					
						
							|  |  |  |         else: | 
					
						
							| 
									
										
										
										
											2012-01-10 16:20:01 +00:00
										 |  |  |             filename = name + ext | 
					
						
							| 
									
										
										
										
											2010-09-14 04:58:25 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if filename: | 
					
						
							|  |  |  |             filepath = _os.path.join(directory, filename) | 
					
						
							|  |  |  |             if _os.path.exists(filepath): | 
					
						
							| 
									
										
										
										
											2010-09-14 16:45:24 +00:00
										 |  |  |                 return filepath | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def keyconfig_set(filepath): | 
					
						
							|  |  |  |     from os.path import basename, splitext | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-31 00:59:17 +00:00
										 |  |  |     if _bpy.app.debug_python: | 
					
						
							| 
									
										
										
										
											2011-05-20 00:21:38 +00:00
										 |  |  |         print("loading preset:", filepath) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-14 16:45:24 +00:00
										 |  |  |     keyconfigs = _bpy.context.window_manager.keyconfigs | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     keyconfigs_old = keyconfigs[:] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     try: | 
					
						
							| 
									
										
										
										
											2011-11-24 19:36:12 +00:00
										 |  |  |         keyfile = open(filepath) | 
					
						
							| 
									
										
										
										
											2012-06-19 22:17:19 +00:00
										 |  |  |         exec(compile(keyfile.read(), filepath, "exec"), {"__file__": filepath}) | 
					
						
							| 
									
										
										
										
											2011-11-24 19:36:12 +00:00
										 |  |  |         keyfile.close() | 
					
						
							| 
									
										
										
										
											2010-09-14 16:45:24 +00:00
										 |  |  |     except: | 
					
						
							|  |  |  |         import traceback | 
					
						
							|  |  |  |         traceback.print_exc() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     kc_new = [kc for kc in keyconfigs if kc not in keyconfigs_old][0] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     kc_new.name = "" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # remove duplicates | 
					
						
							|  |  |  |     name = splitext(basename(filepath))[0] | 
					
						
							|  |  |  |     while True: | 
					
						
							|  |  |  |         kc_dupe = keyconfigs.get(name) | 
					
						
							|  |  |  |         if kc_dupe: | 
					
						
							|  |  |  |             keyconfigs.remove(kc_dupe) | 
					
						
							|  |  |  |         else: | 
					
						
							|  |  |  |             break | 
					
						
							| 
									
										
										
										
											2011-01-01 07:20:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-14 16:45:24 +00:00
										 |  |  |     kc_new.name = name | 
					
						
							|  |  |  |     keyconfigs.active = kc_new | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-18 06:55:51 +00:00
										 |  |  | def user_resource(resource_type, path="", create=False): | 
					
						
							| 
									
										
										
										
											2010-12-18 07:22:52 +00:00
										 |  |  |     """
 | 
					
						
							|  |  |  |     Return a user resource path (normally from the users home directory). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     :arg type: Resource type in ['DATAFILES', 'CONFIG', 'SCRIPTS', 'AUTOSAVE']. | 
					
						
							|  |  |  |     :type type: string | 
					
						
							|  |  |  |     :arg subdir: Optional subdirectory. | 
					
						
							|  |  |  |     :type subdir: string | 
					
						
							| 
									
										
										
										
											2011-07-31 03:15:37 +00:00
										 |  |  |     :arg create: Treat the path as a directory and create | 
					
						
							|  |  |  |        it if its not existing. | 
					
						
							| 
									
										
										
										
											2010-12-18 07:22:52 +00:00
										 |  |  |     :type create: boolean | 
					
						
							|  |  |  |     :return: a path. | 
					
						
							|  |  |  |     :rtype: string | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-18 06:55:51 +00:00
										 |  |  |     target_path = _user_resource(resource_type, path) | 
					
						
							| 
									
										
										
										
											2010-12-18 07:22:52 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if create: | 
					
						
							|  |  |  |         # should always be true. | 
					
						
							|  |  |  |         if target_path: | 
					
						
							|  |  |  |             # create path if not existing. | 
					
						
							|  |  |  |             if not _os.path.exists(target_path): | 
					
						
							|  |  |  |                 try: | 
					
						
							|  |  |  |                     _os.makedirs(target_path) | 
					
						
							|  |  |  |                 except: | 
					
						
							|  |  |  |                     import traceback | 
					
						
							|  |  |  |                     traceback.print_exc() | 
					
						
							|  |  |  |                     target_path = "" | 
					
						
							|  |  |  |             elif not _os.path.isdir(target_path): | 
					
						
							| 
									
										
										
										
											2010-12-19 07:05:29 +00:00
										 |  |  |                 print("Path %r found but isn't a directory!" % target_path) | 
					
						
							| 
									
										
										
										
											2010-12-18 07:22:52 +00:00
										 |  |  |                 target_path = "" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return target_path | 
					
						
							| 
									
										
										
										
											2011-02-10 23:48:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-11 00:39:07 +00:00
										 |  |  | def _bpy_module_classes(module, is_registered=False): | 
					
						
							|  |  |  |     typemap_list = _bpy_types.TypeMap.get(module, ()) | 
					
						
							|  |  |  |     i = 0 | 
					
						
							|  |  |  |     while i < len(typemap_list): | 
					
						
							| 
									
										
										
										
											2011-02-28 04:37:24 +00:00
										 |  |  |         cls_weakref = typemap_list[i] | 
					
						
							| 
									
										
										
										
											2011-02-11 00:39:07 +00:00
										 |  |  |         cls = cls_weakref() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if cls is None: | 
					
						
							|  |  |  |             del typemap_list[i] | 
					
						
							| 
									
										
										
										
											2011-02-11 01:27:00 +00:00
										 |  |  |         else: | 
					
						
							| 
									
										
										
										
											2011-02-14 07:26:07 +00:00
										 |  |  |             if is_registered == cls.is_registered: | 
					
						
							| 
									
										
										
										
											2011-02-28 04:37:24 +00:00
										 |  |  |                 yield cls | 
					
						
							| 
									
										
										
										
											2011-02-11 00:39:07 +00:00
										 |  |  |             i += 1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-11 01:12:01 +00:00
										 |  |  | def register_module(module, verbose=False): | 
					
						
							|  |  |  |     if verbose: | 
					
						
							|  |  |  |         print("bpy.utils.register_module(%r): ..." % module) | 
					
						
							| 
									
										
										
										
											2011-03-22 01:38:26 +00:00
										 |  |  |     cls = None | 
					
						
							| 
									
										
										
										
											2011-02-28 04:37:24 +00:00
										 |  |  |     for cls in _bpy_module_classes(module, is_registered=False): | 
					
						
							| 
									
										
										
										
											2011-02-11 01:12:01 +00:00
										 |  |  |         if verbose: | 
					
						
							| 
									
										
										
										
											2011-02-28 04:37:24 +00:00
										 |  |  |             print("    %r" % cls) | 
					
						
							| 
									
										
										
										
											2011-02-11 00:39:07 +00:00
										 |  |  |         try: | 
					
						
							|  |  |  |             register_class(cls) | 
					
						
							|  |  |  |         except: | 
					
						
							| 
									
										
										
										
											2011-07-31 03:15:37 +00:00
										 |  |  |             print("bpy.utils.register_module(): " | 
					
						
							|  |  |  |                   "failed to registering class %r" % cls) | 
					
						
							| 
									
										
										
										
											2011-02-27 14:16:32 +00:00
										 |  |  |             import traceback | 
					
						
							| 
									
										
										
										
											2011-02-11 00:39:07 +00:00
										 |  |  |             traceback.print_exc() | 
					
						
							| 
									
										
										
										
											2011-02-11 01:12:01 +00:00
										 |  |  |     if verbose: | 
					
						
							|  |  |  |         print("done.\n") | 
					
						
							| 
									
										
										
										
											2011-03-22 01:38:26 +00:00
										 |  |  |     if cls is None: | 
					
						
							| 
									
										
										
										
											2011-02-10 23:48:22 +00:00
										 |  |  |         raise Exception("register_module(%r): defines no classes" % module) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-11 01:12:01 +00:00
										 |  |  | def unregister_module(module, verbose=False): | 
					
						
							|  |  |  |     if verbose: | 
					
						
							|  |  |  |         print("bpy.utils.unregister_module(%r): ..." % module) | 
					
						
							| 
									
										
										
										
											2011-02-28 04:37:24 +00:00
										 |  |  |     for cls in _bpy_module_classes(module, is_registered=True): | 
					
						
							| 
									
										
										
										
											2011-02-11 01:12:01 +00:00
										 |  |  |         if verbose: | 
					
						
							| 
									
										
										
										
											2011-02-28 04:37:24 +00:00
										 |  |  |             print("    %r" % cls) | 
					
						
							| 
									
										
										
										
											2011-02-11 00:39:07 +00:00
										 |  |  |         try: | 
					
						
							|  |  |  |             unregister_class(cls) | 
					
						
							|  |  |  |         except: | 
					
						
							| 
									
										
										
										
											2011-07-31 03:15:37 +00:00
										 |  |  |             print("bpy.utils.unregister_module(): " | 
					
						
							|  |  |  |                   "failed to unregistering class %r" % cls) | 
					
						
							| 
									
										
										
										
											2011-02-27 14:16:32 +00:00
										 |  |  |             import traceback | 
					
						
							| 
									
										
										
										
											2011-02-11 00:39:07 +00:00
										 |  |  |             traceback.print_exc() | 
					
						
							| 
									
										
										
										
											2011-02-11 01:12:01 +00:00
										 |  |  |     if verbose: | 
					
						
							| 
									
										
										
										
											2011-02-14 04:47:55 +00:00
										 |  |  |         print("done.\n") | 
					
						
							| 
									
										
										
										
											2012-08-25 14:07:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # ----------------------------------------------------------------------------- | 
					
						
							|  |  |  | # Manual lookups, each function has to return a basepath and a sequence | 
					
						
							|  |  |  | # of... | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # we start with the built-in default mapping | 
					
						
							|  |  |  | def _blender_default_map(): | 
					
						
							|  |  |  |     import sys | 
					
						
							|  |  |  |     import rna_wiki_reference as ref_mod | 
					
						
							|  |  |  |     ret = (ref_mod.url_manual_prefix, ref_mod.url_manual_mapping) | 
					
						
							|  |  |  |     # avoid storing in memory | 
					
						
							|  |  |  |     del sys.modules["rna_wiki_reference"] | 
					
						
							|  |  |  |     return ret | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # hooks for doc lookups | 
					
						
							|  |  |  | _manual_map = [_blender_default_map] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-26 21:19:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-25 14:07:51 +00:00
										 |  |  | def register_manual_map(manual_hook): | 
					
						
							|  |  |  |     _manual_map.append(manual_hook) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-26 21:19:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-25 14:07:51 +00:00
										 |  |  | def unregister_manual_map(manual_hook): | 
					
						
							|  |  |  |     _manual_map.remove(manual_hook) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-26 21:19:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-25 14:07:51 +00:00
										 |  |  | def manual_map(): | 
					
						
							|  |  |  |     # reverse so default is called last | 
					
						
							|  |  |  |     for cb in reversed(_manual_map): | 
					
						
							|  |  |  |         try: | 
					
						
							|  |  |  |             prefix, url_manual_mapping = cb() | 
					
						
							|  |  |  |         except: | 
					
						
							|  |  |  |             print("Error calling %r" % cb) | 
					
						
							|  |  |  |             import traceback | 
					
						
							|  |  |  |             traceback.print_exc() | 
					
						
							|  |  |  |             continue | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         yield prefix, url_manual_mapping |