1 #@ MODIF N_FONCTION Noyau DATE 18/12/2007 AUTEUR COURTOIS M.COURTOIS
2 # -*- coding: iso-8859-1 -*-
3 # CONFIGURATION MANAGEMENT OF EDF VERSION
4 # ======================================================================
5 # COPYRIGHT (C) 1991 - 2002 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.
21 # ======================================================================
23 # attention ! cet import permet d'avoir, dans les formules, le comportement
24 # de la division réelle pour les entiers, et non la division entière
26 from __future__ import division
28 from N_ASSD import ASSD
29 from asojb import AsBase
31 class FONCTION(ASSD):pass
33 class formule(ASSD,AsBase):
34 def __init__(self,**args):
35 ASSD.__init__(self,**args)
39 def __call__(self,*val):
40 if hasattr(self.parent,'contexte_fichier_init'):
41 context=self.parent.contexte_fichier_init
44 for param in self.nompar :
48 res=eval(self.expression,self.jdc.const_context, context)
51 print '! ' + '%-72s' % ('Erreur evaluation formule '+self.nom) + '!'
56 def setFormule(self,nom_para,texte):
58 Cette methode sert a initialiser les attributs
59 nompar, expression et code qui sont utilisés
60 dans l'évaluation de la formule
62 self.nompar = nom_para
63 self.expression = texte
65 self.code=compile(texte,texte,'eval')
68 print '! ' + '%-72s' % ('Erreur evaluation formule '+self.nom) + '!'
72 def __setstate__(self,state):
74 Cette methode sert a restaurer l'attribut code
77 self.__dict__.update(state) # update attributes
78 self.setFormule(self.nompar,self.expression) # restore code attribute
80 def __getstate__(self):
82 Pour les formules, il faut enlever l'attribut code
83 qui n'est pas picklable
85 d=ASSD.__getstate__(self)
90 """Equivalent de fonction.Parametres pour pouvoir utiliser des formules
91 à la place de fonctions dans certaines macro-commandes.
93 from SD.sd_fonction import sd_formule
94 from Utilitai.Utmess import UTMESS
95 if not self.par_lot():
96 TypeProl={'E':'EXCLU', 'L':'LINEAIRE', 'C':'CONSTANT', 'I':'INTERPRE' }
97 sd = sd_formule(self.get_name())
100 if prol is None or nova is None:
101 UTMESS('F', 'SDVERI_2', valk=[objev])
103 'INTERPOL' : ['LIN','LIN'],
104 'NOM_PARA' : [s.strip() for s in nova],
105 'NOM_RESU' : prol[3][0:16].strip(),
106 'PROL_DROITE' : TypeProl['E'],
107 'PROL_GAUCHE' : TypeProl['E'],
110 raise Accas.AsException("Erreur dans fonction.Parametres en PAR_LOT='OUI'")
114 class formule_c(formule):