Salome HOME
etat provisoire pour sauvegarde avant vacances. non stable
[tools/eficas.git] / Extensions / jdc_include.py
index 2e2778d5fbacf5bf7014cd71602a023a4441869e..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
    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
 
-class NOTIFIER:
-   def __init__(self):
-      self.subscribers=[]
-
-   def subscribe(self,obj):
-      if not obj in self.subscribers:
-         self.subscribers.append(obj)
-
-   def notify(self):
-      for obj in self.subscribers:
-         obj.notify(self)
-
-class JDC_POURSUITE(JDC,NOTIFIER):
+class JDC_POURSUITE(JDC):
    def __init__(self,definition=None,procedure=None,cata=None,
                      cata_ord_dico=None,parent=None,
                      nom='SansNom',appli=None,context_ini=None,
                      jdc_pere=None,etape_include=None,prefix_include=None,
                      recorded_units=None,old_recorded_units=None,**args):
 
-      NOTIFIER.__init__(self)
       JDC.__init__(self, definition=definition,
                          procedure=procedure,
                          cata=cata,
@@ -65,6 +53,9 @@ class JDC_POURSUITE(JDC,NOTIFIER):
       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
@@ -73,11 +64,34 @@ class JDC_POURSUITE(JDC,NOTIFIER):
           Si le nom est deja utilise, leve une exception
           Met le concept créé dans le contexe global g_context
       """
+      #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
@@ -97,10 +111,25 @@ class JDC_POURSUITE(JDC,NOTIFIER):
          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)
@@ -111,10 +140,13 @@ class JDC_POURSUITE(JDC,NOTIFIER):
          Si le contexte ne peut pas etre inséré, la méthode leve une
          exception sinon elle retourne le contexte inchangé
       """
+      #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 " +
@@ -126,12 +158,16 @@ class JDC_POURSUITE(JDC,NOTIFIER):
       """
           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):
@@ -144,9 +180,10 @@ class JDC_POURSUITE(JDC,NOTIFIER):
          mais par un appel à fin_modif pour préserver l'état modified
          de tous les objets entre temps
       """
-      print "init_modif",self,self.etape_include
+      #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):
       """
@@ -154,18 +191,156 @@ class JDC_POURSUITE(JDC,NOTIFIER):
           déclencher d'éventuels traitements post-modification
           ex : INCLUDE et POURSUITE
       """
-      print "fin_modif",self,self.etape_include
-      self.etape_include.fin_modif()
-      self.notify()
+      #print "jdc_include.fin_modif",self,self.etape_include
+      CONNECTOR.Emit(self,"valid")
+      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
+         On tient compte des concepts produits par le jdc pere
+         en reactualisant le contexte initial context_ini
+         On tient compte des commandes qui modifient le contexte
+         comme DETRUIRE ou les macros
+         Si etape == None, on retourne le contexte en fin de JDC
+      """
+      #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'):
+      """
+           Cette méthode retourne la SD de nom nom_sd qui est éventuellement
+           définie apres etape
+           Si avec vaut 'non' exclut etape de la recherche
+      """
+      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'):
+      """
+           On veut savoir ce que devient le concept sd de nom nom_sd apres etape.
+           Il peut etre detruit, remplacé ou conservé
+           Cette méthode retourne la SD sd de nom nom_sd qui est éventuellement
+           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')
+
+   def delete_concept(self,sd):
+      """
+          Fonction : Mettre a jour les etapes du JDC suite à la disparition du
+          concept sd
+          Seuls les mots cles simples MCSIMP font un traitement autre
+          que de transmettre aux fils
+      """
+      # Nettoyage des etapes de l'include
+      JDC.delete_concept(self,sd)
+      # Nettoyage des etapes du parent
+      if self.etape_include:
+         self.etape_include.parent.delete_concept_after_etape(self.etape_include,sd)
+
+   def delete_concept_after_etape(self,etape,sd):
+      """
+          Fonction : Mettre à jour les étapes du JDC qui sont après etape suite à
+          la disparition du concept sd
+      """
+      # Nettoyage des etapes de l'include
+      JDC.delete_concept_after_etape(self,etape,sd)
+      # Nettoyage des etapes du parent
+      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):
+      """
+          Fonction : Mettre à jour les étapes du JDC qui sont après etape suite au
+          remplacement du concept old_sd par sd
+      """
+      # Nettoyage des etapes de l'include
+      JDC.replace_concept_after_etape(self,etape,old_sd,sd)
+      # Nettoyage des etapes du parent
+      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()
@@ -178,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'),