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.
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 # ======================================================================
21 from __future__ import absolute_import
23 from builtins import object
26 class AU_PLUS_UN(object):
29 La regle verifie que l'on trouve 1 (au plus) des mots-cles
30 de la regle parmi les arguments d'un OBJECT.
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.
37 def verif(self, args):
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
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.
45 # on compte le nombre de mots cles presents
48 args = self.listeToDico(args)
50 count = count + args.get(mc, 0)
52 text = "- Il ne faut qu'un mot-cle (au plus) parmi : " + \
57 def listeToDico(self, args):
58 if type(args) is dict:
60 elif type(args) in (list, tuple):
63 dico[arg] = dico.get(arg, 0) + 1
66 raise Exception( "Erreur ce n'est ni un dictionnaire ni une liste %s" % args)