Adding support for calculate window size while C generating
authorlbessard
Mon, 30 Jun 2008 17:04:25 +0200 (2008-06-30)
changeset 189 48ba1ae12ffd
parent 188 e152b46cd9b0
child 190 be969d4694c7
Adding support for calculate window size while C generating
plugins/svgui/svgui.py
--- a/plugins/svgui/svgui.py	Mon Jun 30 14:31:18 2008 +0200
+++ b/plugins/svgui/svgui.py	Mon Jun 30 17:04:25 2008 +0200
@@ -11,6 +11,7 @@
 from FBD_Objects import *
 
 from wxPopen import ProcessLogger
+from wx.wxsvg import SVGDocument
 
 [ID_SVGUIEDITORFBDPANEL, 
 ] = [wx.NewId() for _init_ctrls in range(1)]
@@ -180,8 +181,13 @@
     def PlugGenerate_C(self, buildpath, locations, logger):
         progname = "SVGUI_%s"%"_".join(map(str, self.GetCurrentLocation()))
         
+        doc = SVGDocument(self.GetSVGFilePath())
+        root_element = doc.GetRootElement()
+        window_size = (int(root_element.GetAttribute("width")),
+                       int(root_element.GetAttribute("height")))
+        
         generator = _SVGUICGenerator(self.GetElementsByType(), self.GetSVGFilePath(), self.GetFilePath(), self.GetCurrentLocation())
-        generator.GenerateProgram((0, 0), buildpath, progname)
+        generator.GenerateProgram(window_size, buildpath, progname)
         Gen_C_file = os.path.join(buildpath, progname+".cpp" )
         
         if wx.Platform == '__WXMSW__':
@@ -363,7 +369,6 @@
 
 """
 
-#        text += "pthread_t wxMainLoop,automate;\n"
         text += """int myargc = 0;
 char** myargv = NULL;
         
@@ -385,31 +390,18 @@
 }
 
 """
-#        text += """void* SimulAutomate(void* args)
-#{
-#  while(1){
-#    myapp->frame->m_svgCtrl->IN_"+self.BusNumber+"();
-#    //printf(\"AUTOMATE\\n\");
-#    myapp->frame->m_svgCtrl->OUT_"+self.BusNumber+"();
-#    sleep(1);
-#  }
-#  return args;
-#}
-#
-#"""
-      
+
         text += """bool SVGViewApp::OnInit()
 {
   #ifndef __WXMSW__
     setlocale(LC_NUMERIC, "C");
   #endif
 """
-        #text += "  frame = new MainFrame(NULL, wxT(\"Program\"),wxDefaultPosition, wxSize(%d, %d));\n"%size
-        text += """  frame = new MainFrame(NULL, wxT("Program"),wxDefaultPosition, wxDefaultSize);
+        
+        text += """  frame = new MainFrame(NULL, wxT("Program"),wxDefaultPosition, wxSize(%d, %d));
   frame->Show();
   myapp = this;
-"""
-#        text += "  pthread_create(&automate, NULL, SimulAutomate, NULL);\n"
+"""%size
         text += """  return true;
 }