-#@ MODIF N_MCSIMP Noyau DATE 30/11/2007 AUTEUR COURTOIS M.COURTOIS
+#@ MODIF N_MCSIMP Noyau DATE 13/10/2008 AUTEUR COURTOIS M.COURTOIS
# -*- coding: iso-8859-1 -*-
# CONFIGURATION MANAGEMENT OF EDF VERSION
# ======================================================================
Cette valeur est utilisée lors de la création d'un contexte
d'évaluation d'expressions à l'aide d'un interpréteur Python
"""
- return self.valeur
+ v = self.valeur
+ # Singleton : on retourne l'element
+ # Permet aussi d'ignorer l'erreur : concept=COMMANDE(),
+ # ou 'concept' est un tuple de longueur 1 a cause de la virgule.
+ if type(v) in (list, tuple) and len(v) == 1:
+ v = v[0]
+ return v
def get_val(self):
"""
-#@ MODIF ascheckers Noyau DATE 28/11/2007 AUTEUR COURTOIS M.COURTOIS
+#@ MODIF ascheckers Noyau DATE 07/10/2008 AUTEUR PELLET J.PELLET
# -*- coding: iso-8859-1 -*-
# CONFIGURATION MANAGEMENT OF EDF VERSION
# ======================================================================
à la celle de la dernière vérification.
Si on incrémentait "marq" à chaque étape, on revérifie à chaque fois.
"""
+
def __init__(self):
self.msg = []
self.names = {}
+ self.cksums = {}
self.optional = False
self._marq = 1
self._lastmarq = self._marq
self._debug = False
+ self._profond = False # True pour forcer des vérifications plus profondes
def log(self, level, obj, msg ):
if obj :
key = obj.nomj()
self.names[key] = self._marq
+ def checkSumOJB(self, obj, sd, maj='non'):
+ # vérifie que le checksum de obj n'a pas changé
+ # sd : concept qui contient obj
+ # maj='maj', l'opérateur a le droit de modifier ojb
+ if obj.exists :
+ import md5
+ m=md5.new()
+ m.update(str(obj.get()))
+ cksum=m.digest()
+ nom=obj.nomj()
+ if not self.cksums.has_key(nom) :
+ self.cksums[nom]=cksum
+ else :
+ if self.cksums[nom] != cksum :
+ self.cksums[nom] = cksum
+ #if maj.strip()=='maj' and nom[0:8].strip()==sd.nomj.nomj[0:8].strip() :
+ # Remarque : ne pas tester 'maj' premet de résoudre (un peu) le problème
+ # posé par la commande DETRUIRE
+ if nom[0:8].strip()==sd.nomj.nomj[0:8].strip() :
+ pass
+ else :
+ self.err(obj,'Le checksum a changé')
+
def visitAsBase(self, obj):
key = (obj.nomj(), obj.__class__.__name__)
self.names[key] = self._marq
-#@ MODIF asojb Noyau DATE 07/04/2008 AUTEUR COURTOIS M.COURTOIS
+#@ MODIF asojb Noyau DATE 07/10/2008 AUTEUR PELLET J.PELLET
# -*- coding: iso-8859-1 -*-
# CONFIGURATION MANAGEMENT OF EDF VERSION
# ======================================================================
try :
v( checker )
except :
- UTMESS("E", 'SDVERI_45') # AJACOT NON
- print 40*'-'
- traceback.print_exc(file=sys.stdout)
- print self
+ mess=60*'-'+'\n'
+ mess=mess+'Erreur SDVERI_45 (Attention : vérification incomplète)'+'\n'
+ mess=mess.join(traceback.format_tb(sys.exc_traceback))
+ checker.err(self,mess)
checker.optional = optional
return checker
global _root
if _root : raise "Impossible d'affecter _root. Il devrait valoir None"
_root=step
+ print "dans set_current_step", step
def get_current_step():
"""
-#@ MODIF V_UN_PARMI Validation DATE 14/09/2004 AUTEUR MCOURTOI M.COURTOIS
+#@ MODIF V_UN_PARMI Validation DATE 16/09/2008 AUTEUR PELLET J.PELLET
# -*- coding: iso-8859-1 -*-
# CONFIGURATION MANAGEMENT OF EDF VERSION
# ======================================================================
# COPYRIGHT (C) 1991 - 2002 EDF R&D WWW.CODE-ASTER.ORG
# THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
# IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
-# THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR
-# (AT YOUR OPTION) ANY LATER VERSION.
+# THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR
+# (AT YOUR OPTION) ANY LATER VERSION.
+#
+# THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT
+# WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF
+# MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU
+# GENERAL PUBLIC LICENSE FOR MORE DETAILS.
+#
+# YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE
+# ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,
+# 1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.
#
-# THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT
-# WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF
-# MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU
-# GENERAL PUBLIC LICENSE FOR MORE DETAILS.
#
-# YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE
-# ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,
-# 1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.
-#
-#
# ======================================================================
La règle vérifie que l'on trouve un des mots-clés
de la règle parmi les arguments d'un OBJECT.
- Ces arguments sont transmis à la règle pour validation sous la forme
- d'une liste de noms de mots-clés ou d'un dictionnaire dont
+ Ces arguments sont transmis à la règle pour validation sous la forme
+ d'une liste de noms de mots-clés ou d'un dictionnaire dont
les clés sont des noms de mots-clés.
"""
def verif(self,args):
for mc in self.mcs:
if args.has_key(mc):count=count+1
if count != 1:
- text = "- Il ne faut qu'un mot-clé parmi : "+`self.mcs`+'\n'
+ text = "- Il faut un et un seul mot-clé parmi : "+`self.mcs`+'\n'
return text,0
return text,1