-
-
Notifications
You must be signed in to change notification settings - Fork 142
/
Copy path__init__.py
108 lines (76 loc) · 2.82 KB
/
__init__.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
import logging
import bpy
import addon_utils
from bpy.app import background
bl_info = {
"name": "CAD Sketcher",
"author": "hlorus",
"version": (0, 27, 6),
"blender": (3, 3, 0),
"location": "View3D > Toolbar",
"description": "Parametric, constraint-based geometry sketcher",
"warning": "Experimental",
"category": "3D View",
"doc_url": "https://hlorus.github.io/CAD_Sketcher",
"tracker_url": "https://github.com/hlorus/CAD_Sketcher/discussions/categories/announcements",
}
def get_addon_version_tuple() -> tuple:
"""Return addon version as a tuple e.g. (0, 27, 1)"""
for mod in addon_utils.modules():
if mod.__name__ == __package__:
return addon_utils.module_bl_info(mod).get("version", (0, 0, 0))
return (0, 0, 0)
def get_addon_version() -> str:
"""Return addon version as string"""
version = get_addon_version_tuple()
return ".".join(map(str, version))
def get_min_blender_version() -> tuple:
"""Returns the minimal required blender version from manifest file"""
for mod in addon_utils.modules():
if mod.__name__ == __package__:
return addon_utils.module_bl_info(mod).get("blender", (0, 0, 0))
return (0, 0, 0)
# Check user's Blender version against minimum required Blender version for add-on.
if bpy.app.version < get_min_blender_version():
raise Exception(
"This add-on is only compatible with Blender versions "
f"{get_min_blender_version()} or greater.\n"
)
from . import global_data
from .registration import register_base, unregister_base, register_full, unregister_full
from .utilities.install import check_module
from .utilities.register import cleanse_modules
from .utilities.presets import ensure_addon_presets
from .utilities.logging import setup_logger, update_logger
# Globals
logger = logging.getLogger(__name__)
def register():
# Setup root logger
setup_logger(logger)
# Register base
ensure_addon_presets()
register_base()
update_logger(logger)
if not background:
from . import icon_manager
icon_manager.load()
logger.info("Enabled CAD Sketcher base, version: {}".format(get_addon_version()))
# Check Module and register all modules
try:
check_module("py_slvs", raise_exception=True)
register_full()
global_data.registered = True
logger.info("Solvespace available, fully registered modules")
except ModuleNotFoundError as e:
global_data.registered = False
logger.warning(
"Solvespace module isn't available, only base modules registered\n" + str(e)
)
def unregister():
if not background:
from . import icon_manager
icon_manager.unload()
if global_data.registered:
unregister_full()
unregister_base()
cleanse_modules(__package__)