1 # -*- coding: utf-8 -*-
2 #@ MODIF N_ASSD Noyau DATE 27/03/2002 AUTEUR DURAND C.DURAND
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 # ======================================================================
29 Classe de base pour definir des types de structures de donnees ASTER
30 equivalent d un concept ASTER
34 def __init__(self,etape=None,sd=None,reg='oui'):
36 reg est un paramètre qui vaut oui ou non :
37 - si oui (défaut) : on enregistre la SD auprès du JDC
38 - si non : on ne l'enregistre pas
44 self.parent=etape.parent
46 self.parent=CONTEXT.get_current_step()
48 self.jdc = self.parent.get_jdc_root()
55 self.id = self.parent.reg_sd(self)
57 self.id = self.parent.o_register(self)
59 def __getitem__(self,key):
60 return self.etape[key]
62 def is_object(valeur):
64 Indique si valeur est d'un type conforme à la classe (retourne 1)
65 ou non conforme (retourne 0)
71 Retourne le nom de self, éventuellement en le demandant au JDC
75 self.nom=self.parent.get_name(self) or self.id
78 if string.find(self.nom,'sansnom') != -1 or self.nom == '':
84 Cassage des boucles de références pour destruction du JDC
91 def accept(self,visitor):
93 Cette methode permet de parcourir l'arborescence des objets
94 en utilisant le pattern VISITEUR
96 visitor.visitASSD(self)
100 def is_object(valeur):
102 Indique si valeur est d'un type conforme à la classe (1)
104 La classe assd est utilisée pour valider tout objet