Salome HOME
*** empty log message ***
[tools/eficas.git] / Noyau / N_JDC_CATA.py
1 # -*- coding: utf-8 -*-
2 #@ MODIF N_JDC_CATA Noyau  DATE 27/03/2002   AUTEUR DURAND C.DURAND 
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     Ce module contient la classe de definition JDC_CATA
24     qui permet de spécifier les caractéristiques d'un JDC
25 """
26
27 import types,string,traceback
28
29 import N_ENTITE
30 import N_JDC
31
32 class JDC_CATA(N_ENTITE.ENTITE):
33    """
34     Classe pour definir un jeu de commandes
35
36     Attributs de classe :
37
38     - class_instance qui indique la classe qui devra etre utilisée 
39             pour créer l'objet qui servira à controler la conformité 
40             du jeu de commandes avec sa définition
41
42     - label qui indique la nature de l'objet de définition (ici, JDC)
43
44    """
45    class_instance = N_JDC.JDC
46    label = 'JDC'
47
48    def __init__(self,code='',execmodul=None,regles=(),niveaux=(),**args):
49       """
50       """
51       self.code = code
52       self.execmodul=execmodul
53       if type(regles)== types.TupleType:
54         self.regles = regles
55       else:
56         self.regles=(regles,)
57       # Tous les arguments supplémentaires sont stockés dans l'attribut args
58       # et seront passés au JDC pour initialiser ses paramètres propres
59       self.args=args
60       self.d_niveaux={}
61       self.l_niveaux=niveaux
62       self.commandes=[]
63       for niveau in niveaux:
64          self.d_niveaux[niveau.nom]=niveau
65       # On change d'objet catalogue. Il faut d'abord mettre le catalogue 
66       # courant à None
67       CONTEXT.unset_current_cata()
68       CONTEXT.set_current_cata(self)
69
70    def __call__(self,procedure=None,cata=None,cata_ord_dico=None,
71                      nom='SansNom',parent=None,**args):
72       """
73           Construit l'objet JDC a partir de sa definition (self),
74       """
75       return self.class_instance(definition=self,procedure=procedure,
76                          cata=cata,cata_ord_dico=cata_ord_dico,
77                          nom=nom,
78                          parent=parent,
79                          **args
80                          )
81
82    def enregistre(self,commande):
83       """
84          Methode qui permet aux definitions de commandes de s'enregistrer aupres
85          d'un JDC_CATA
86       """
87       self.commandes.append(commande)
88
89    def verif_cata(self):
90       """
91           Méthode de vérification des attributs de définition
92       """
93       if type(self.regles) != types.TupleType :
94         self.cr.fatal("L'attribut 'regles' doit etre un tuple : %s" %`self.regles`)
95       self.verif_cata_regles()
96
97    def verif_cata_regles(self):
98       """
99          Cette méthode vérifie pour tous les objets stockés dans la liste entités
100          respectent les REGLES associés  à self
101       """
102       # A FAIRE
103
104    def report(self):
105       """
106          Methode pour produire un compte-rendu de validation d'un catalogue de commandes
107       """
108       self.cr = self.CR(debut = "Compte-rendu de validation du catalogue "+self.code,
109                          fin = "Fin Compte-rendu de validation du catalogue "+self.code)
110       self.verif_cata()
111       for commande in self.commandes:
112         cr = commande.report()
113         cr.debut = "Début Commande :"+commande.nom
114         cr.fin = "Fin commande :"+commande.nom
115         self.cr.add(cr)
116       return self.cr
117
118    def supprime(self):
119       """
120           Méthode pour supprimer les références arrières susceptibles de provoquer
121           des cycles de références
122       """
123       for commande in self.commandes:
124          commande.supprime()
125
126    def get_niveau(self,nom_niveau):
127       """
128            Retourne l'objet de type NIVEAU de nom nom_niveau
129            ou None s'il n'existe pas
130       """
131       return self.d_niveaux.get(nom_niveau,None)
132
133
134