diff -r a73fde048749 -r c9ace6a881c9 CodeFileTreeNode.py
--- a/CodeFileTreeNode.py Wed May 08 18:33:49 2013 +0200
+++ b/CodeFileTreeNode.py Wed May 08 21:37:31 2013 +0200
@@ -4,246 +4,142 @@
from xmlclass import *
-from CFileEditor import CFileEditor
-from PLCControler import UndoBuffer, LOCATION_CONFNODE, LOCATION_VAR_INPUT, LOCATION_VAR_OUTPUT
+from PLCControler import UndoBuffer
+from editors.CodeFileEditor import SECTIONS_NAMES
-CFileClasses = GenerateClassesFromXSD(os.path.join(os.path.dirname(__file__), "cext_xsd.xsd"))
+CodeFileClasses = GenerateClassesFromXSD(os.path.join(os.path.dirname(__file__), "code_file.xsd"))
-TYPECONVERSION = {"BOOL" : "X", "SINT" : "B", "INT" : "W", "DINT" : "D", "LINT" : "L",
- "USINT" : "B", "UINT" : "W", "UDINT" : "D", "ULINT" : "L", "REAL" : "D", "LREAL" : "L",
- "STRING" : "B", "BYTE" : "B", "WORD" : "W", "DWORD" : "D", "LWORD" : "L", "WSTRING" : "W"}
-
-class CFile:
- XSD = """
-
-
-
-
-
-
-
-
- """
- EditorType = CFileEditor
+class CodeFile:
def __init__(self):
- filepath = self.CFileName()
+ filepath = self.CodeFileName()
- self.CFile = CFileClasses["CFile"]()
+ self.CodeFile = CodeFileClasses["CodeFile"]()
if os.path.isfile(filepath):
xmlfile = open(filepath, 'r')
tree = minidom.parse(xmlfile)
xmlfile.close()
for child in tree.childNodes:
- if child.nodeType == tree.ELEMENT_NODE and child.nodeName == "CFile":
- self.CFile.loadXMLTree(child, ["xmlns", "xmlns:xsi", "xsi:schemaLocation"])
- self.CreateCFileBuffer(True)
+ if child.nodeType == tree.ELEMENT_NODE and child.nodeName == "CodeFile":
+ self.CodeFile.loadXMLTree(child, ["xmlns", "xmlns:xsi", "xsi:schemaLocation"])
+ self.CreateCodeFileBuffer(True)
else:
- self.CreateCFileBuffer(False)
+ self.CreateCodeFileBuffer(False)
self.OnCTNSave()
- def GetIconName(self):
- return "Cfile"
-
- def CFileName(self):
- return os.path.join(self.CTNPath(), "cfile.xml")
-
def GetBaseTypes(self):
return self.GetCTRoot().GetBaseTypes()
- def GetDataTypes(self, basetypes = False, only_locatables = False):
- return self.GetCTRoot().GetDataTypes(basetypes=basetypes, only_locatables=only_locatables)
-
- def GetSizeOfType(self, type):
- return TYPECONVERSION.get(self.GetCTRoot().GetBaseType(type), None)
+ def GetDataTypes(self, basetypes = False):
+ return self.GetCTRoot().GetDataTypes(basetypes=basetypes)
def SetVariables(self, variables):
- self.CFile.variables.setvariable([])
+ self.CodeFile.variables.setvariable([])
for var in variables:
- variable = CFileClasses["variables_variable"]()
+ variable = CodeFileClasses["variables_variable"]()
variable.setname(var["Name"])
variable.settype(var["Type"])
- variable.setclass(var["Class"])
- self.CFile.variables.appendvariable(variable)
+ variable.setinitial(var["Initial"])
+ self.CodeFile.variables.appendvariable(variable)
def GetVariables(self):
datas = []
- for var in self.CFile.variables.getvariable():
- datas.append({"Name" : var.getname(), "Type" : var.gettype(), "Class" : var.getclass()})
+ for var in self.CodeFile.variables.getvariable():
+ datas.append({"Name" : var.getname(), "Type" : var.gettype(), "Initial" : var.getinitial()})
return datas
- def SetPartText(self, name, text):
- if name == "Includes":
- self.CFile.includes.settext(text)
- elif name == "Globals":
- self.CFile.globals.settext(text)
- elif name == "Init":
- self.CFile.initFunction.settext(text)
- elif name == "CleanUp":
- self.CFile.cleanUpFunction.settext(text)
- elif name == "Retrieve":
- self.CFile.retrieveFunction.settext(text)
- elif name == "Publish":
- self.CFile.publishFunction.settext(text)
+ def SetTextParts(self, parts):
+ for section, code_object in zip(
+ SECTIONS_NAMES,
+ [self.CodeFile.includes,
+ self.CodeFile.globals,
+ self.CodeFile.initFunction,
+ self.CodeFile.cleanUpFunction,
+ self.CodeFile.retrieveFunction,
+ self.CodeFile.publishFunction]):
+ code_object.settext(parts[section])
- def GetPartText(self, name):
- if name == "Includes":
- return self.CFile.includes.gettext()
- elif name == "Globals":
- return self.CFile.globals.gettext()
- elif name == "Init":
- return self.CFile.initFunction.gettext()
- elif name == "CleanUp":
- return self.CFile.cleanUpFunction.gettext()
- elif name == "Retrieve":
- return self.CFile.retrieveFunction.gettext()
- elif name == "Publish":
- return self.CFile.publishFunction.gettext()
- return ""
+ def GetTextParts(self):
+ parts = {}
+ for section, code_object in zip(
+ SECTIONS_NAMES,
+ [self.CodeFile.includes,
+ self.CodeFile.globals,
+ self.CodeFile.initFunction,
+ self.CodeFile.cleanUpFunction,
+ self.CodeFile.retrieveFunction,
+ self.CodeFile.publishFunction]):
+ parts[section] = code_object.gettext()
+ return parts
def CTNTestModified(self):
- return self.ChangesToSave or not self.CFileIsSaved()
+ return self.ChangesToSave or not self.CodeFileIsSaved()
def OnCTNSave(self, from_project_path=None):
- filepath = self.CFileName()
+ filepath = self.CodeFileName()
text = "\n"
extras = {"xmlns":"http://www.w3.org/2001/XMLSchema",
"xmlns:xsi":"http://www.w3.org/2001/XMLSchema-instance",
- "xsi:schemaLocation" : "cext_xsd.xsd"}
- text += self.CFile.generateXMLText("CFile", 0, extras)
+ "xsi:schemaLocation" : "codefile.xsd"}
+ text += self.CodeFile.generateXMLText("CodeFile", 0, extras)
xmlfile = open(filepath,"w")
xmlfile.write(text.encode("utf-8"))
xmlfile.close()
- self.MarkCFileAsSaved()
+ self.MarkCodeFileAsSaved()
return True
def CTNGlobalInstances(self):
current_location = self.GetCurrentLocation()
- return [("%s_%s" % (
- variable.getname(),"_".join(map(str, current_location))),
- variable.gettype())
- for variable in self.CFile.variables.variable]
-
- def CTNGenerate_C(self, buildpath, locations):
- """
- Generate C code
- @param current_location: Tupple containing confnode IEC location : %I0.0.4.5 => (0,0,4,5)
- @param locations: List of complete variables locations \
- [{"IEC_TYPE" : the IEC type (i.e. "INT", "STRING", ...)
- "NAME" : name of the variable (generally "__IW0_1_2" style)
- "DIR" : direction "Q","I" or "M"
- "SIZE" : size "X", "B", "W", "D", "L"
- "LOC" : tuple of interger for IEC location (0,1,2,...)
- }, ...]
- @return: [(C_file_name, CFLAGS),...] , LDFLAGS_TO_APPEND
- """
- current_location = self.GetCurrentLocation()
- # define a unique name for the generated C file
- location_str = "_".join(map(str, current_location))
-
- text = "/* Code generated by Beremiz c_ext confnode */\n\n"
- text += "#include "
-
- # Adding includes
- text += "/* User includes */\n"
- text += self.CFile.includes.gettext()
- text += "\n"
-
- text += '#include "iec_types_all.h"'
-
- # Adding variables
- base_types = self.GetCTRoot().GetBaseTypes()
- config = self.GetCTRoot().GetProjectConfigNames()[0]
- text += "/* User variables reference */\n"
- for variable in self.CFile.variables.variable:
- var_infos = {
- "name": variable.getname(),
- "global": "%s__%s_%s" % (config.upper(),
- variable.getname().upper(),
- location_str),
- "type": "__IEC_%s_t" % variable.gettype()}
- text += "extern %(type)s %(global)s;\n" % var_infos
- text += "#define %(name)s %(global)s.value\n" % var_infos
- text += "\n"
-
- # Adding user global variables and routines
- text += "/* User internal user variables and routines */\n"
- text += self.CFile.globals.gettext()
-
- # Adding Beremiz confnode functions
- text += "/* Beremiz confnode functions */\n"
- text += "int __init_%s(int argc,char **argv)\n{\n"%location_str
- text += self.CFile.initFunction.gettext()
- text += " return 0;\n"
- text += "\n}\n\n"
-
- text += "void __cleanup_%s(void)\n{\n"%location_str
- text += self.CFile.cleanUpFunction.gettext()
- text += "\n}\n\n"
-
- text += "void __retrieve_%s(void)\n{\n"%location_str
- text += self.CFile.retrieveFunction.gettext()
- text += "\n}\n\n"
-
- text += "void __publish_%s(void)\n{\n"%location_str
- text += self.CFile.publishFunction.gettext()
- text += "\n}\n\n"
-
- Gen_Cfile_path = os.path.join(buildpath, "CFile_%s.c"%location_str)
- cfile = open(Gen_Cfile_path,'w')
- cfile.write(text)
- cfile.close()
-
- matiec_flags = '"-I%s"'%os.path.abspath(self.GetCTRoot().GetIECLibPath())
-
- return [(Gen_Cfile_path, str(self.CExtension.getCFLAGS() + matiec_flags))],str(self.CExtension.getLDFLAGS()),True
-
+ return [(variable.getname(),
+ variable.gettype(),
+ variable.getinitial())
+ for variable in self.CodeFile.variables.variable]
#-------------------------------------------------------------------------------
# Current Buffering Management Functions
#-------------------------------------------------------------------------------
"""
- Return a copy of the cfile model
+ Return a copy of the codefile model
"""
def Copy(self, model):
return cPickle.loads(cPickle.dumps(model))
- def CreateCFileBuffer(self, saved):
+ def CreateCodeFileBuffer(self, saved):
self.Buffering = False
- self.CFileBuffer = UndoBuffer(cPickle.dumps(self.CFile), saved)
+ self.CodeFileBuffer = UndoBuffer(cPickle.dumps(self.CodeFile), saved)
- def BufferCFile(self):
- self.CFileBuffer.Buffering(cPickle.dumps(self.CFile))
+ def BufferCodeFile(self):
+ self.CodeFileBuffer.Buffering(cPickle.dumps(self.CodeFile))
def StartBuffering(self):
self.Buffering = True
def EndBuffering(self):
if self.Buffering:
- self.CFileBuffer.Buffering(cPickle.dumps(self.CFile))
+ self.CodeFileBuffer.Buffering(cPickle.dumps(self.CodeFile))
self.Buffering = False
- def MarkCFileAsSaved(self):
+ def MarkCodeFileAsSaved(self):
self.EndBuffering()
- self.CFileBuffer.CurrentSaved()
+ self.CodeFileBuffer.CurrentSaved()
- def CFileIsSaved(self):
- return self.CFileBuffer.IsCurrentSaved() and not self.Buffering
+ def CodeFileIsSaved(self):
+ return self.CodeFileBuffer.IsCurrentSaved() and not self.Buffering
def LoadPrevious(self):
self.EndBuffering()
- self.CFile = cPickle.loads(self.CFileBuffer.Previous())
+ self.CodeFile = cPickle.loads(self.CodeFileBuffer.Previous())
def LoadNext(self):
- self.CFile = cPickle.loads(self.CFileBuffer.Next())
+ self.CodeFile = cPickle.loads(self.CodeFileBuffer.Next())
def GetBufferState(self):
- first = self.CFileBuffer.IsFirst() and not self.Buffering
- last = self.CFileBuffer.IsLast()
+ first = self.CodeFileBuffer.IsFirst() and not self.Buffering
+ last = self.CodeFileBuffer.IsLast()
return not first, not last