/usr/share/pyshared/Validation/V_MCFACT.py is in eficas 6.4.0-1-1.1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 | #@ MODIF V_MCFACT Validation DATE 07/09/2009 AUTEUR COURTOIS M.COURTOIS
# -*- coding: iso-8859-1 -*-
# RESPONSABLE COURTOIS M.COURTOIS
# 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.
#
# 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.
#
#
# ======================================================================
"""
Ce module contient la classe mixin MCFACT qui porte les méthodes
nécessaires pour réaliser la validation d'un objet de type MCFACT
dérivé de OBJECT.
Une classe mixin porte principalement des traitements et est
utilisée par héritage multiple pour composer les traitements.
"""
# Modules Python
import string
# Modules EFICAS
import V_MCCOMPO
class MCFACT(V_MCCOMPO.MCCOMPO):
"""
Cette classe a un attribut de classe :
- txt_nat qui sert pour les comptes-rendus liés à cette classe
"""
txt_nat="Mot cle Facteur :"
def isvalid(self,sd='oui',cr='non'):
"""
Methode pour verifier la validité du MCFACT. Cette méthode
peut etre appelée selon plusieurs modes en fonction de la valeur
de sd et de cr.
Si cr vaut oui elle crée en plus un compte-rendu
sd est présent pour compatibilité de l'interface mais ne sert pas
"""
if self.state == 'unchanged' :
return self.valid
else:
valid = 1
if hasattr(self,'valid'):
old_valid = self.valid
else:
old_valid = None
for child in self.mc_liste :
if not child.isvalid():
valid = 0
break
# Après avoir vérifié la validité de tous les sous-objets, on vérifie
# la validité des règles
text_erreurs,test_regles = self.verif_regles()
if not test_regles :
if cr == 'oui' : self.cr.fatal(string.join(("Règle(s) non respectée(s) :", text_erreurs)))
valid = 0
#
# On verifie les validateurs s'il y en a
#
if self.definition.validators and not self.definition.validators.verif(self.valeur):
if cr == 'oui' :
self.cr.fatal(string.join(("Mot-clé : ",self.nom,"devrait avoir ",self.definition.validators.info())))
valid=0
# fin des validateurs
#
if self.reste_val != {}:
if cr == 'oui' :
self.cr.fatal("Mots cles inconnus :" + string.join(self.reste_val.keys(),','))
valid=0
self.valid = valid
self.state = 'unchanged'
if not old_valid or old_valid != self.valid :
self.init_modif_up()
return self.valid
|