Salome HOME
update version
[tools/eficas.git] / Validation / V_AU_PLUS_UN.py
1 # coding=utf-8
2 # person_in_charge: mathieu.courtois at edf.fr
3 # ======================================================================
4 # COPYRIGHT (C) 2007-2021  EDF R&D                  
5 # THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
6 # IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
7 # THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR
8 # (AT YOUR OPTION) ANY LATER VERSION.
9 #
10 # THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT
11 # WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF
12 # MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU
13 # GENERAL PUBLIC LICENSE FOR MORE DETAILS.
14 #
15 # YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE
16 # ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,
17 #    1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.
18 # ======================================================================
19
20
21 from __future__ import absolute_import
22 try :
23     from builtins import object
24 except : pass
25
26 class AU_PLUS_UN(object):
27
28     """
29        La regle verifie que l'on trouve 1 (au plus) des mots-cles
30        de la regle parmi les arguments d'un OBJECT.
31
32        Ces arguments sont transmis a la regle pour validation sous la forme
33        d'une liste de noms de mots-cles ou d'un dictionnaire dont
34        les cles sont des noms de mots-cles.
35     """
36
37     def verif(self, args):
38         """
39             La methode verif verifie que l'on trouve 1 (au plus) des mos-cles
40             de la liste self.mcs parmi les elements de args
41
42             args peut etre un dictionnaire ou une liste. Les elements de args
43             sont soit les elements de la liste soit les cles du dictionnaire.
44         """
45         #  on compte le nombre de mots cles presents
46         text = ''
47         count = 0
48         args = self.listeToDico(args)
49         for mc in self.mcs:
50             count = count + args.get(mc, 0)
51         if count > 1:
52             text = "- Il ne faut qu'un mot-cle (au plus) parmi : " + \
53                 repr(self.mcs)+'\n'
54             return text, 0
55         return text, 1
56
57     def listeToDico(self, args):
58         if type(args) is dict:
59             return args
60         elif type(args) in (list, tuple):
61             dico = {}
62             for arg in args:
63                 dico[arg] = dico.get(arg, 0) + 1
64             return dico
65         else:
66             raise Exception( "Erreur ce n'est ni un dictionnaire ni une liste %s" % args)