1 # -*- coding: utf-8 -*-
2 # Copyright (C) 2010 EDF R&D
4 # This library is free software; you can redistribute it and/or
5 # modify it under the terms of the GNU Lesser General Public
6 # License as published by the Free Software Foundation; either
7 # version 2.1 of the License.
9 # This library is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 # Lesser General Public License for more details.
14 # You should have received a copy of the GNU Lesser General Public
15 # License along with this library; if not, write to the Free Software
16 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
18 # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
27 from Ihm import CONNECTOR
29 import adaoStudyEditor
35 self.name = "not yet defined" # Name of the case
37 self.filename = "not yet defined" # Python filename generated by Eficas
38 self.yacs_filename = "not yet defined" # Yacs schema filename
40 self.salome_study_id = -1 # Study of the case
41 self.salome_study_item = None # Study item object
43 self.eficas_editor = None # Editor object from Eficas
45 def setEditor(self, editor):
46 if editor is not self.eficas_editor:
47 self.eficas_editor = editor
49 CONNECTOR.Connect(self.eficas_editor.jdc, "valid", self.editorValidEvent, ())
51 # Rq on notera que l'on utilise isvalid dans isOk
52 # et que isOk appelle editorValidEvent
53 # il n'y a pas de boucle infini car isvalid n'émet
54 # son signal que si l'état a changé
55 def editorValidEvent(self):
56 adaoStudyEditor.updateItem(self.salome_study_id, self.salome_study_item, self)
57 adaoGuiHelper.refreshObjectBrowser()
60 if self.eficas_editor.jdc:
61 return self.eficas_editor.jdc.isvalid()
64 def createYACSFile(self):
66 if (self.filename == ""):
67 return "You need to save your case to export it"
69 self.eficas_editor.modified = True
70 self.eficas_editor.saveFile()
71 filename = self.filename[:self.filename.rfind(".")] + '.py'
72 if not os.path.exists(filename):
73 msg = "Cannot find the py file for YACS generation \n"
74 msg += "Is your case correct ? \n"
77 if not os.environ.has_key("ADAO_ROOT_DIR"):
78 return "Please add ADAO_ROOT_DIR to your environnement"
80 adao_path = os.environ["ADAO_ROOT_DIR"]
81 adao_exe = adao_path + "/bin/salome/AdaoYacsSchemaCreator.py"
82 self.yacs_filename = self.filename[:self.filename.rfind(".")] + '.xml'
83 args = ["python", adao_exe, filename, self.yacs_filename]
84 p = subprocess.Popen(args)
85 (stdoutdata, stderrdata) = p.communicate()
86 if not os.path.exists(self.yacs_filename):
87 msg = "An error occured during the execution of AdaoYacsSchemaCreator.py \n"
88 msg += "See erros details in your terminal \n"
92 def exportCaseToYACS(self):
94 rtn = self.createYACSFile()
100 yacs_swig = libYACS_Swig.YACS_Swig()
101 yacs_swig.loadSchema(self.yacs_filename)
103 msg = "Please install YACS module, error was: \n"
104 msg += traceback.format_exc()