Salome HOME
CCAR: correction d'un probleme de mise a jour de contexte lors d'une insertion
[tools/eficas.git] / Noyau / N_JDC_CATA.py
1 #@ MODIF N_JDC_CATA Noyau  DATE 14/09/2004   AUTEUR MCOURTOI M.COURTOIS 
2 # -*- coding: iso-8859-1 -*-
3 #            CONFIGURATION MANAGEMENT OF EDF VERSION
4 # ======================================================================
5 # COPYRIGHT (C) 1991 - 2002  EDF R&D                  WWW.CODE-ASTER.ORG
6 # THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
7 # IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
8 # THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR   
9 # (AT YOUR OPTION) ANY LATER VERSION.                                 
10 #
11 # THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT 
12 # WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF          
13 # MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU    
14 # GENERAL PUBLIC LICENSE FOR MORE DETAILS.                            
15 #
16 # YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE   
17 # ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,       
18 #    1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.      
19 #                                                                       
20 #                                                                       
21 # ======================================================================
22
23
24 """ 
25     Ce module contient la classe de definition JDC_CATA
26     qui permet de spécifier les caractéristiques d'un JDC
27 """
28
29 import types,string,traceback
30
31 import N_ENTITE
32 import N_JDC
33
34 class JDC_CATA(N_ENTITE.ENTITE):
35    """
36     Classe pour definir un jeu de commandes
37
38     Attributs de classe :
39
40     - class_instance qui indique la classe qui devra etre utilisée 
41             pour créer l'objet qui servira à controler la conformité 
42             du jeu de commandes avec sa définition
43
44     - label qui indique la nature de l'objet de définition (ici, JDC)
45
46    """
47    class_instance = N_JDC.JDC
48    label = 'JDC'
49
50    def __init__(self,code='',execmodul=None,regles=(),niveaux=(),**args):
51       """
52       """
53       self.code = code
54       self.execmodul=execmodul
55       if type(regles)== types.TupleType:
56         self.regles = regles
57       else:
58         self.regles=(regles,)
59       # Tous les arguments supplémentaires sont stockés dans l'attribut args
60       # et seront passés au JDC pour initialiser ses paramètres propres
61       self.args=args
62       self.d_niveaux={}
63       self.l_niveaux=niveaux
64       self.commandes=[]
65       for niveau in niveaux:
66          self.d_niveaux[niveau.nom]=niveau
67       # On change d'objet catalogue. Il faut d'abord mettre le catalogue 
68       # courant à None
69       CONTEXT.unset_current_cata()
70       CONTEXT.set_current_cata(self)
71
72    def __call__(self,procedure=None,cata=None,cata_ord_dico=None,
73                      nom='SansNom',parent=None,**args):
74       """
75           Construit l'objet JDC a partir de sa definition (self),
76       """
77       return self.class_instance(definition=self,procedure=procedure,
78                          cata=cata,cata_ord_dico=cata_ord_dico,
79                          nom=nom,
80                          parent=parent,
81                          **args
82                          )
83
84    def enregistre(self,commande):
85       """
86          Methode qui permet aux definitions de commandes de s'enregistrer aupres
87          d'un JDC_CATA
88       """
89       self.commandes.append(commande)
90
91    def verif_cata(self):
92       """
93           Méthode de vérification des attributs de définition
94       """
95       if type(self.regles) != types.TupleType :
96         self.cr.fatal("L'attribut 'regles' doit etre un tuple : %s" %`self.regles`)
97       self.verif_cata_regles()
98
99    def verif_cata_regles(self):
100       """
101          Cette méthode vérifie pour tous les objets stockés dans la liste entités
102          respectent les REGLES associés  à self
103       """
104       # A FAIRE
105
106    def report(self):
107       """
108          Methode pour produire un compte-rendu de validation d'un catalogue de commandes
109       """
110       self.cr = self.CR(debut = "Compte-rendu de validation du catalogue "+self.code,
111                          fin = "Fin Compte-rendu de validation du catalogue "+self.code)
112       self.verif_cata()
113       for commande in self.commandes:
114         cr = commande.report()
115         cr.debut = "Début Commande :"+commande.nom
116         cr.fin = "Fin commande :"+commande.nom
117         self.cr.add(cr)
118       return self.cr
119
120    def supprime(self):
121       """
122           Méthode pour supprimer les références arrières susceptibles de provoquer
123           des cycles de références
124       """
125       for commande in self.commandes:
126          commande.supprime()
127
128    def get_niveau(self,nom_niveau):
129       """
130            Retourne l'objet de type NIVEAU de nom nom_niveau
131            ou None s'il n'existe pas
132       """
133       return self.d_niveaux.get(nom_niveau,None)
134
135
136