Salome HOME
bug
[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) 1991 - 2015  EDF R&D                  WWW.CODE-ASTER.ORG
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 class AU_PLUS_UN:
22
23     """
24        La règle vérifie que l'on trouve 1 (au plus) des mots-clés
25        de la règle parmi les arguments d'un OBJECT.
26
27        Ces arguments sont transmis à la règle pour validation sous la forme
28        d'une liste de noms de mots-clés ou d'un dictionnaire dont
29        les clés sont des noms de mots-clés.
30     """
31
32     def verif(self, args):
33         """
34             La méthode verif vérifie que l'on trouve 1 (au plus) des mos-clés
35             de la liste self.mcs parmi les éléments de args
36
37             args peut etre un dictionnaire ou une liste. Les éléments de args
38             sont soit les éléments de la liste soit les clés du dictionnaire.
39         """
40         #  on compte le nombre de mots cles presents
41         text = ''
42         count = 0
43         args = self.liste_to_dico(args)
44         for mc in self.mcs:
45             count = count + args.get(mc, 0)
46         if count > 1:
47             text = u"- Il ne faut qu'un mot-clé (au plus) parmi : " + \
48                 `self.mcs`+'\n'
49             return text, 0
50         return text, 1
51
52     def liste_to_dico(self, args):
53         if type(args) is dict:
54             return args
55         elif type(args) in (list, tuple):
56             dico = {}
57             for arg in args:
58                 dico[arg] = dico.get(arg, 0) + 1
59             return dico
60         else:
61             raise Exception(
62                 "Erreur ce n'est ni un dictionnaire ni une liste %s" % args)