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.
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.
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 # ======================================================================
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.
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.
32 def verif(self, args):
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
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.
40 # on compte le nombre de mots cles presents
43 args = self.liste_to_dico(args)
45 count = count + args.get(mc, 0)
47 text = u"- Il ne faut qu'un mot-clé (au plus) parmi : " + \
52 def liste_to_dico(self, args):
53 if type(args) is dict:
55 elif type(args) in (list, tuple):
58 dico[arg] = dico.get(arg, 0) + 1
62 "Erreur ce n'est ni un dictionnaire ni une liste %s" % args)