1 #@ MODIF V_MCLIST 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 MCList qui porte les méthodes
26 nécessaires pour réaliser la validation d'un objet de type MCList
29 Une classe mixin porte principalement des traitements et est
30 utilisée par héritage multiple pour composer les traitements.
37 from Noyau import N_CR
38 from Noyau.N_Exception import AsException
42 Cette classe a deux attributs de classe :
44 - CR qui sert à construire l'objet compte-rendu
46 - txt_nat qui sert pour les comptes-rendus liés à cette classe
50 txt_nat="Mot cle Facteur Multiple :"
52 def isvalid(self,cr='non'):
54 Methode pour verifier la validité du MCList. Cette méthode
55 peut etre appelée selon plusieurs modes en fonction de la valeur
58 Si cr vaut oui elle crée en plus un compte-rendu.
60 On n'utilise pas d'attribut pour stocker l'état et on ne remonte pas
61 le changement d'état au parent (pourquoi ??)
62 MCLIST est une liste de MCFACT. Les MCFACT ont le meme parent
63 que le MCLIST qui les contient. Il n'est donc pas necessaire de
64 remonter le changement d'etat au parent. C'est deja fait
67 if len(self.data) == 0 : return 0
70 definition=self.data[0].definition
71 # Verification du nombre des mots cles facteurs
72 if definition.min is not None and len(self.data) < definition.min :
75 self.cr.fatal("Nombre de mots cles facteurs insuffisant minimum : %s" % definition.min)
77 if definition.max is not None and len(self.data) > definition.max :
80 self.cr.fatal("Nombre de mots cles facteurs trop grand maximum : %s" % definition.max)
86 if cr=='oui' and len(self) > 1:
87 self.cr.fatal(string.join(["L'occurrence n",`num`," du mot-clé facteur :",self.nom," n'est pas valide"]))
92 Génère le rapport de validation de self
95 # Mot cle facteur multiple
96 self.cr=self.CR( debut = "Mot-clé facteur multiple : "+self.nom,
97 fin = "Fin Mot-clé facteur multiple : "+self.nom)
99 self.cr.add(i.report())
101 # Mot cle facteur non multiple
102 self.cr=self.data[0].report()
104 self.cr=self.CR( debut = "Mot-cle facteur : "+self.nom,
105 fin = "Fin Mot-cle facteur : "+self.nom)
108 self.isvalid(cr='oui')
109 except AsException,e:
110 if CONTEXT.debug : traceback.print_exc()
111 self.cr.fatal(string.join(["Mot-clé facteur multiple : ",self.nom,str(e)]))