diff pyink/domview.py @ 1342:972d749b9656

Move component_manager to a separated object. - component_manager is a mixin for domview. - domview inherit component_manager to mixing-in component_manager. - There is no boundary between component_manager and domview, hard to be managed and reused. - component_manager is a separated object that hold a reference to corresponding domview. - domview delegate attribute accessing to component_manager object to expose attributes and methods of component_manager. (__getattr__()) - component_manager is still a mix-in of domview.
author Thinker K.F. Li <thinker@codemud.net>
date Tue, 08 Feb 2011 13:05:07 +0800
parents 10d5f06f7566
children c2fbae4f0adc
line wrap: on
line diff
--- a/pyink/domview.py	Mon Feb 07 21:54:03 2011 +0800
+++ b/pyink/domview.py	Tue Feb 08 13:05:07 2011 +0800
@@ -48,8 +48,8 @@
     #
     # \param comp_node is None for main component.
     #
-    def __init__(self, comp_mgr, comp_node):
-        self._comp_mgr = comp_mgr
+    def __init__(self, domview, comp_node):
+        self._domview = domview
         self.node = comp_node
         self.layers = []
         self.timelines = []
@@ -66,11 +66,11 @@
                 break
             pass
         else:                   # no any ns0:scenes
-            doc = self._comp_mgr._doc
+            doc = self._domview._doc
             scenes_node = doc.createElement('ns0:scenes')
             scenes_node.setAttribute('name', 'default')
             
-            node_id = self._comp_mgr.new_id()
+            node_id = self._domview.new_id()
             scenes_node.setAttribute('id', node_id)
             
             comp_node.appendChild(scenes_node)
@@ -126,12 +126,12 @@
             raise ValueError, \
                 'try add a timeline with duplicated name - %s' % (name)
         
-        doc = self._comp_mgr._doc
+        doc = self._domview._doc
         comp_node = self.node
         
         scenes_node = doc.createElement('ns0:scenes')
         scenes_node.setAttribute('name', name)
-        node_id = self._comp_mgr.new_id()
+        node_id = self._domview.new_id()
         scenes_node.setAttribute('id', node_id)
 
         comp_node.appendChild(scenes_node)
@@ -236,7 +236,8 @@
 # removed and normalized to normal components.
 #
 class component_manager(component_manager_ui_update):
-    def __init__(self):
+    def __init__(self, domview):
+        super(component_manager, self).__init__()
         self._components_node = None
         self._components = []
         self._comp_names = set()
@@ -244,12 +245,14 @@
         self._cur_comp = None
         self._cur_timeline = None
         self._components_group = None
+        
+        self._domview = domview
         pass
 
     def _set_main_component(self):
-        comp = Component(self, None)
-        comp.layers = self._layers
-        scenes_node = self._scenes_node
+        comp = Component(self._domview, None)
+        comp.layers = self._domview._layers
+        scenes_node = self._domview._scenes_node
         timeline = Timeline(scenes_node)
         comp.timelines = [timeline]
 
@@ -269,7 +272,7 @@
             if child_name in comp_names:
                 raise ValueError, 'duplicate component name %s' % (child_name)
 
-            comp = Component(self, child)
+            comp = Component(self._domview, child)
             comp.parse_timelines()
             
             self._components.append(comp)
@@ -282,7 +285,7 @@
     # This method is called by domview._init_metadata().
     #
     def _component_manager_init_metadata(self):
-        metadata_node = self._metadata_node
+        metadata_node = self._domview._metadata_node
 
         # Make sure ns0:components in metadata
 	for n in metadata_node.childList():
@@ -291,13 +294,14 @@
 		break
 	    pass
 	else:
-	    components_node = self._doc.createElement("ns0:components")
+	    components_node = \
+                self._domview._doc.createElement("ns0:components")
 	    metadata_node.appendChild(components_node)
 	    self._components_node = components_node
 	    pass
         
         # Make sure the group for containing components.
-        for n in self._root.childList():
+        for n in self._domview._root.childList():
             if n.name() != 'svg:g':
                 continue
             try:
@@ -309,12 +313,12 @@
                 break
             pass
         else:                   # no components group
-            components_group = self._doc.createElement('svg:g')
+            components_group = self._domview._doc.createElement('svg:g')
             components_group.setAttribute('inkscape:label', 'components')
-            gid = self.new_id()
+            gid = self._domview.new_id()
             components_group.setAttribute('id', gid)
             
-            self._root.appendChild(components_group)
+            self._domview._root.appendChild(components_group)
             self._components_group = components_group
             pass
         pass
@@ -327,7 +331,7 @@
         self._cur_comp = self._main_comp
         tl = self._main_comp.get_timeline('default')
         self._cur_timeline = tl
-        self._scenes_node = tl.scenes_node
+        self._domview._scenes_node = tl.scenes_node
         pass
 
     ## \brief Create component group
@@ -336,16 +340,16 @@
     # The layers group is where layer groups is in.
     #
     def _create_component_group(self):
-        doc = self._doc
+        doc = self._domview._doc
         group = doc.createElement('svg:g')
-        gid = self.new_id()
+        gid = self._domview.new_id()
         group.setAttribute('id', gid)
         
         self._components_group.appendChild(group)
 
         # Create layers group
         layers_group = doc.createElement('svg:g')
-        gid = self.new_id()
+        gid = self._domview.new_id()
         layers_group.setAttribute('id', gid)
         layers_group.setAttribute('inkscape:label', 'layers')
         group.appendChild(layers_group)
@@ -359,8 +363,8 @@
     # \return a ns0:component node.
     #
     def _create_component_node(self, comp_name, comp_group_id):
-        comp_node = self._doc.createElement('ns0:component')
-        comp_id = self.new_id()
+        comp_node = self._domview._doc.createElement('ns0:component')
+        comp_id = self._domview.new_id()
         comp_node.setAttribute('id', comp_id)
         comp_node.setAttribute('name', comp_name)
         comp_node.setAttribute('ref', comp_group_id)
@@ -381,8 +385,8 @@
     ## \brief Create a layer group for give layer of a component.
     #
     def _create_comp_layer_group(self, layers_group, layer_name):
-        doc = self._doc
-        gid = self.new_id()
+        doc = self._domview._doc
+        gid = self._domview.new_id()
         
         layer_group = doc.createElement('svg:g')
         layer_group.setAttribute('id', gid)
@@ -404,7 +408,7 @@
 
     def _get_layers_group_of_component(self, comp_name):
         if comp_name == 'main':
-            return self._root
+            return self._domview._root
         
         comp_group = self.get_component_group(comp_name)
         layers_group = comp_group.firstChild()
@@ -449,10 +453,11 @@
         
         comp = self._get_component(comp_name)
         self._cur_comp = comp
-        self._layers = comp.layers
+        self._domview._layers = comp.layers
         comp_name = self._cur_comp.name()
         # for domview
-        self._layers_parent = self._get_layers_group_of_component(comp_name)
+        self._domview._layers_parent = \
+            self._get_layers_group_of_component(comp_name)
         
         first_name = comp.all_timeline_names()[0]
         self.switch_timeline(first_name)
@@ -470,7 +475,7 @@
         comp_group_id = comp_group.getAttribute('id')
         comp_node = self._create_component_node(comp_name, comp_group_id)
         
-        comp = Component(self, comp_node)
+        comp = Component(self._domview, comp_node)
         comp.parse_timelines()
 
         self._components.append(comp)
@@ -486,7 +491,7 @@
         pass
 
     def add_component_node(self, comp_node):
-        comp = Component(self, comp_node)
+        comp = Component(self._domview, comp_node)
         comp_name = comp.name()
         if self.has_component(comp_name):
             raise ValueError, \
@@ -518,11 +523,11 @@
         
         comp_name = comp.name()
         if comp_name == 'main':
-            return self._root
+            return self._domview._root
         
         comp_node = comp.node
         gid = comp_node.getAttribute('ref')
-        comp_group = self.get_node(gid)
+        comp_group = self._domview.get_node(gid)
         return comp_group
 
     def get_current_component(self):
@@ -531,10 +536,10 @@
     def switch_timeline(self, timeline_name):
         tl = self._cur_comp.get_timeline(timeline_name)
         self._cur_timeline = tl
-        self._scenes_node = tl.scenes_node # of class domview
+        self._domview._scenes_node = tl.scenes_node # of class domview
 
         # Make domview to rescan layers and scenes.
-        self.reset()            # from domview
+        self._domview.reset()            # from domview
         pass
 
     def add_timeline(self, timeline_name):
@@ -589,10 +594,10 @@
     def link_to_component(self, comp_name, parent_group):
         layers_group = self._get_layers_group_of_component(comp_name)
         
-        use_node = self._doc.createElement('svg:use')
+        use_node = self._domview._doc.createElement('svg:use')
         layers_group_id = layers_group.getAttribute('id')
         use_node.setAttribute('xlink:href', '#' + layers_group_id)
-        use_node_id = self.new_id()
+        use_node_id = self._domview.new_id()
         use_node.setAttribute('id', use_node_id)
         use_node.setAttribute('use_component', 'true')
 
@@ -937,7 +942,7 @@
 # change and destroy scene node and scene group.  A scene node is a 'ns0:scene'
 # in 'ns0:scenes' tag.  A scene group is respective 'svg:g' for a scene.
 #
-class domview(domview_monitor, component_manager):
+class domview(domview_monitor):
     # Declare variables, here, for keeping tracking
     _doc = None
     _root = None
@@ -952,8 +957,19 @@
         self._scenes_node = None
         self._layers_parent = None
         self._layers = []
+
+        self._comp_mgr = component_manager(self)
 	pass
 
+    ## \brief Special method to get attribute.
+    #
+    # This method is here for delegating attribute accessing for
+    # mix-in.
+    #
+    def __getattr__(self, name):
+        val = getattr(self._comp_mgr, name)
+        return val
+
     ## \brief Create a scenes node if not existed.
     #
     def _init_metadata(self):
@@ -1018,7 +1034,7 @@
 	
 	self._init_metadata()
 	self._start_monitor()	# from domview_monitor
-        self._start_component_manager() # from component_manager
+        self._comp_mgr._start_component_manager()
 	self._parse_all_layers()
 	pass