Salome HOME
etat provisoire pour sauvegarde avant vacances. non stable
[tools/eficas.git] / Extensions / jdc_include.py
index 07a6c94e330e8c7b2512679abdcaabc124ba4960..ba4f84ff039d32b507d158ecc8e41a3effc649a7 100644 (file)
@@ -1,23 +1,22 @@
 # -*- coding: utf-8 -*-
-#            CONFIGURATION MANAGEMENT OF EDF VERSION
-# ======================================================================
-# COPYRIGHT (C) 1991 - 2002  EDF R&D                  WWW.CODE-ASTER.ORG
-# THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
-# IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
-# THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR
-# (AT YOUR OPTION) ANY LATER VERSION.
+# Copyright (C) 2007-2013   EDF R&D
 #
-# THIS PROGRAM 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
-# GENERAL PUBLIC LICENSE FOR MORE DETAILS.
+# 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.
 #
-# YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE
-# ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,
-#    1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.
+# 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 la classe JDC_INCLUDE qui sert a inclure
@@ -27,6 +26,7 @@
    que le jeu de commandes inclus est valide et compatible
    avec le contexte avant et apres l'insertion
 """
+import string
 from Accas import JDC,ASSD,AsException,JDC_CATA
 from Ihm import CONNECTOR
 
@@ -53,6 +53,9 @@ class JDC_POURSUITE(JDC):
       if recorded_units is not None:self.recorded_units=recorded_units
       if old_recorded_units is not None:self.old_recorded_units=old_recorded_units
 
+   def o_register(self,sd):
+      return self.jdc_pere.o_register(sd)
+
    def NommerSdprod(self,sd,sdnom,restrict='non'):
       """
           Nomme la SD apres avoir verifie que le nommage est possible : nom
@@ -64,9 +67,31 @@ class JDC_POURSUITE(JDC):
       #print "NommerSdprod",sd,sdnom,restrict
       if self.prefix_include:
           if sdnom != self.prefix_include:sdnom=self.prefix_include+sdnom
+
+      if sdnom != '' and sdnom[0] == '_':
+        # Si le nom du concept commence par le caractere _ on lui attribue
+        # un identificateur automatique comme dans JEVEUX (voir gcncon)
+        # 
+        # nom commencant par __ : il s'agit de concepts qui seront detruits
+        # nom commencant par _ : il s'agit de concepts intermediaires qui seront gardes
+        # ATTENTION : il faut traiter différemment les concepts dont le nom
+        # commence par _ mais qui sont des concepts nommés automatiquement par
+        # une éventuelle sous macro.
+        if sdnom[1] in string.digits:
+          # Ce concept provient probablement d'une sous macro (cas improbable)
+          #pas de renommage
+          pass
+        elif sdnom[1] == '_':
+          #cas d'un concept à ne pas conserver apres execution de la commande
+          sdnom=sd.id[2:]
+          pass
+        else:
+          sdnom=sd.id[2:]
+          pass
+
       o=self.sds_dict.get(sdnom,None)
       if isinstance(o,ASSD):
-         raise AsException("Nom de concept deja defini : %s" % sdnom)
+         raise AsException(tr("Nom de concept deja defini : %s" ,sdnom))
 
       # On pourrait verifier que le jdc_pere apres l'etape etape_include
       # ne contient pas deja un concept de ce nom
@@ -86,10 +111,25 @@ class JDC_POURSUITE(JDC):
          self.g_context[sdnom]=sd
 
    def get_verif_contexte(self):
+      #print "get_verif_contexte"
       j_context=self.get_contexte_avant(None)
       self.verif_contexte(j_context)
       return j_context
 
+   def force_contexte(self,contexte):
+      for nom_sd,sd in contexte.items():
+        if not isinstance(sd,ASSD):continue
+        autre_sd= self.jdc_pere.get_sd_apres_etape_avec_detruire(nom_sd,sd,
+                                                       etape=self.etape_include)
+        if autre_sd is None:continue
+        if sd is not autre_sd:
+           # Il existe un autre concept de meme nom produit par une etape apres self 
+           # on detruit ce concept pour pouvoir inserer les etapes du jdc_include
+           if sd.etape:
+              sd.etape.supprime_sdprod(sd)
+
+      return contexte
+
    def verif_contexte(self,context):
       """
          Cette methode verifie si le contexte passé en argument (context)
@@ -103,8 +143,10 @@ class JDC_POURSUITE(JDC):
       #print "verif_contexte"
       for nom_sd,sd in context.items():
         if not isinstance(sd,ASSD):continue
-        if self.jdc_pere.get_sd_apres_etape_avec_detruire(nom_sd,sd,
-                                                       etape=self.etape_include):
+        autre_sd= self.jdc_pere.get_sd_apres_etape_avec_detruire(nom_sd,sd,
+                                                       etape=self.etape_include)
+        if autre_sd is None:continue
+        if sd is not autre_sd:
            # Il existe un concept produit par une etape apres self 
            # => impossible d'inserer
            raise Exception("Impossible d'inclure le fichier. Un concept de nom " +
@@ -116,12 +158,16 @@ class JDC_POURSUITE(JDC):
       """
           Retourne la liste des commandes du catalogue
       """
+      if self.jdc_pere is None:
+         return JDC.get_liste_cmd(self)
       return self.jdc_pere.get_liste_cmd()
 
    def get_groups(self):
       """
           Retourne la liste des commandes du catalogue par groupes
       """
+      if self.jdc_pere is None:
+         return JDC.get_groups(self)
       return self.jdc_pere.get_groups()
 
    def init_modif(self):
@@ -136,7 +182,8 @@ class JDC_POURSUITE(JDC):
       """
       #print "jdc_include.init_modif",self,self.etape_include
       self.state = 'modified'
-      self.etape_include.init_modif()
+      if self.etape_include:
+         self.etape_include.init_modif()
 
    def fin_modif(self):
       """
@@ -145,32 +192,27 @@ class JDC_POURSUITE(JDC):
           ex : INCLUDE et POURSUITE
       """
       #print "jdc_include.fin_modif",self,self.etape_include
-
-      # Mise a jour du contexte en fin d'include
-      # On suppose que toutes les modifications sont valides
-      # On recupere le contexte final dans j_context
-      j_context=self.get_contexte_avant(None) #get_verif_contexte ???
-      # On remplit le dictionnaire des concepts produits de l'etape macro INCLUDE
-      # sans y mettre les concepts présents dans le  contexte initial (context_ini)
-      # On ajoute egalement les concepts produits dans le sds_dict du parent
-      # sans verification car on est sur (verification integrée) que
-      # le nommage est possible
-      self.etape_include.g_context.clear()
-      for k,v in j_context.items():
-         if not self.context_ini.has_key(k) or self.context_ini[k] != v:
-            self.etape_include.g_context[k]=v
-            self.etape_include.parent.sds_dict[k]=v
-
       CONNECTOR.Emit(self,"valid")
-      self.etape_include.fin_modif()
-      #print "jdc_include.fin_modif.context_ini",self.context_ini
+      if self.etape_include:
+         self.etape_include.fin_modif()
 
    def supprime(self):
       """
-          On ne supprime rien pour un jdc auxiliaire d'include ou de poursuite
+          On ne supprime rien directement pour un jdc auxiliaire d'include ou de poursuite
+          Utiliser supprime_aux
       """
       pass
 
+   def supprime_aux(self):
+      #print "supprime_aux",self
+      JDC.supprime(self)
+      self.jdc_pere=None
+      self.etape_include=None
+   #   self.cata_ordonne_dico={}
+      self.appli=None
+   #   self.context_ini={}
+   #   self.procedure=None
+
    def get_contexte_avant(self,etape):
       """
          Retourne le dictionnaire des concepts connus avant etape
@@ -180,21 +222,20 @@ class JDC_POURSUITE(JDC):
          comme DETRUIRE ou les macros
          Si etape == None, on retourne le contexte en fin de JDC
       """
-      self.context_ini = self.etape_include.parent.get_contexte_avant(self.etape_include).copy()
-      return JDC.get_contexte_avant(self,etape)
-
-   #def get_sd_avant_etape(self,nom_sd,etape):
-      #sd=self.etape_include.parent.get_sd_avant_etape(nom_sd,self.etape_include)
-      #if sd:return sd
-      #return JDC.get_sd_avant_etape(self,nom_sd,etape)
-
-   #def get_sd_avant_du_bon_type(self,etape,types_permis):
-      #"""
-      #    Retourne la liste des concepts avant etape d'un type acceptable
-      #"""
-      #l1=self.etape_include.parent.get_sd_avant_du_bon_type(self.etape_include,types_permis)
-      #l2=JDC.get_sd_avant_du_bon_type(self,etape,types_permis)
-      #return l1+l2
+      #print "jdc_include.get_contexte_avant",etape,etape and etape.nom
+      if self.etape_include:
+         new_context=self.etape_include.parent.get_contexte_avant(self.etape_include).copy()
+         self.context_ini=new_context
+      d= JDC.get_contexte_avant(self,etape)
+      return d
+
+   def reset_context(self):
+      #print "jdc_include.reset_context",self,self.nom
+      if self.etape_include:
+         self.etape_include.parent.reset_context()
+         new_context=self.etape_include.parent.get_contexte_avant(self.etape_include).copy()
+         self.context_ini=new_context
+      JDC.reset_context(self)
 
    def get_sd_apres_etape(self,nom_sd,etape,avec='non'):
       """
@@ -202,8 +243,9 @@ class JDC_POURSUITE(JDC):
            définie apres etape
            Si avec vaut 'non' exclut etape de la recherche
       """
-      sd=self.etape_include.parent.get_sd_apres_etape(nom_sd,self.etape_include,'non')
-      if sd:return sd
+      if self.etape_include:
+         sd=self.etape_include.parent.get_sd_apres_etape(nom_sd,self.etape_include,'non')
+         if sd:return sd
       return JDC.get_sd_apres_etape(self,nom_sd,etape,avec)
 
    def get_sd_apres_etape_avec_detruire(self,nom_sd,sd,etape,avec='non'):
@@ -214,7 +256,13 @@ class JDC_POURSUITE(JDC):
            définie apres etape en tenant compte des concepts detruits
            Si avec vaut 'non' exclut etape de la recherche
       """
+      #print "jdc_include.get_sd_apres_etape_avec_detruire",nom_sd,sd,id(sd)
       autre_sd=JDC.get_sd_apres_etape_avec_detruire(self,nom_sd,sd,etape,avec)
+      # si autre_sd vaut None le concept sd a ete detruit. On peut terminer
+      # la recherche en retournant None
+      # Si autre_sd ne vaut pas sd, le concept a ete redefini. On peut terminer
+      # la recherche en retournant le concept nouvellement defini
+      # Sinon, on poursuit la recherche dans les etapes du niveau superieur.
       if autre_sd is None or autre_sd is not sd :return autre_sd
       return self.etape_include.parent.get_sd_apres_etape_avec_detruire(nom_sd,sd,self.etape_include,'non')
 
@@ -228,7 +276,8 @@ class JDC_POURSUITE(JDC):
       # Nettoyage des etapes de l'include
       JDC.delete_concept(self,sd)
       # Nettoyage des etapes du parent
-      self.etape_include.parent.delete_concept_after_etape(self.etape_include,sd)
+      if self.etape_include:
+         self.etape_include.parent.delete_concept_after_etape(self.etape_include,sd)
 
    def delete_concept_after_etape(self,etape,sd):
       """
@@ -238,7 +287,17 @@ class JDC_POURSUITE(JDC):
       # Nettoyage des etapes de l'include
       JDC.delete_concept_after_etape(self,etape,sd)
       # Nettoyage des etapes du parent
-      self.etape_include.parent.delete_concept_after_etape(self.etape_include,sd)
+      if self.etape_include:
+         self.etape_include.parent.delete_concept_after_etape(self.etape_include,sd)
+
+   def update_concept_after_etape(self,etape,sd):
+      """
+          Fonction : mettre a jour les etapes du JDC suite a une modification
+          du concept sd (principalement renommage)
+      """
+      JDC.update_concept_after_etape(self,etape,sd)
+      if self.etape_include:
+         self.etape_include.parent.update_concept_after_etape(self.etape_include,sd)
 
    def replace_concept_after_etape(self,etape,old_sd,sd):
       """
@@ -248,11 +307,40 @@ class JDC_POURSUITE(JDC):
       # Nettoyage des etapes de l'include
       JDC.replace_concept_after_etape(self,etape,old_sd,sd)
       # Nettoyage des etapes du parent
-      self.etape_include.parent.replace_concept_after_etape(self.etape_include,old_sd,sd)
+      if self.etape_include:
+         self.etape_include.parent.replace_concept_after_etape(self.etape_include,old_sd,sd)
 
+   def changefichier(self,fichier):
+      if self.etape_include:
+         self.etape_include.fichier_ini=fichier
+      self.fin_modif()
 
+   def control_context_apres(self,etape):
+      """
+         Cette méthode verifie que les etapes apres l'etape etape
+         ont bien des concepts produits acceptables (pas de conflit de
+         nom principalement)
+         Si des concepts produits ne sont pas acceptables ils sont supprimés.
+         Effectue les verifications sur les etapes du jdc mais aussi sur les
+         jdc parents s'ils existent.
+      """
+      #print "jdc_include.control_context_apres",self,etape
+      #Regularise les etapes du jdc apres l'etape etape
+      self.control_jdc_context_apres(etape)
+      if self.etape_include:
+         #print "CONTROL_INCLUDE:",self.etape_include,self.etape_include.nom
+         # il existe un jdc pere. On propage la regularisation
+         self.etape_include.parent.control_context_apres(self.etape_include)
 
 class JDC_INCLUDE(JDC_POURSUITE):
+   def get_liste_cmd(self):
+      """
+          Retourne la liste des commandes du catalogue
+      """
+      if self.jdc_pere is None:
+         return JDC.get_liste_cmd(self)
+      return [e for e in self.jdc_pere.get_liste_cmd() if e not in ("DEBUT","POURSUITE","FIN") ]
+
    def active_etapes(self):
       for e in self.etapes:
          e.active()
@@ -265,7 +353,9 @@ class JDC_CATA_POURSUITE(JDC_CATA):
 
 from Accas import AU_MOINS_UN,A_CLASSER
 
-JdC_include=JDC_CATA_INCLUDE(code='ASTER', execmodul=None)
+import prefs
+c=prefs.code
+JdC_include=JDC_CATA_INCLUDE(code=c, execmodul=None)
 
 JdC_poursuite=JDC_CATA_POURSUITE(code='ASTER', execmodul=None,
                                  regles = (AU_MOINS_UN('DEBUT','POURSUITE'),