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

plugin.py « extensions_framework « modules - git.blender.org/blender-addons.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 76f41930fdd8db58503a1d7f962d17d093b00003 (plain)
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
# -*- coding: utf8 -*-
#
# ***** BEGIN GPL LICENSE BLOCK *****
#
# --------------------------------------------------------------------------
# Blender 2.5 Extensions Framework
# --------------------------------------------------------------------------
#
# Authors:
# Doug Hammond
#
# 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.
#
# 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.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, see <http://www.gnu.org/licenses/>.
#
# ***** END GPL LICENCE BLOCK *****
#
import bpy

from extensions_framework import init_properties
from extensions_framework import log

class plugin(object):
	"""Base class for plugins which wish to make use of utilities
	provided in extensions_framework. Using the property_groups
	attribute and the install() and uninstall() methods, a large number
	of custom scene properties can be easily defined, displayed and
	managed.
	
	TODO: Rename, 'extension' would be more appropriate than 'plugin'
	
	"""
	
	"""The property_groups defines a list of declarative_property_group
	types to create in specified types during the initialisation of the
	plugin.
	Item format:
	('bpy.type prototype to attach to', <declarative_property_group>)
	
	Example item:
	('Scene', myaddon_property_group)
	In this example, a new property group will be attached to
	bpy.types.Scene and all of the properties described in that group
	will be added to it.
	See extensions_framework.declarative_property_group.
	
	"""
	property_groups = []
	
	@classmethod
	def install(r_class):
		"""Initialise this plugin. So far, all this does is to create
		custom property groups specified in the property_groups
		attribute.
		
		"""
		for property_group_parent, property_group in r_class.property_groups:
			call_init = False
			if property_group_parent is not None:
				prototype = getattr(bpy.types, property_group_parent)
				if not hasattr(prototype, property_group.__name__):
					init_properties(prototype, [{
						'type': 'pointer',
						'attr': property_group.__name__,
						'ptype': property_group,
						'name': property_group.__name__,
						'description': property_group.__name__
					}])
					call_init = True
			else:
				call_init = True
			
			if call_init:
				init_properties(property_group, property_group.properties)
		
		log('Extension "%s" initialised' % r_class.bl_label)
	
	@classmethod
	def uninstall(r_class):
		"""Unregister property groups in reverse order"""
		reverse_property_groups = [p for p in r_class.property_groups]
		reverse_property_groups.reverse()
		for property_group_parent, property_group in reverse_property_groups:
			prototype = getattr(bpy.types, property_group_parent)
			prototype.RemoveProperty(property_group.__name__)