2 # Copyright (C) 2007-2017 EDF R&D
4 # This library is free software; you can redistribute it and/or
5 # modify it under the terms of the GNU Lesser General Public
6 # License as published by the Free Software Foundation; either
7 # version 2.1 of the License.
9 # This library is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 # Lesser General Public License for more details.
14 # You should have received a copy of the GNU Lesser General Public
15 # License along with this library; if not, write to the Free Software
16 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
18 # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
25 from __future__ import absolute_import
26 from __future__ import print_function
28 from builtins import object
34 Classe de base pour definir des types de structures de donnees ASTER
35 equivalent d un concept ASTER
39 def __init__(self, etape=None, sd=None, reg='oui'):
41 reg est un parametre qui vaut oui ou non :
42 - si oui (défaut) : on enregistre la SD aupres du JDC
43 - si non : on ne l'enregistre pas
49 self.parent = etape.parent
51 self.parent = CONTEXT.getCurrentStep()
53 self.jdc = self.parent.getJdcRoot()
60 self.id = self.parent.regSD(self)
62 self.id = self.parent.o_register(self)
63 # permet de savoir si le concept a été calculé (1) ou non (0)
66 self.order = self.parent.icmd
69 # attributs pour le Catalogue de Structure de Données Jeveux
70 # "self.cata_sdj" est un attribut de classe
71 self.ptr_class_sdj = None
73 # construit en tant que CO('...')
74 # 0 : assd normal, 1 : type CO, 2 : type CO typé
78 """Retourne le catalogue de SD associé au concept."""
79 if self.ptr_sdj is None:
80 cata_sdj = getattr(self, 'cata_sdj', None)
81 assert cata_sdj, "The attribute 'cata_sdj' must be defined in the class %s" \
82 % self.__class__.__name__
83 assert self.nom, "The attribute 'nom' has not been filled!"
84 if self.ptr_class_sdj is None:
85 self.ptr_class_sdj = importObject(cata_sdj)
86 self.ptr_sdj = self.ptr_class_sdj(nomj=self.nom)
90 """Suppression du catalogue de SD."""
91 if self.ptr_sdj is not None:
92 self.ptr_sdj.supprime(True)
94 self.ptr_class_sdj = None
96 sdj = property(_getSdj, None, _del_sdj)
98 def __getitem__(self, key):
99 text_error = "ASSD.__getitem__ est déprécié car la référence a l'objet ETAPE parent sera supprimée."
100 from warnings import warn
101 warn(text_error, DeprecationWarning, stacklevel=2)
102 return self.etape[key]
104 def setName(self, nom):
105 """Positionne le nom de self (et appelle sd_init)
110 """Permet de savoir si l'ASSD est issu d'un type CO.
112 0 : ce n'est pas un type CO
113 1 : c'est un type CO, non encore typé
114 2 : c'est un type CO retypé
118 def changeType(self, new_type):
119 """Type connu a posteriori (type CO)."""
120 self.__class__ = new_type
121 assert self._as_co != 0, 'it should only be called on CO object.'
126 Retourne le nom de self, éventuellement en le demandant au JDC
130 self.nom = self.parent.getName(self) or self.id
133 if self.nom.find('sansnom') != -1 or self.nom == '':
137 def supprime(self, force=False):
139 Cassage des boucles de références pour destruction du JDC.
140 'force' est utilisée pour faire des suppressions complémentaires
141 (voir les formules dans N_FONCTION).
149 def supprimeSd(self):
150 """Supprime la partie du catalogue de SD."""
151 # 'del self.sdj' appellerait la méthode '_getSdj()'...
155 def accept(self, visitor):
157 Cette methode permet de parcourir l'arborescence des objets
158 en utilisant le pattern VISITEUR
160 visitor.visitASSD(self)
162 def __getstate__(self):
164 Cette methode permet de pickler les objets ASSD
165 Ceci est possible car on coupe les liens avec les objets
166 parent, etape et jdc qui conduiraient a pickler de nombreux
167 objets inutiles ou non picklables.
168 En sortie, l'objet n'est plus tout a fait le même !
170 d = self.__dict__.copy()
171 for key in ('parent', 'etape', 'jdc'):
174 for key in list(d.keys()):
175 if key in ('_as_co', ):
181 def accessible(self):
182 """Dit si on peut acceder aux "valeurs" (jeveux) de l'ASSD.
185 print(('| accessible ?', self.nom))
186 is_accessible = CONTEXT.getCurrentStep().sdAccessible()
188 print((' `- is_accessible =', repr(is_accessible)))
191 def filter_context(self, context):
192 """Filtre le contexte fourni pour retirer (en gros) ce qui vient du catalogue."""
193 from .N_ENTITE import ENTITE
196 for key, value in list(context.items()):
197 if type(value) is type:
199 if type(value) is types.ModuleType and value.__name__.startswith('Accas'):
201 if issubclass(type(value), type):
203 if isinstance(value, ENTITE):
209 """Conserver uniquement pour la compatibilite avec le catalogue v9 dans eficas."""
211 if not hasattr(self, 'jdc') or self.jdc == None:
214 val = self.jdc.parLot
217 def rebuild_sd(self):
218 """Conserver uniquement pour la compatibilite avec le catalogue v10 dans eficas."""
223 def __convert__(cls, valeur):
224 # On accepte les vraies ASSD et les objets 'entier' et 'reel'
225 # qui font tout pour se faire passer pour de vrais entiers/réels.
226 if isinstance(valeur, ASSD) or type(valeur) in (int, float):
228 raise ValueError(_(u"On attend un objet concept."))
229 __convert__ = classmethod(__convert__)
232 class not_checked(ASSD):
234 def __convert__(cls, valeur):
236 __convert__ = classmethod(__convert__)