]> SALOME platform Git repositories - tools/eficas.git/blob - Aster/Cata/cataSTA10/SD/sd_courbe_lm.py
Salome HOME
Modif V6_4_°
[tools/eficas.git] / Aster / Cata / cataSTA10 / SD / sd_courbe_lm.py
1 #@ MODIF sd_courbe_lm SD  DATE 30/06/2009   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
23 class sd_courbe_lm(AsBase):
24     nomj = SDNom(fin=8)
25     MAIL1 = AsColl(SDNom(debut=8), acces='NU', stockage='CONTIG', modelong='VARIABLE', type='I', )
26     MAIL2 = AsColl(SDNom(debut=8), acces='NU', stockage='CONTIG', modelong='VARIABLE', type='I', )
27     CHEMIN = AsColl(SDNom(debut=8), acces='NU', stockage='CONTIG', modelong='VARIABLE', type='I', )
28     def check_DIM(self,checker):
29 # verification que les 3 collections ont le meme nbre d'objets
30        n1 = self.MAIL1.nmaxoc
31        n2 = self.MAIL2.nmaxoc
32        assert n1 == n2
33        bool = self.CHEMIN.exists
34        if self.CHEMIN.exists:
35           n = self.CHEMIN.nmaxoc
36           assert n == n1
37           chemin = self.CHEMIN.get()
38           mail1 = self.MAIL1.get()
39           mail2 = self.MAIL2.get()
40           for i in chemin.keys():
41             lon = len(chemin[i])
42             lon1 = len(mail1[i])
43             lon2 = len(mail2[i])
44 # verification que les objets des 3 collections ont la meme longueur
45             assert lon == lon1
46             assert lon == lon2
47             deb = chemin[i][0]
48             fin = chemin[i][lon-1]
49 # verification que le chemin est soit simple (fin = 0) soit cyclique (deb = fin)
50             assert (deb == fin) or (fin == 0)
51 # verification que le dernier entier des objets des collections mail1 et mail2 est nul
52             fin = mail1[i][lon1-1]
53             assert fin == 0
54             fin = mail2[i][lon2-1]
55             assert fin == 0
56