Adding "ParameterValue" as optional parameter for "VAR" entries
authorlbessard
Thu, 06 Dec 2007 17:55:46 +0100
changeset 323 4df7e6d2d1db
parent 322 78615d6a8ddd
child 324 c6865f99747a
Adding "ParameterValue" as optional parameter for "VAR" entries
objdictgen/eds_utils.py
--- a/objdictgen/eds_utils.py	Tue Dec 04 08:10:23 2007 +0100
+++ b/objdictgen/eds_utils.py	Thu Dec 06 17:55:46 2007 +0100
@@ -58,12 +58,12 @@
                     "LOWLIMIT" : is_integer, "HIGHLIMIT" : is_integer,
                     "ACCESSTYPE" : lambda x: x.upper() in ACCESS_TRANSLATE.keys(),
                     "DEFAULTVALUE" : lambda x: True, "PDOMAPPING" : is_boolean,
-                    "OBJFLAGS" : is_integer}
+                    "OBJFLAGS" : is_integer, "PARAMETERVALUE" : lambda x: True,}
 
 # Define entry parameters by entry ObjectType number
 ENTRY_TYPES = {7 : {"name" : " VAR",
                     "require" : ["PARAMETERNAME", "DATATYPE", "ACCESSTYPE"],
-                    "optional" : ["OBJECTTYPE", "DEFAULTVALUE", "PDOMAPPING", "LOWLIMIT", "HIGHLIMIT", "OBJFLAGS"]},
+                    "optional" : ["OBJECTTYPE", "DEFAULTVALUE", "PDOMAPPING", "LOWLIMIT", "HIGHLIMIT", "OBJFLAGS", "PARAMETERVALUE"]},
                8 : {"name" : "n ARRAY",
                     "require" : ["PARAMETERNAME", "OBJECTTYPE", "SUBNUMBER"],
                     "optional" : ["OBJFLAGS"]},
@@ -379,6 +379,20 @@
                     attributes = "Attribute \"%s\" is"%unsupported[0]
                 raise SyntaxError, "Error on section \"[%s]\":\n%s unsupported for a%s entry"%(section_name, attributes, ENTRY_TYPES[objecttype]["name"])
             
+            if "PARAMETERVALUE" in values:
+                try:
+                    if values["DATATYPE"] in (0x09, 0x0A, 0x0B, 0x0F):
+                        values["PARAMETERVALUE"] = str(values["PARAMETERVALUE"])
+                    elif values["DATATYPE"] in (0x08, 0x11):
+                        values["PARAMETERVALUE"] = float(values["PARAMETERVALUE"])
+                    elif values["DATATYPE"] == 0x01:
+                        values["PARAMETERVALUE"] = {0 : True, 1 : False}[values["PARAMETERVALUE"]]
+                    else:
+                        if type(values["PARAMETERVALUE"]) != IntType and values["PARAMETERVALUE"].find("$NODEID") == -1:
+                            raise
+                except:
+                    raise SyntaxError, "Error on section \"[%s]\":\nParameterValue incompatible with DataType"%section_name
+            
             if "DEFAULTVALUE" in values:
                 try:
                     if values["DATATYPE"] in (0x09, 0x0A, 0x0B, 0x0F):
@@ -713,7 +727,9 @@
                 # First case, entry is a VAR
                 if values["OBJECTTYPE"] == 7:
                     # Take default value if it is defined
-                    if "DEFAULTVALUE" in values:
+                    if "PARAMETERVALUE" in values:
+                        value = values["PARAMETERVALUE"]
+                    elif "DEFAULTVALUE" in values:
                         value = values["DEFAULTVALUE"]
                     # Find default value for value type of the entry
                     else:
@@ -735,7 +751,9 @@
                         # Define value for all subindexes except the first 
                         for subindex in xrange(1, int(max_subindex) + 1):
                             # Take default value if it is defined and entry is defined
-                            if subindex in values["subindexes"] and "DEFAULTVALUE" in values["subindexes"][subindex]:
+                            if subindex in values["subindexes"] and "PARAMETERVALUE" in values["subindexes"][subindex]:
+                                value = values["subindexes"][subindex]["PARAMETERVALUE"]
+                            elif subindex in values["subindexes"] and "DEFAULTVALUE" in values["subindexes"][subindex]:
                                 value = values["subindexes"][subindex]["DEFAULTVALUE"]
                             # Find default value for value type of the subindex
                             elif subindex in values["subindexes"] or not consecutive: