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.
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.
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.
21 # ======================================================================
25 Ce module contient la classe de definition JDC_CATA
26 qui permet de spécifier les caractéristiques d'un JDC
29 import types,string,traceback
34 class JDC_CATA(N_ENTITE.ENTITE):
36 Classe pour definir un jeu de commandes
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
44 - label qui indique la nature de l'objet de définition (ici, JDC)
47 class_instance = N_JDC.JDC
50 def __init__(self,code='',execmodul=None,regles=(),niveaux=(),**args):
54 self.execmodul=execmodul
55 if type(regles)== types.TupleType:
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
63 self.l_niveaux=niveaux
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
69 CONTEXT.unset_current_cata()
70 CONTEXT.set_current_cata(self)
72 def __call__(self,procedure=None,cata=None,cata_ord_dico=None,
73 nom='SansNom',parent=None,**args):
75 Construit l'objet JDC a partir de sa definition (self),
77 return self.class_instance(definition=self,procedure=procedure,
78 cata=cata,cata_ord_dico=cata_ord_dico,
84 def enregistre(self,commande):
86 Methode qui permet aux definitions de commandes de s'enregistrer aupres
89 self.commandes.append(commande)
93 Méthode de vérification des attributs de définition
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()
99 def verif_cata_regles(self):
101 Cette méthode vérifie pour tous les objets stockés dans la liste entités
102 respectent les REGLES associés à self
108 Methode pour produire un compte-rendu de validation d'un catalogue de commandes
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)
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
122 Méthode pour supprimer les références arrières susceptibles de provoquer
123 des cycles de références
125 for commande in self.commandes:
128 def get_niveau(self,nom_niveau):
130 Retourne l'objet de type NIVEAU de nom nom_niveau
131 ou None s'il n'existe pas
133 return self.d_niveaux.get(nom_niveau,None)