# -*- 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
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
#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
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)
#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 " +
"""
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):
"""
#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):
"""
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
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'):
"""
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'):
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')
# 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):
"""
# 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):
"""
# 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()
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'),