]> SALOME platform Git repositories - modules/eficas.git/commitdiff
Salome HOME
PN version 7.3.29 d aster
authoreficas <>
Mon, 22 Nov 2004 15:38:36 +0000 (15:38 +0000)
committereficas <>
Mon, 22 Nov 2004 15:38:36 +0000 (15:38 +0000)
Noyau/N_FONCTION.py
Noyau/N_MCCOMPO.py
Noyau/properties.py
Validation/V_MCSIMP.py

index fc75656cffb76dd6f54f04bc89be658db474c13f..00a82552933b4e0a5658d77051e121c31f55cddd 100644 (file)
@@ -1,4 +1,4 @@
-#@ MODIF N_FONCTION Noyau  DATE 28/09/2004   AUTEUR DURAND C.DURAND 
+#@ MODIF N_FONCTION Noyau  DATE 20/10/2004   AUTEUR DURAND C.DURAND 
 # -*- coding: iso-8859-1 -*-
 #            CONFIGURATION MANAGEMENT OF EDF VERSION
 # ======================================================================
@@ -30,19 +30,52 @@ class formule(ASSD):
       ASSD.__init__(self,**args)
       self.nompar    =None
       self.expression=None
+
    def __call__(self,*val):
-      context=self.jdc.const_context
+      context={}
       i=0
       for param in self.nompar : 
          context[param]=val[i]
          i=i+1
       try :
-       exec(self.expression) in context
+       res=eval(self.expression,self.jdc.const_context, context)
       except :
        print 75*'!'
        print '! '+string.ljust('Erreur evaluation formule '+self.nom,72)+'!'
        print 75*'!'
        raise
-      res=context['____x']
-      del(context)
       return res
+
+   def setFormule(self,nom_para,texte):
+      """
+         Cette methode sert a initialiser les attributs
+         nompar, expression et code qui sont utilisés
+         dans l'évaluation de la formule
+      """
+      self.nompar     = nom_para
+      self.expression = texte
+      try :
+        self.code=compile(texte,texte,'eval')
+      except SyntaxError :
+        print 75*'!'
+        print '! '+string.ljust('Erreur evaluation formule '+self.nom,72)+'!'
+        print 75*'!'
+        raise
+
+   def __setstate__(self,state):
+      """
+         Cette methode sert a restaurer l'attribut code
+         lors d'un unpickle
+      """
+      self.__dict__.update(state)                  # update attributes
+      self.setFormule(self.nompar,self.expression) # restore code attribute
+      
+   def __getstate__(self):
+      """
+         Pour les formules, il faut enlever l'attribut code
+         qui n'est pas picklable
+      """
+      d=ASSD.__getstate__(self)
+      del d['code']
+      return d
+
index dfc371ed8e5a706c49d5d23b590de4877a7a8d37..a587e0d7deaec6483032713e791a314a95389b0c 100644 (file)
@@ -1,4 +1,4 @@
-#@ MODIF N_MCCOMPO Noyau  DATE 14/09/2004   AUTEUR MCOURTOI M.COURTOIS 
+#@ MODIF N_MCCOMPO Noyau  DATE 20/10/2004   AUTEUR DURAND C.DURAND 
 # -*- coding: iso-8859-1 -*-
 #            CONFIGURATION MANAGEMENT OF EDF VERSION
 # ======================================================================
index f6bb7c467816985f9da74910c0460cd45ef33ee1..1cb28aa2b211a5d3be5fecb894d719360dbadd73 100644 (file)
@@ -19,6 +19,6 @@
 #                                                                       
 #                                                                       
 # ======================================================================
-version = "6.2.24"
-date = "15/03/2002"
+version = "7.4.0"
+date = "22/11/2004"
 
index c3e28c5979c8ed980d85dd1955b4ff1dc96d4ea5..9735364528b06d6a6744045b33e1dfdc307494e8 100644 (file)
@@ -112,12 +112,6 @@ class MCSIMP:
               valid=0
            # fin des validateurs
            #
-       # cas d un item Parametre
-       if self.valeur.__class__.__name__ == 'ITEM_PARAMETRE':
-          valid=self.valeur.isvalid()
-          if valid == 0:
-              if cr == 'oui' :
-                self.cr.fatal(string.join( repr (self.valeur), " a un indice incorrect"))
 
         self.set_valid(valid)
         return self.valid
@@ -273,11 +267,7 @@ class MCSIMP:
           return 0
       elif type(valeur) not in (types.IntType,types.FloatType,types.LongType):
         # ce n'est pas un réel
-       try :
-         valeur=valeur +1
-         return 1
-       except:
-          return 0
+        return 0
       else:
         return 1
 
@@ -331,11 +321,6 @@ class MCSIMP:
           # on a à faire à un PARAMETRE qui définit une liste d'items
           # --> on teste sur la première car on n'accepte que les liste homogènes
           valeur = valeur.valeur[0]
-
-      if valeur.__class__.__name__ == 'PARAMETRE' or valeur.__class__.__name__ == 'ITEM_PARAMETRE':
-       # on admet que c'est OK
-       return 1
-
       if type_permis == 'R':
         return self.is_reel(valeur)
       elif type_permis == 'I':