1 # -*- coding: utf-8 -*-
2 # Copyright (C) 2007-2021 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
20 """Ce module contient le plugin generateur de fichier au format Code_Carmel3D pour EFICAS.
23 from __future__ import absolute_import
24 from __future__ import print_function
26 from builtins import str
31 from Extensions.i18n import tr
32 from .generator_python import PythonGenerator
36 Retourne les informations necessaires pour le chargeur de plugins
37 Ces informations sont retournees dans un dictionnaire
42 # La factory pour creer une instance du plugin
43 'factory' : XMLGenerator,
47 class XMLGenerator(PythonGenerator):
49 Ce generateur parcourt un objet de type JDC et produit
50 un texte au format eficas et
53 # Les extensions de fichier permis?
56 #----------------------------------------------------------------------------------------
57 def gener(self,obj,format='brut',config=None,appliEficas=None):
61 self.texteXML=obj.toXml()
63 self.texteXML='erreur generation'
64 #print (self.texteXML)
67 self.textePourAide =""
69 # Cette instruction genere le contenu du fichier de commandes (persistance)
70 self.text=PythonGenerator.gener(self,obj,format)
74 #----------------------------------------------------------------------------------------
76 #----------------------------------------------------------------------------------------
79 #----------------------------------------------------------------------------------------
81 def writeDefault(self,fn) :
82 fileXML = fn[:fn.rfind(".")] + '.xml'
83 #filePyxb = fn[:fn.rfind(".")] + '.py'
84 fileBase = os.path.basename(fileXML)
85 fileBase = fileBase[:fileBase.rfind(".")] + '.py'
86 filePyxb = '/tmp/example_' + fileBase
88 #fileDico='/tmp/toto.xml'
89 #print (self.texteXML)
90 f = open( str(fileXML), 'w')
91 f.write(str(self.texteXML))
94 f = open( str(filePyxb), 'w')
95 self.textePourAide='txt=""'+'\n'+self.textePourAide
96 self.textePourAide=self.textePourAide+'print (txt)'+'\n'
97 f.write(str(self.textePourAide))
101 def generMCSIMP(self,obj) :
102 if obj.nom != 'Consigne' :
103 if obj.nom in self.dictNbNomObj.keys():
104 nomUtil = obj.nom + "_" + str(self.dictNbNomObj[obj.nom])
105 self.dictNbNomObj[obj.nom] += 1
108 self.dictNbNomObj[obj.nom] = 1
109 if obj.definition.avecBlancs : self.textePourAide += nomUtil + " = vimmpCase." + obj.getNomDsXML() + ".s\n"
110 else : self.textePourAide += nomUtil + " = vimmpCase." + obj.getNomDsXML() + "\n"
111 self.textePourAide +='txt += "' + nomUtil + '" + " = " +str( ' + nomUtil + ')+"\\n"'+ "\n"
115 s=PythonGenerator.generMCSIMP(self,obj)