]> SALOME platform Git repositories - tools/eficas.git/blobdiff - generator/generator_aplat.py
Salome HOME
onItem=Deplie
[tools/eficas.git] / generator / generator_aplat.py
index c12b6dacce712f3454e4d227adec941f544f8753..2935310bd87196ccf057ffe734bd61e305fb44b7 100644 (file)
@@ -1,3 +1,22 @@
+# -*- coding: utf-8 -*-
+# Copyright (C) 2007-2013   EDF R&D
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
+#
+# See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
+#
 """
     Ce module contient le plugin generateur de fichier au format 
     aplat pour EFICAS.
@@ -5,6 +24,8 @@
 """
 import traceback
 import types,string,re
+from Extensions.i18n import tr
+from Extensions.eficas_exception import EficasException
 
 from Noyau import N_CR
 from Noyau.N_utils import repr_float
@@ -40,8 +61,7 @@ class AplatGenerator:
 
        Ses caractéristiques principales sont exposées dans des attributs 
        de classe :
-
-       - extensions : qui donne une liste d'extensions de fichier préconisées
+         - extensions : qui donne une liste d'extensions de fichier préconisées
 
    """
    # Les extensions de fichier préconisées
@@ -65,12 +85,10 @@ class AplatGenerator:
       fp.write(self.text)
       fp.close()
 
-   def gener(self,obj,format='brut'):
+   def gener(self,obj,format='brut',config=None):
       """
-          Retourne une représentation du JDC obj sous une
-          forme qui est paramétrée par format.
-          Si format vaut 'brut', 'standard' ou 'beautifie', retourne le texte issu
-                       de generator
+          Retourne une représentation du JDC obj sous une forme qui est paramétrée par format.
+          Si format vaut 'brut', 'standard' ou 'beautifie', retourne le texte issu de generator
       """
       liste= self.generator(obj)
       if format == 'brut':
@@ -80,7 +98,7 @@ class AplatGenerator:
       elif format == 'beautifie':
          self.text=liste
       else:
-         raise "Format pas implémenté : "+format
+        raise EficasException(tr("Format pas implemente : %s", format))
       return self.text
 
    def generator(self,obj):
@@ -126,7 +144,8 @@ class AplatGenerator:
       elif isinstance(obj,MCNUPLET):
          return self.generMCNUPLET(obj)
       else:
-         raise "Type d'objet non prévu",obj
+         raise EficasException(tr("Format non implemente : %s", format))
+
 
    def generJDC(self,obj):
       """
@@ -189,7 +208,9 @@ class AplatGenerator:
          en une chaine de caractères à la syntaxe aplat 
       """
       if type(obj.valeur) == types.StringType:
-        return obj.nom + " = '" + obj.valeur + "';\n"
+        # PN pour corriger le bug a='3+4' au lieu de a= 3+4
+        #return obj.nom + " = '" + obj.valeur + "';\n"
+        return obj.nom + " = " + obj.valeur + ";\n"
       else:
         return obj.nom + ' = ' + str(obj.valeur) + ';\n'
 
@@ -268,7 +289,7 @@ class AplatGenerator:
       text = ''
       init = self.init + self.sep + obj.nom
       old_init=self.init
-      for data in self.data :
+      for data in obj.data :
         i=i+1
         self.init = init + self.sep + "occurrence n°"+`i`
         text = text + self.generator(data)
@@ -283,7 +304,7 @@ class AplatGenerator:
       if type(obj.valeur) in (types.TupleType,types.ListType) :
          # On est en présence d'une liste de valeur
          rep = '('
-         for val in self.valeur:
+         for val in obj.valeur:
            if type(val) == types.InstanceType :
              rep = rep + self.generator(val) +','
            else: