Adding support for loading Profile dictionaries only if needed
authorLaurent Bessard
Thu, 13 Sep 2012 11:07:51 +0200 (2012-09-13)
changeset 2074 bf2fa4cb62a9
parent 2073 d14ab97a452a
child 2075 21eb91dc7071
Adding support for loading Profile dictionaries only if needed
etherlab/etherlab.py
--- a/etherlab/etherlab.py	Wed Sep 12 18:13:28 2012 +0200
+++ b/etherlab/etherlab.py	Thu Sep 13 11:07:51 2012 +0200
@@ -232,7 +232,7 @@
             }
         
         def _getCIA402AxisRef(self):
-            data = wx.TextDataObject(str(("%IW%s.0" % ".".join(map(str, self.GetCurrentLocation())), 
+            data = wx.TextDataObject(str(("%%IW%s.0" % ".".join(map(str, self.GetCurrentLocation())), 
                                           "location", "AXIS_REF", self.CTNName(), "")))
             dragSource = wx.DropSource(self.GetCTRoot().AppFrame)
             dragSource.SetData(data)
@@ -1149,6 +1149,22 @@
 
 EtherCATInfoClasses = GenerateClassesFromXSD(os.path.join(os.path.dirname(__file__), "EtherCATInfo.xsd")) 
 
+cls = EtherCATInfoClasses["EtherCATBase.xsd"].get("DictionaryType", None)
+if cls:
+    cls.loadXMLTreeArgs = None
+    
+    setattr(cls, "_loadXMLTree", getattr(cls, "loadXMLTree"))
+    
+    def loadXMLTree(self, *args):
+        self.loadXMLTreeArgs = args
+    setattr(cls, "loadXMLTree", loadXMLTree)
+
+    def load(self):
+        if self.loadXMLTreeArgs is not None:
+            self._loadXMLTree(*self.loadXMLTreeArgs)
+            self.loadXMLTreeArgs = None
+    setattr(cls, "load", load)
+
 cls = EtherCATInfoClasses["EtherCATInfo.xsd"].get("DeviceType", None)
 if cls:
     cls.DataTypes = None
@@ -1220,6 +1236,7 @@
         entries = {}
         
         for dictionary in self.GetProfileDictionaries():
+            dictionary.load()
             
             for object in dictionary.getObjects().getObject():
                 entry_index = object.getIndex().getcontent()