Salome HOME
chgt copyright
[tools/eficas.git] / Validation / V_MCLIST.py
1 # coding=utf-8
2 # ======================================================================
3 # Copyright (C) 2007-2021   EDF R&D
4 # THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
5 # IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
6 # THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR
7 # (AT YOUR OPTION) ANY LATER VERSION.
8 #
9 # THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT
10 # WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF
11 # MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU
12 # GENERAL PUBLIC LICENSE FOR MORE DETAILS.
13 #
14 # YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE
15 # ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,
16 #    1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.
17 #
18 #
19 # ======================================================================
20
21
22 """
23    Ce module contient la classe mixin MCList qui porte les methodes
24    necessaires pour realiser la validation d'un objet de type MCList
25    derive de OBJECT.
26
27    Une classe mixin porte principalement des traitements et est
28    utilisee par heritage multiple pour composer les traitements.
29 """
30 # Modules Python
31 from __future__ import print_function
32 from __future__ import absolute_import
33 try : 
34   from builtins import object
35 except : pass
36
37 import traceback
38
39 # Modules EFICAS
40 from Extensions.i18n import tr
41 from Noyau import MAXSIZE, MAXSIZE_MSGCHK
42 from Noyau import N_CR
43 from Noyau.N_Exception import AsException
44
45
46 class MCList(object):
47
48     """
49        Cette classe a deux attributs de classe :
50
51        - CR qui sert a construire l'objet compte-rendu
52
53        - txt_nat qui sert pour les comptes-rendus lies a cette classe
54     """
55
56     CR = N_CR.CR
57     txt_nat = "Mot cle Facteur Multiple :"
58
59     def isValid(self, cr='non'):
60         """
61            Methode pour verifier la validite du MCList. Cette methode
62            peut etre appelee selon plusieurs modes en fonction de la valeur
63            de cr.
64
65            Si cr vaut oui elle cree en plus un compte-rendu.
66
67            On n'utilise pas d'attribut pour stocker l'etat et on ne remonte pas
68            le changement d'etat au parent (pourquoi ??)
69            MCLIST est une liste de MCFACT. Les MCFACT ont le meme parent
70            que le MCLIST qui les contient. Il n'est donc pas necessaire de
71            remonter le changement d'etat au parent. C'est deja fait
72            par les MCFACT.
73         """
74         if len(self.data) == 0:
75             return 0
76
77         valid = 1
78         definition = self.data[0].definition
79         # Verification du nombre des mots cles facteurs
80         if definition.min is not None and len(self.data) < definition.min:
81             valid = 0
82             if cr == 'oui':
83                 self.cr.fatal( "Nombre de mots cles facteurs insuffisant minimum : %s" % definition.min)
84
85         if definition.max is not None and len(self.data) > definition.max:
86             valid = 0
87             if cr == 'oui':
88                 self.cr.fatal(
89                     "Nombre de mots cles facteurs trop grand maximum : %s" % definition.max)
90         num = 0
91         for i in self.data:
92             num = num + 1
93             if not i.isValid():
94                 valid = 0
95                 if cr == 'oui' and len(self) > 1:
96                     self.cr.fatal( "L'occurrence numero %d du mot-cle facteur : %s n'est pas valide" % (num, self.nom))
97         return valid
98
99     def report(self):
100         """
101             Genere le rapport de validation de self
102         """
103         if len(self) > 1:
104             # Mot cle facteur multiple
105             self.cr = self.CR( debut="Mot-cle facteur multiple : " + tr(self.nom),
106                 fin="Fin Mot-cle facteur multiple : " + tr(self.nom))
107             j = 0
108             for i in self.data:
109                 j += 1
110                 if j > MAXSIZE:
111                     print (MAXSIZE_MSGCHK.format(MAXSIZE, len(self.data)))
112                     break
113                 self.cr.add(i.report())
114         elif len(self) == 1:
115             # Mot cle facteur non multiple
116             self.cr = self.data[0].report()
117         else:
118             self.cr = self.CR(debut="Mot-cle facteur : " + tr(self.nom) ,
119                             fin="Fin Mot-cle facteur : " + tr(self.nom))
120
121         try:
122             self.isValid(cr='oui')
123         except AsException as e:
124             if CONTEXT.debug:
125                 traceback.print_exc()
126             self.cr.fatal(" %s Mot-cle facteur multiple : %s" %( self.nom, e))
127         return self.cr