Salome HOME
CCAR: merge de la version 1.14 dans la branche principale
[tools/eficas.git] / Aster / Cata / cataSTA9 / SD / sd_proj_mesu.py
1 #@ MODIF sd_proj_mesu SD  DATE 15/01/2008   AUTEUR PELLET J.PELLET 
2 # -*- coding: iso-8859-1 -*-
3 #            CONFIGURATION MANAGEMENT OF EDF VERSION
4 # ======================================================================
5 # COPYRIGHT (C) 1991 - 2007  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.
10 #
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.
15 #
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.
19 # ======================================================================
20
21 from SD import *
22 from sd_modele  import sd_modele
23
24
25
26 class sd_proj_mesu(AsBase):
27 #-------------------------------------
28     nomj = SDNom(fin=18)
29     PJMNO = AsVI()
30     PJMRG = AsVK8()
31     PJMBP = AsVR()
32     PJMRF = AsVK16(lonmax=5)
33
34     # si PROJ_MESU_MODAL :
35     PJMOR = Facultatif(AsVR())
36
37     # si MACR_ELEM_STAT :
38     PJMIG    = Facultatif(AsVR())
39     PJMMM    = Facultatif(AsObject(genr='V',type=Parmi('C', 'R')))
40
41
42     def exists(self):
43     #  retourne .true. si la SD semble exister
44         return self.PJMNO.exists
45
46
47     def check_1(self, checker):
48     #------------------------------------
49         if not self.exists() : return
50
51         nbutil=self.PJMNO.lonuti
52         assert nbutil > 0 , nbutil
53
54         # vérifications communes :
55         assert self.PJMRG.lonmax >= nbutil
56         n1=self.PJMBP.lonmax
57         nbmode=n1/nbutil
58         assert n1==nbutil*nbmode , (nbmode,nbutil,n1)
59         assert self.PJMRF.exists
60         pjmrf=self.PJMRF.get_stripped()
61         sd2=sd_modele(pjmrf[0]) ; sd2.check(checker)
62         assert pjmrf[1] != '' , pjmrf
63         assert pjmrf[2] != '' , pjmrf
64
65         # quel cas de figure : PROJ_MESU_MODAL ou MACR_ELEM_STAT ?
66         lproj=self.PJMOR.exists
67
68         # si PROJ_MESU_MODAL :
69         if lproj :
70             nbcapt=nbutil
71             assert self.PJMOR.lonmax >= 3*nbcapt
72             assert not self.PJMIG.exists
73             assert pjmrf[3] == '' , pjmrf
74             assert pjmrf[4] == '' , pjmrf
75
76         # si MACR_ELEM_STAT :
77         else :
78             nbddle=nbutil
79             assert self.PJMIG.exists
80             assert self.PJMMM.exists
81             n1=self.PJMIG.lonmax
82             nbmoid=n1/nbddle
83             assert n1==nbddle*nbmoid , (nbmodi,nbddle,n1)
84
85             assert pjmrf[3] != '' , pjmrf
86             sd2=sd_proj_mesu(pjmrf[4]) ; sd2.check(checker)
87