Fixed bug when modifying project properties
authorLaurent Bessard
Mon, 09 Sep 2013 23:36:51 +0200 (2013-09-09)
changeset 1309 85ce56758900
parent 1308 ad61268dbdb6
child 1310 3d7fa2257b24
Fixed bug when modifying project properties
plcopen/plcopen.py
--- a/plcopen/plcopen.py	Mon Sep 09 23:36:12 2013 +0200
+++ b/plcopen/plcopen.py	Mon Sep 09 23:36:51 2013 +0200
@@ -27,7 +27,6 @@
 from types import *
 import os, re
 from lxml import etree
-from collections import OrderedDict
 """
 Dictionary that makes the relation between var names in plcopen and displayed values
 """
@@ -269,8 +268,12 @@
     
     def setfileHeader(self, fileheader):
         fileheader_obj = self.fileHeader
-        for attr, value in fileheader.iteritems():
-            setattr(fileheader_obj, attr, value)
+        for attr in ["companyName", "companyURL", "productName",
+                     "productVersion", "productRelease", "creationDateTime",
+                     "contentDescription"]:
+            value = fileheader.get(attr)
+            if value is not None:
+                setattr(fileheader_obj, attr, value)
     setattr(cls, "setfileHeader", setfileHeader)
     
     def getcontentHeader(self):
@@ -297,11 +300,13 @@
                 contentheader_obj.setname(value)
             elif attr == "projectVersion":
                 contentheader_obj.setversion(value)
+            elif attr == "authorName":
+                contentheader_obj.setauthor(value)
             elif attr == "pageSize":
                 contentheader_obj.setpageSize(*contentheader["pageSize"])
             elif attr == "scaling":
                 contentheader_obj.setscaling(contentheader["scaling"])
-            else:
+            elif attr in ["modificationDateTime", "organization", "language"]:
                 setattr(contentheader_obj, attr, value)
     setattr(cls, "setcontentHeader", setcontentHeader)
     
@@ -603,7 +608,7 @@
         var = PLCOpenParser.CreateElement("variable", "varListPlain")
         var.setname(name)
         var_type_obj = PLCOpenParser.CreateElement("dataType")
-        if var_type in [x for x,y in TypeHierarchy_list if not x.startswith("ANY")]:
+        if not var_type.startswith("ANY") and TypeHierarchy.get(var_type):
             var_type_obj.setcontent(PLCOpenParser.CreateElement(
                 var_type.lower() if var_type in ["STRING", "WSTRING"]
                 else vartype, "dataType"))
@@ -1162,7 +1167,7 @@
         var = PLCOpenParser.CreateElement("variable", "varListPlain")
         var.setname(name)
         var_type_obj = PLCOpenParser.CreateElement("type", "variable")
-        if var_type in [x for x,y in TypeHierarchy_list if not x.startswith("ANY")]:
+        if not var_type.startswith("ANY") and TypeHierarchy.get(var_type):
             var_type_obj.setcontent(PLCOpenParser.CreateElement(
                 var_type.lower() if var_type in ["STRING", "WSTRING"]
                 else var_type, "dataType"))