1 #@ MODIF N_SENSIBILITE Noyau DATE 16/05/2007 AUTEUR COURTOIS M.COURTOIS
2 # -*- coding: iso-8859-1 -*-
3 # CONFIGURATION MANAGEMENT OF EDF VERSION
4 # ======================================================================
5 # COPYRIGHT (C) 1991 - 2006 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.
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.
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 # ======================================================================
22 Ce module contient les règles nécessaires aux commandes sensibles
23 pour renseigner l'attribut etape.sd.sensi, gérer le caractère réentrant
24 sur présence de la sensibilité.
27 from types import TupleType, ListType
28 EnumTypes = (TupleType, ListType)
30 from N_REGLE import REGLE
32 # -----------------------------------------------------------------------------
33 class CONCEPT_SENSIBLE(REGLE):
34 """Règle permettant de renseigner au niveau du catalogue comment sera
35 rempli le concept (valeur nominale ou dérivée(s) ou les deux...).
37 def __init__(self, mode, mocle='SENSIBILITE'):
40 mode : manière dont la commande rempli le concept
41 - 'ENSEMBLE' : concept nominal ET dérivées en une seule passe
42 - 'SEPARE' : concept nominal OU dérivée (une ou plusieurs)
44 mocle : mot-clé contenant les paramètres sensibles.
48 self._modes = { 'ENSEMBLE' : 0, 'SEPARE' : 1 }
49 self.mode = self._modes.get(mode, self._modes['ENSEMBLE'])
56 def verif(self, args):
57 """Retourne texte + 1 si ok, 0 si nook.
58 On stocke dans sd.sensi l'étape courante, c'est-à-dire celle qui
59 renseigne le concept si cela n'a pas déjà été fait (car verif est
60 appelé à chaque validation).
64 id_etape = '%s_%s' % (etape.id, id(etape))
67 if not hasattr(etape.sd,"sensi"):
69 # si ENSEMBLE, la sd nominale est forcément produite
70 if self.mode == self._modes['ENSEMBLE'] and not etape.sd.sensi.has_key('nominal'):
71 etape.sd.sensi['nominal'] = id_etape
72 # liste des paramètres sensibles
73 valeur = obj[self.mocle]
75 # pas de sensibilité, la sd nominale est produite
76 if not etape.sd.sensi.has_key('nominal'):
77 etape.sd.sensi['nominal'] = id_etape
79 if not type(valeur) in EnumTypes:
82 if not etape.sd.sensi.has_key(v.get_name()):
83 etape.sd.sensi[v.get_name()] = id_etape
87 # -----------------------------------------------------------------------------
88 class REUSE_SENSIBLE(REGLE):
89 """Limite le caractère réentrant de la commande.
90 On autorisera reuse seulement si le concept (au sens fortran) n'a pas déjà
91 été calculé (d'après sd.sensi). Ce sera interdit dans les cas suivants :
92 - sd nominale calculée et SENSIBILITE absent
93 - PS1 dans SENSIBILITE et sd dérivée par rapport à PS1 calculée
95 def __init__(self, mocle='SENSIBILITE'):
97 mocle : mot-clé SENSIBILITE.
107 def verif(self,args):
108 """Retourne texte + 1 si ok, 0 si nook = reuse interdit.
109 Comme CONCEPT_SENSIBLE est appelé avant (et à chaque validation),
110 on regarde si sd.sensi[ps] a été renseigné par une étape précédente.
114 id_etape = '%s_%s' % (etape.id, id(etape))
116 # si la commande n'est pas réentrante, rien à faire
117 if etape.reuse is not None:
118 valeur = obj[self.mocle]
120 if not hasattr(sd, 'sensi') or sd.sensi.get('nominal', id_etape) != id_etape:
121 # pas de sensibilite et concept nominal déjà calculé : reuse interdit
122 text = "Commande non réentrante en l'absence de sensibilité."
125 if not type(valeur) in EnumTypes:
128 if hasattr(sd, 'sensi') and sd.sensi.get(ps.nom, id_etape) != id_etape:
129 # concept dérivé par rapport à ps déjà calculé : reuse interdit
130 text = "Commande non réentrante : dérivée par rapport à %s déjà calculée" % ps.nom
135 # -----------------------------------------------------------------------------
136 class DERIVABLE(REGLE):
137 """Déclare que le concept fourni derrière un mot-clé est dérivable.
138 Sa présence ne suffit pas à le valider, il faut encore que son attribut
139 '.sensi' soit cohérent avec le contenu du mot-clé SENSIBILITE (ou l'absence
142 def __init__(self, mocle):
144 mocle : mot-clé dérivable.
154 def verif(self,args):
159 concept = obj[self.mocle]
162 if not type(concept) in EnumTypes:
164 l_ps = obj["SENSIBILITE"]
167 text = "Concept non défini (None) sous le mot-clé %s" % self.mocle
171 if hasattr(co,"sensi") and not co.sensi.get('nominal'):
172 text = "%s ne contient que des valeurs dérivées, utilisez le mot cle SENSIBILITE" %\
176 # sensibilité spécifiée
177 if not type(l_ps) in EnumTypes:
180 if not hasattr(co,"sensi") or not co.sensi.get(ps.nom):
181 text = "La dérivée de %s par rapport à %s n'est pas disponible." %\