]> SALOME platform Git repositories - tools/eficas.git/blob - Noyau/ascheckers.py
Salome HOME
CCAR: merge de la version de developpement V1_12a2 dans la branche principale
[tools/eficas.git] / Noyau / ascheckers.py
1 #@ MODIF ascheckers Noyau  DATE 23/05/2007   AUTEUR PELLET J.PELLET 
2 # -*- coding: iso-8859-1 -*-
3 #            CONFIGURATION MANAGEMENT OF EDF VERSION
4 # ======================================================================
5 # COPYRIGHT (C) 1991 - 2007  EDF R&D                  WWW.CODE-ASTER.ORG
6 # THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
7 # IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
8 # THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR
9 # (AT YOUR OPTION) ANY LATER VERSION.
10 #
11 # THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT
12 # WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF
13 # MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU
14 # GENERAL PUBLIC LICENSE FOR MORE DETAILS.
15 #
16 # YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE
17 # ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,
18 #    1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.
19 # ======================================================================
20
21 class Parmi(object):
22     """Classe qui exprime une contrainte multiple pour un attribut"""
23     def __init__(self, *args):
24         self.values = list(args)
25
26     def add_value(self, value ):
27         if value not in self.values:
28             self.values.append( value )
29
30     def __call__(self, obj, name, value, log ):
31         if value not in self.values:
32             log.err( obj, "l'attribut %s=%r n'est pas dans %r" % (name, value, self.values) )
33
34     def __repr__(self):
35         l = [ "Parmi(", ]
36         g = [ repr(v) for v in self.values ]
37         l.append( ", ".join(g) )
38         l.append( ")" )
39         return "".join( l )
40
41 class CheckLog(object):
42     """Un validateur qui enregistre toutes
43     les erreurs trouvées"""
44     def __init__(self):
45         self.msg = []
46         self.names = {}
47         self.optional = False
48
49     def log(self, level, obj, msg ):
50         if obj :
51             self.msg.append( (level, obj.nomj(), msg) )
52         else :
53             self.msg.append( (level, 'None', msg) )
54
55     def err(self, obj, msg ):
56         self.log( 0, obj, msg )
57
58     def warn(self, obj, msg ):
59         self.log( 1, obj, msg )
60
61     def visit(self, obj ):
62         self.names[obj.nomj()] = 1
63
64     def __str__(self):
65         d = { 0: "E", 1:"W" }
66         return "\n".join( [ "%s:%s: %s" % (d[l],n,m)
67                             for l,n,m in self.msg ])
68
69 class CheckFail(CheckLog):
70     """Un validateur qui lève une exception
71     dès la première erreur"""
72     def err(self, obj, msg ):
73         raise AssertionError("%s: %s" % (obj.nomj(), msg) )