Salome HOME
update with the version in the OCC branch OCC_development_generic_2006.
[modules/med.git] / src / MEDWrapper / V2_1 / Core / med_hdfi.hxx
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 #ifndef MED_HDFI_H
20 #define MED_HDFI_H
21 #include "med.hxx"
22
23 /* FONCTIONS INTERFACE MED/HDF */
24 namespace med_2_1{
25
26 /* Gestion des fichiers HDF */
27 extern
28 med_idt _MEDfichierCreer(char *nom);
29
30 extern
31 med_idt _MEDfichierOuvrir(char *nom,med_mode_acces mode);
32
33 extern
34 med_err _MEDfichierFermer(med_idt fid);
35
36
37 /* Gestion des datagroups HDF */
38 extern 
39 med_idt _MEDdatagroupCreer(med_idt pid, char *nom);
40
41 extern 
42 med_idt _MEDdatagroupOuvrir(med_idt pid, char *nom);
43
44 extern
45 med_err _MEDdatagroupFermer(med_idt id);
46
47
48 /* Gestion des datasets HDF */
49
50 extern 
51 med_idt _MEDdatasetOuvrir(med_idt pid,char *nom);
52
53 extern
54 med_err _MEDdatasetFermer(med_idt id);
55
56 extern
57 med_err _MEDdatasetNumEcrire (med_idt pere,char *nom, med_type_champ type,
58                              med_mode_switch interlace, med_size nbdim, med_size fixdim, 
59                              med_size psize, med_ssize * profil, med_int ngauss,
60                               med_size *size,  unsigned char *val, med_mode_acces mode);
61
62
63 extern
64 med_err _MEDdatasetNumLire(med_idt pere,char *nom,med_type_champ type,
65                            med_mode_switch interlace, med_size nbdim, med_size fixdim, 
66                            med_size psize, med_ssize * pfltab, med_int ngauss,
67                            unsigned char *val);
68
69 extern
70 med_err _MEDdatasetStringEcrire(med_idt pere,char *nom,med_size *dimd,
71                                 char *val, med_mode_acces mode);
72
73 extern
74 med_err _MEDdatasetStringLire(med_idt pere,char *nom,char *val);
75
76 /* Gestion des attributs HDF */
77 extern 
78 med_idt _MEDattrOuvrir(med_idt pid,char * nom);
79
80 extern
81 med_err _MEDattrFermer(med_idt id);
82
83 extern
84 med_err _MEDattrNumEcrire(med_idt pere,med_type_champ type,char *nom,unsigned char *val,med_mode_acces mode);
85
86 #define _MEDattrEntierEcrire(w,x,y,z)  _MEDattrNumEcrire(w,MED_INT   ,x,(unsigned char *) y,z)
87 #define _MEDattrFloatEcrire(w,x,y,z)   _MEDattrNumEcrire(w,MED_REEL64,x,(unsigned char *) y,z)
88
89 extern
90 med_err _MEDattrNumLire(med_idt pere,med_type_champ type,char *nom,unsigned char *val);
91
92 #define _MEDattrEntierLire(x,y,z) _MEDattrNumLire(x,MED_INT   ,y,(unsigned char*)z)
93 #define _MEDattrFloatLire(x,y,z)  _MEDattrNumLire(x,MED_REEL64,y,(unsigned char*)z)
94
95 extern
96 med_err _MEDattrStringEcrire(med_idt pere,char *nom,int longueur,char *val,med_mode_acces mode);
97
98 extern
99 med_err _MEDattrStringLire(med_idt pere,char *nom,int longueur,char *val);
100
101
102 /* Divers */
103 extern
104 med_err _MEDindiceInfo(med_idt id, const char *nom, void *donnees);
105
106 extern
107 med_err _MEDindiceNum(med_idt id,const char *nom, void *donnees);
108
109 extern  
110 med_err _MEDobjetIdentifier(med_idt fid,char *chemin,int indice,void *nom);
111
112 extern 
113 med_err _MEDnObjets(med_idt fid,char *chemin,int *n);
114
115 extern 
116 void _MEDmodeErreurVerrouiller(); 
117
118 }
119
120 #endif /* MED_HDFI_H */