Salome HOME
update with the version in the OCC branch OCC_development_generic_2006.
[modules/med.git] / src / MEDWrapper / V2_1 / Core / MEDnEntites.cxx
1 /*************************************************************************
2 * COPYRIGHT (C) 1999 - 2002  EDF R&D
3 * THIS LIBRARY IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
4 * IT UNDER THE TERMS OF THE GNU LESSER GENERAL PUBLIC LICENSE 
5 * AS PUBLISHED BY THE FREE SOFTWARE FOUNDATION; 
6 * EITHER VERSION 2.1 OF THE LICENSE, OR (AT YOUR OPTION) ANY LATER VERSION.
7 *  
8 * THIS LIBRARY IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT
9 * WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF
10 * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU
11 * LESSER GENERAL PUBLIC LICENSE FOR MORE DETAILS.
12 *
13 * YOU SHOULD HAVE RECEIVED A COPY OF THE GNU LESSER GENERAL PUBLIC LICENSE
14 * ALONG WITH THIS LIBRARY; IF NOT, WRITE TO THE FREE SOFTWARE FOUNDATION,
15 * INC., 59 TEMPLE PLACE, SUITE 330, BOSTON, MA 02111-1307 USA
16 *
17 *************************************************************************/
18
19 #include "med.hxx"
20
21 namespace med_2_1{
22
23 med_int
24 MEDnEntites(med_idt fid,char *maa,med_entite_maillage typ_ent, 
25             med_connectivite typ_con)
26 {
27   med_int total = 0;
28   int i;  
29   med_geometrie_element typ_mai[MED_NBR_GEOMETRIE_MAILLE] = {MED_POINT1,MED_SEG2, 
30                                                     MED_SEG3,MED_TRIA3,
31                                                     MED_TRIA6,MED_QUAD4,
32                                                     MED_QUAD8,MED_TETRA4,
33                                                     MED_TETRA10,MED_HEXA8,
34                                                     MED_HEXA20,MED_PENTA6,
35                                                     MED_PENTA15,MED_PYRA5,
36                                                     MED_PYRA13};
37   med_geometrie_element typ_fac[MED_NBR_GEOMETRIE_FACE] = {MED_TRIA3,MED_TRIA6,
38                                                     MED_QUAD4,MED_QUAD8};
39   med_geometrie_element typ_are[MED_NBR_GEOMETRIE_ARETE] = {MED_SEG2,MED_SEG3};  
40
41   switch (typ_ent)
42   {
43      case MED_MAILLE :
44         for (i=0;i<MED_NBR_GEOMETRIE_MAILLE;i++)
45           total += MEDnEntMaa(fid,maa,MED_CONN,MED_MAILLE,typ_mai[i],typ_con);
46         break;
47
48      case MED_FACE :
49         for (i=0;i<MED_NBR_GEOMETRIE_FACE;i++)
50           total += MEDnEntMaa(fid,maa,MED_CONN,MED_FACE,typ_fac[i],typ_con);
51         break;
52
53      case MED_ARETE :
54         for (i=0;i<MED_NBR_GEOMETRIE_ARETE;i++)
55           total += MEDnEntMaa(fid,maa,MED_CONN,MED_ARETE,typ_are[i],typ_con);
56         break;
57
58      case MED_NOEUD :
59         total = MEDnEntMaa(fid,maa,MED_COOR,MED_NOEUD,(med_geometrie_element)0,(med_connectivite)0);
60         break;
61
62      default :
63         total = -1;
64   }
65
66   return total;
67 }
68
69 }