Salome HOME
Modif V6_4_°
[tools/eficas.git] / Validation / V_MCLIST.py
1 #@ MODIF V_MCLIST Validation  DATE 07/09/2009   AUTEUR COURTOIS M.COURTOIS 
2 # -*- coding: iso-8859-1 -*-
3 # RESPONSABLE COURTOIS M.COURTOIS
4 #            CONFIGURATION MANAGEMENT OF EDF VERSION
5 # ======================================================================
6 # COPYRIGHT (C) 1991 - 2002  EDF R&D                  WWW.CODE-ASTER.ORG
7 # THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
8 # IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
9 # THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR   
10 # (AT YOUR OPTION) ANY LATER VERSION.                                 
11 #
12 # THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT 
13 # WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF          
14 # MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU    
15 # GENERAL PUBLIC LICENSE FOR MORE DETAILS.                            
16 #
17 # YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE   
18 # ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,       
19 #    1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.      
20 #                                                                       
21 #                                                                       
22 # ======================================================================
23
24
25 """
26    Ce module contient la classe mixin MCList qui porte les méthodes
27    nécessaires pour réaliser la validation d'un objet de type MCList
28    dérivé de OBJECT.
29
30    Une classe mixin porte principalement des traitements et est
31    utilisée par héritage multiple pour composer les traitements.
32 """
33 # Modules Python
34 import string
35 import traceback
36
37 # Modules EFICAS
38 from Noyau import N_CR
39 from Noyau.N_Exception import AsException
40
41 class MCList:
42    """
43       Cette classe a deux attributs de classe :
44
45       - CR qui sert à construire l'objet compte-rendu
46
47       - txt_nat qui sert pour les comptes-rendus liés à cette classe
48    """
49
50    CR=N_CR.CR
51    txt_nat="Mot cle Facteur Multiple :"
52
53    def isvalid(self,cr='non'):
54       """ 
55          Methode pour verifier la validité du MCList. Cette méthode
56          peut etre appelée selon plusieurs modes en fonction de la valeur
57          de cr.
58
59          Si cr vaut oui elle crée en plus un compte-rendu.
60
61          On n'utilise pas d'attribut pour stocker l'état et on ne remonte pas 
62          le changement d'état au parent (pourquoi ??)
63          MCLIST est une liste de MCFACT. Les MCFACT ont le meme parent
64          que le MCLIST qui les contient. Il n'est donc pas necessaire de
65          remonter le changement d'etat au parent. C'est deja fait
66          par les MCFACT.
67       """
68       if len(self.data) == 0 : return 0
69
70       valid= 1
71       definition=self.data[0].definition
72       # Verification du nombre des mots cles facteurs
73       if definition.min is not None and len(self.data) < definition.min :
74          valid=0
75          if cr == 'oui' :
76             self.cr.fatal("Nombre de mots cles facteurs insuffisant minimum : %s" % definition.min)
77
78       if definition.max is not None and len(self.data) > definition.max :
79          valid=0
80          if cr == 'oui' :
81             self.cr.fatal("Nombre de mots cles facteurs trop grand maximum : %s" % definition.max)
82       num = 0
83       for i in self.data:
84         num = num+1
85         if not i.isvalid():
86           valid = 0
87           if cr=='oui' and len(self) > 1:
88             self.cr.fatal(string.join(["L'occurrence n",`num`," du mot-clé facteur :",self.nom," n'est pas valide"]))
89       return valid
90
91    def report(self):
92       """ 
93           Génère le rapport de validation de self 
94       """
95       if len(self) > 1:
96          # Mot cle facteur multiple
97          self.cr=self.CR( debut = "Mot-clé facteur multiple : "+self.nom,
98                   fin = "Fin Mot-clé facteur multiple : "+self.nom)
99          for i in self.data:
100            self.cr.add(i.report())
101       elif len(self) == 1:
102          # Mot cle facteur non multiple
103          self.cr=self.data[0].report()
104       else:
105          self.cr=self.CR( debut = "Mot-cle facteur : "+self.nom,
106                   fin = "Fin Mot-cle facteur : "+self.nom)
107
108       try :
109         self.isvalid(cr='oui')
110       except AsException,e:
111         if CONTEXT.debug : traceback.print_exc()
112         self.cr.fatal(string.join(["Mot-clé facteur multiple : ",self.nom,str(e)]))
113       return self.cr
114