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