Salome HOME
CCAR: merge de la version de developpement V1_12a2 dans la branche principale
[tools/eficas.git] / Ihm / I_MCSIMP.py
index 0cf75cbf50e704feae5a30ca4f57133bc97dad7e..507cead75a6b56c7edebc6af905de397aa995797 100644 (file)
@@ -44,8 +44,10 @@ import Accas
 # fin attention
 
 from Extensions import parametre
+from Extensions import param2
 import I_OBJECT
 import CONNECTOR
+from I_VALIDATOR import ValError,listProto
 
 class MCSIMP(I_OBJECT.OBJECT):
 
@@ -74,8 +76,6 @@ class MCSIMP(I_OBJECT.OBJECT):
       return None
     elif type(self.valeur) == types.FloatType : 
       # Traitement d'un flottant isolé
-      # txt = repr_float(self.valeur)
-      # Normalement str fait un travail correct
       txt = str(self.valeur)
       clefobj=self.GetNomConcept()
       if self.jdc.appli.dict_reels.has_key(clefobj):
@@ -84,38 +84,28 @@ class MCSIMP(I_OBJECT.OBJECT):
     elif type(self.valeur) in (types.ListType,types.TupleType) :
       # Traitement des listes
       txt='('
-      i=0
+      sep=''
       for val in self.valeur:
         if type(val) == types.FloatType : 
-           # CCAR : Normalement str fait un travail correct
-           #txt=txt + i*',' + repr_float(val)
            clefobj=self.GetNomConcept()
            if self.jdc.appli.dict_reels.has_key(clefobj):
               if self.jdc.appli.dict_reels[clefobj].has_key(val):
-                 txt=txt + i*',' +self.jdc.appli.dict_reels[clefobj][val]
+                 txt=txt + sep +self.jdc.appli.dict_reels[clefobj][val]
               else :
-                 txt=txt + i*',' + str(val)
+                 txt=txt + sep + str(val)
            else :
-              txt=txt + i*',' + str(val)
-        elif isinstance(val,ASSD): 
-           txt = txt + i*',' + val.get_name()
-    #PN
-    # ajout du elif
-        elif type(val) == types.InstanceType and val.__class__.__name__ in  ('PARAMETRE','PARAMETRE_EVAL'):
-          txt = txt + i*','+ str(val) 
+              txt=txt + sep + str(val)
         else: 
-           txt = txt + i*','+ myrepr.repr(val)
-        i=1
+           txt = txt + sep+ str(val)
+        if len(txt) > 200:
+            #ligne trop longue, on tronque
+            txt=txt+" ..."
+            break
+        sep=','
       txt=txt+')'
-    elif isinstance(self.valeur,ASSD): 
-      # Cas des ASSD
-      txt=self.getval()
-    elif type(self.valeur) == types.InstanceType and self.valeur.__class__.__name__ in  ('PARAMETRE','PARAMETRE_EVAL'):
-      # Cas des PARAMETRES
-      txt=str(self.valeur)
     else:
       # Traitement des autres cas
-      txt = myrepr.repr(self.valeur)
+      txt = str(self.valeur)
 
     # txt peut etre une longue chaine sur plusieurs lignes.
     # Il est possible de tronquer cette chaine au premier \n et 
@@ -155,7 +145,7 @@ class MCSIMP(I_OBJECT.OBJECT):
         qui n'existe pas encore (type CO()), 0 sinon
     """
     for typ in self.definition.type:
-      if type(typ) == types.ClassType :
+      if type(typ) == types.ClassType or isinstance(typ,type):
         if issubclass(typ,CO) :
            return 1
     return 0
@@ -166,7 +156,7 @@ class MCSIMP(I_OBJECT.OBJECT):
         ou dérivé, 0 sinon
     """
     for typ in self.definition.type:
-      if type(typ) == types.ClassType :
+      if type(typ) == types.ClassType or isinstance(typ,type):
         if issubclass(typ,ASSD) and not issubclass(typ,GEOM):
           return 1
     return 0
@@ -178,7 +168,7 @@ class MCSIMP(I_OBJECT.OBJECT):
          Retourne 0 dans le cas contraire
     """
     for typ in self.definition.type:
-      if type(typ) == types.ClassType :
+      if type(typ) == types.ClassType or isinstance(typ,type):
         if typ.__name__ in ("GEOM","ASSD","geom","assd") or issubclass(typ,GEOM) :
           return 1
     return 0
@@ -189,7 +179,7 @@ class MCSIMP(I_OBJECT.OBJECT):
          Retourne 0 dans le cas contraire
     """
     for typ in self.definition.type:
-      if type(typ) == types.ClassType :
+      if type(typ) == types.ClassType or isinstance(typ,type):
         if issubclass(typ,GEOM) : return 1
     return 0
 
@@ -217,62 +207,71 @@ class MCSIMP(I_OBJECT.OBJECT):
   def isoblig(self):
     return self.definition.statut=='o'
 
+  def valid_val(self,valeur):
+      """
+        Verifie que la valeur passee en argument (valeur) est valide
+        sans modifier la valeur courante 
+      """
+      lval=listProto.adapt(valeur)
+      if lval is None:
+         valid=0
+         mess="None n'est pas une valeur autorisée"
+      else:
+         try:
+            for val in lval:
+                self.typeProto.adapt(val)
+                self.intoProto.adapt(val)
+            self.cardProto.adapt(lval)
+            if self.definition.validators:
+                self.definition.validators.convert(lval)
+            valid,mess=1,""
+         except ValError,e:
+            mess=str(e)
+            valid=0
+      return valid,mess
+
   def valid_valeur(self,new_valeur):
       """
         Verifie que la valeur passee en argument (new_valeur) est valide
         sans modifier la valeur courante (evite d'utiliser set_valeur et est plus performant)
       """
-      old_valeur=self.valeur
-      old_val=self.val
-      self.valeur = new_valeur
-      self.val = new_valeur
-      self.state="modified"
-      validite=self.isvalid()
-      self.valeur = old_valeur
-      self.val = old_valeur
-      self.state="modified"
-      self.isvalid()
+      validite,mess=self.valid_val(new_valeur)
       return validite
 
   def valid_valeur_partielle(self,new_valeur):
       """
-        Verifie que la valeur passee en argument (new_valeur) est partiellement valide
-        sans modifier la valeur courante (evite d'utiliser set_valeur et est plus performant)
+        Verifie que la valeur passee en argument (new_valeur) est une liste partiellement valide
+        sans modifier la valeur courante du mot cle
       """
-      old_valeur=self.valeur
-      old_val=self.val
-
-      self.valeur = new_valeur
-      self.val = new_valeur
-      self.state="modified"
-      validite=0
-      if self.isvalid():
-         validite=1
-      elif self.definition.validators :
-         validite=self.definition.validators.valide_liste_partielle(new_valeur)
-
-      if validite==0:
-         min,max=self.get_min_max()
-         if len(new_valeur) < min :
-            validite=1
-
-      self.valeur = old_valeur
-      self.val = old_valeur
-      self.state="modified"
-      self.isvalid()
+      validite=1
+      try:
+          for val in new_valeur:
+              self.typeProto.adapt(val)
+              self.intoProto.adapt(val)
+              #on ne verifie pas la cardinalité
+              if self.definition.validators:
+                  validite=self.definition.validators.valide_liste_partielle(new_valeur)
+      except ValError,e:
+          validite=0
+
       return validite
 
+  def update_condition_bloc(self):
+      """ Met a jour les blocs conditionnels dependant du mot cle simple self
+      """
+      if self.definition.position == 'global' : 
+         self.etape.deep_update_condition_bloc()
+      elif self.definition.position == 'global_jdc' :
+         self.jdc.deep_update_condition_bloc()
+      else:
+         self.parent.update_condition_bloc()
+
   def set_valeur(self,new_valeur,evaluation='oui'):
         #print "set_valeur",new_valeur
         self.init_modif()
         self.valeur = new_valeur
         self.val = new_valeur
-        if self.definition.position == 'global' : 
-           self.etape.deep_update_condition_bloc()
-        elif self.definition.position == 'global_jdc' :
-           self.jdc.deep_update_condition_bloc()
-        else:
-           self.parent.update_condition_bloc()
+        self.update_condition_bloc()
         self.fin_modif()
         return 1
 
@@ -284,7 +283,7 @@ class MCSIMP(I_OBJECT.OBJECT):
     sd = self.jdc.get_sd_avant_etape(new_valeur,self.etape)
     #sd = self.jdc.get_contexte_avant(self.etape).get(new_valeur,None)
     #print sd
-    if sd :
+    if sd is not None:
       return sd,1
     lsd = self.jdc.cherche_list_avant(self.etape,new_valeur) 
     if lsd :
@@ -297,24 +296,62 @@ class MCSIMP(I_OBJECT.OBJECT):
         objet = eval(new_valeur,d)
         return objet,1
       except Exception:
-       itparam=self.cherche_item_parametre(new_valeur)
-       if itparam:
-            return itparam,1
+        itparam=self.cherche_item_parametre(new_valeur)
+        if itparam:
+             return itparam,1
+        try :
+             object=eval(new_valeur.valeur,d)
+        except :
+             pass
         if CONTEXT.debug : traceback.print_exc()
         return None,0
 
+  def eval_val(self,new_valeur):
+    """
+       Tente d'evaluer new_valeur comme un objet du jdc (par appel a eval_val_item)
+       ou comme une liste de ces memes objets
+       Si new_valeur contient au moins un separateur (,), tente l'evaluation sur
+       la chaine splittee
+    """
+    if type(new_valeur) in (types.ListType,types.TupleType):
+       valeurretour=[]
+       for item in new_valeur :
+          valeurretour.append(self.eval_val_item(item))
+       return valeurretour
+    else:
+       valeur=self.eval_val_item(new_valeur)
+       return valeur
+
+  def eval_val_item(self,new_valeur):
+    """
+       Tente d'evaluer new_valeur comme un concept, un parametre, un objet Python
+       Si c'est impossible retourne new_valeur inchange
+       argument new_valeur : string (nom de concept, de parametre, expression ou simple chaine)
+    """
+    if self.etape and self.etape.parent:
+       valeur=self.etape.parent.eval_in_context(new_valeur,self.etape)
+       return valeur
+    else:
+       try :
+           valeur = eval(val)
+           return valeur
+       except:
+           #traceback.print_exc()
+           return new_valeur
+           pass
+
   def cherche_item_parametre (self,new_valeur):
         try:
-         nomparam=new_valeur[0:new_valeur.find("[")]
-         indice=new_valeur[new_valeur.find("[")+1:new_valeur.find("]")]
-         for p in self.jdc.params:
-            if p.nom == nomparam :
-               if int(indice) < len(p.get_valeurs()):
-                  itparam=parametre.ITEM_PARAMETRE(p,int(indice))
-                  return itparam
-         return None
-       except:
-         return None
+          nomparam=new_valeur[0:new_valeur.find("[")]
+          indice=new_valeur[new_valeur.find("[")+1:new_valeur.find("]")]
+          for p in self.jdc.params:
+             if p.nom == nomparam :
+                if int(indice) < len(p.get_valeurs()):
+                   itparam=parametre.ITEM_PARAMETRE(p,int(indice))
+                   return itparam
+          return None
+        except:
+          return None
 
   def update_concept(self,sd):
     if type(self.valeur) in (types.ListType,types.TupleType) :
@@ -410,38 +447,41 @@ class MCSIMP(I_OBJECT.OBJECT):
       self.init_modif()
       self.valeur = new_objet
       self.val = new_objet
-      self.fin_modif()
-      step.reset_context()
       # On force l'enregistrement de new_objet en tant que concept produit 
       # de la macro en appelant get_type_produit avec force=1
       self.etape.get_type_produit(force=1)
+      self.fin_modif()
+      step.reset_context()
       #print "set_valeur_co",new_objet
       return 1,"Concept créé"
-       
+        
   def verif_existence_sd(self):
      """
         Vérifie que les structures de données utilisées dans self existent bien dans le contexte
-       avant étape, sinon enlève la référence à ces concepts
+        avant étape, sinon enlève la référence à ces concepts
      """
      #print "verif_existence_sd"
      # Attention : possible probleme avec include
+     # A priori il n'y a pas de raison de retirer les concepts non existants
+     # avant etape. En fait il s'agit uniquement eventuellement de ceux crees par une macro
      l_sd_avant_etape = self.jdc.get_contexte_avant(self.etape).values()  
      if type(self.valeur) in (types.TupleType,types.ListType) :
        l=[]
-       self.init_modif()
        for sd in self.valeur:
          if isinstance(sd,ASSD) :
-           if sd in l_sd_avant_etape :
-              l.append(sd)
-        else:
-           l.append(sd)
-       self.valeur=tuple(l)
-       self.fin_modif()
+            if sd in l_sd_avant_etape or self.etape.get_sdprods(sd.nom) is sd:
+               l.append(sd)
+         else:
+            l.append(sd)
+       if len(l) < len(self.valeur):
+          self.init_modif()
+          self.valeur=tuple(l)
+          self.fin_modif()
      else:
        if isinstance(self.valeur,ASSD) :
-         if self.valeur not in l_sd_avant_etape :
+          if self.valeur not in l_sd_avant_etape and self.etape.get_sdprods(self.valeur.nom) is None:
              self.init_modif()
-            self.valeur = None
+             self.valeur = None
              self.fin_modif()
  
   def get_min_max(self):
@@ -457,113 +497,88 @@ class MCSIMP(I_OBJECT.OBJECT):
      """
      return self.definition.type
 
-#--------------------------------------------------------------------------------
-# PN : ajout pour Salome des methodes suivantes (jusqu aux méthodes surchargees)
-#--------------------------------------------------------------------------------
-  def get_salome_valeurs(self):
-       l=[]
-       if not hasattr(self,'list_salome_valeurs'):
-           self.list_salome_valeurs=[]
-       if self.list_salome_valeurs != [] :
-           for val in self.list_salome_valeurs:
-                l.append(val)
-       return l
-
-  def put_salome_valeurs(self,list):
-       self.list_salome_valeurs=[]
-       for val in list:
-           self.list_salome_valeurs.append(val)
-
-  def add_salome_valeurs(self,val):
-      if not hasattr(self,'list_salome_valeurs'):
-           self.list_salome_valeurs=[]
+  def delete_mc_global(self):
+      """ Retire self des declarations globales
+      """
+      if self.definition.position == 'global' : 
+         etape = self.get_etape()
+         if etape :
+            del etape.mc_globaux[self.nom]
+      elif self.definition.position == 'global_jdc' :
+         del self.jdc.mc_globaux[self.nom]
+
+  def update_mc_global(self):
+     """
+        Met a jour les mots cles globaux enregistrés dans l'étape parente
+        et dans le jdc parent.
+        Un mot cle simple peut etre global. 
+     """
+     if self.definition.position == 'global' :
+        etape = self.get_etape()
+        if etape :
+           etape.mc_globaux[self.nom]=self
+     elif self.definition.position == 'global_jdc' :
+        if self.jdc:
+           self.jdc.mc_globaux[self.nom]=self
+
+  def nbrColonnes(self):
+     genea = self.get_genealogie()
+     if "VALE_C" in genea and "DEFI_FONCTION" in genea : return 3
+     if "VALE" in genea and "DEFI_FONCTION" in genea : return 2
+     return 0
+
+  def valide_item(self,item):
+      """Valide un item isolé. Cet item est candidat à l'ajout à la liste existante"""
+      valid=1
       try:
-           self.list_salome_valeurs.append(val)
-      except :
-           try:
-              for uneval in val :
-                  self.list_salome_valeurs.append(uneval)
-           except :
-              pass
-
-  def has_salome_valeurs(self):
-      if not hasattr(self,'list_salome_valeurs'):
-           self.list_salome_valeurs=[]
-      if self.list_salome_valeurs != []:
-           return true
-      else:
-           return false
+          #on verifie le type
+          self.typeProto.adapt(item)
+          #on verifie les choix possibles
+          self.intoProto.adapt(item)
+          #on ne verifie pas la cardinalité
+          if self.definition.validators:
+              valid=self.definition.validators.verif_item(item)
+      except ValError,e:
+          #traceback.print_exc()
+          valid=0
+      return valid
+
+  def verif_type(self,item):
+      """Verifie le type d'un item de liste"""
+      try:
+          #on verifie le type
+          self.typeProto.adapt(item)
+          #on verifie les choix possibles
+          self.intoProto.adapt(item)
+          #on ne verifie pas la cardinalité mais on verifie les validateurs
+          if self.definition.validators:
+              valid=self.definition.validators.verif_item(item)
+          comment=""
+          valid=1
+      except ValError,e:
+          #traceback.print_exc()
+          comment=str(e)
+          valid=0
+      return valid,comment
 
 #--------------------------------------------------------------------------------
-# PN : fin ajout pour Salome 
-#--------------------------------------------------------------------------------
  
 #ATTENTION SURCHARGE : toutes les methodes ci apres sont des surcharges du Noyau et de Validation
 # Elles doivent etre reintegrees des que possible
 
 
-  def isvalid(self,cr='non'):
-      """
-         Cette méthode retourne un indicateur de validité de l'objet de type MCSIMP
+  def verif_typeihm(self,val,cr='non'):
+      try :
+         val.eval()
+         return 1
+      except :
+         traceback.print_exc()
+         pass
+      return self.verif_type(val,cr)
 
-           - 0 si l'objet est invalide
-           - 1 si l'objet est valide
+  def verif_typeliste(self,val,cr='non') :
+      verif=0
+      for v in val :
+        verif=verif+self.verif_typeihm(v,cr)
+      return verif
 
-         Le paramètre cr permet de paramétrer le traitement. Si cr == 'oui'
-         la méthode construit également un comte-rendu de validation
-         dans self.cr qui doit avoir été créé préalablement.
-      """
-      if self.state == 'unchanged':
-        return self.valid
-      else:
-        valid = 1
-        v=self.valeur
-        #  verification presence
-        if self.isoblig() and v == None :
-          if cr == 'oui' :
-            self.cr.fatal(string.join(("Mot-clé : ",self.nom," obligatoire non valorisé")))
-          valid = 0
-
-        if v is None:
-           valid=0
-           if cr == 'oui' :
-              self.cr.fatal("None n'est pas une valeur autorisée")
-        else:
-           # type,into ...
-          if v.__class__.__name__ in ('PARAMETRE' , 'EVAL', 'ITEM_PARAMETRE','PARAMETRE_EVAL'):
-             verif_type=1
-          else:
-             verif_type=self.verif_type(val=v,cr=None)
-             # cas des tuples avec un ITEM_PARAMETRE
-              if verif_type == 0:
-                 if type(v) == types.TupleType :
-                  new_val=[]
-                  for i in v:
-                    if i.__class__.__name__  not in ('PARAMETRE','EVAL', 'ITEM_PARAMETRE','PARAMETRE_EVAL'): 
-                         new_val.append(i)
-                  if new_val != [] :
-                    verif_type=self.verif_type(val=new_val,cr=cr)
-                  else :
-                    # Cas d une liste de paramétre
-                    verif_type= 1
-                else:
-                    verif_type=self.verif_type(val=v,cr=cr)
-           valid = verif_type*self.verif_into(cr=cr)*self.verif_card(cr=cr)
-           #
-           # On verifie les validateurs s'il y en a et si necessaire (valid == 1)
-           #
-           if valid and self.definition.validators and not self.definition.validators.verif(self.valeur):
-              if cr == 'oui' :
-                 self.cr.fatal(string.join(("Mot-clé : ",self.nom,"devrait avoir ",self.definition.validators.info())))
-              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