1 #@ MODIF V_MCBLOC Validation 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 mixin MCBLOC qui porte les méthodes
26 nécessaires pour réaliser la validation d'un objet de type MCBLOC
29 Une classe mixin porte principalement des traitements et est
30 utilisée par héritage multiple pour composer les traitements.
38 class MCBLOC(V_MCCOMPO.MCCOMPO):
40 Cette classe a un attribut de classe :
42 - txt_nat qui sert pour les comptes-rendus liés à cette classe
47 def isvalid(self,sd='oui',cr='non'):
49 Methode pour verifier la validité du MCBLOC. Cette méthode
50 peut etre appelée selon plusieurs modes en fonction de la valeur
53 Si cr vaut oui elle crée en plus un compte-rendu
54 sd est présent pour compatibilité de l'interface mais ne sert pas
56 if self.state == 'unchanged' :
60 if hasattr(self,'valid'):
61 old_valid = self.valid
64 for child in self.mc_liste :
65 if not child.isvalid():
68 # Après avoir vérifié la validité de tous les sous-objets, on vérifie
69 # la validité des règles
70 text_erreurs,test_regles = self.verif_regles()
72 if cr == 'oui' : self.cr.fatal(string.join(("Règle(s) non respectée(s) :", text_erreurs)))
75 self.state = 'unchanged'
76 if not old_valid or old_valid != self.valid :