]> SALOME platform Git repositories - modules/med.git/blob - src/MEDWrapper/V2_1/Core/MEDdatasetStringEcrire.cxx
Salome HOME
Mantis issue 0021668: [CEA 564] MED2.1 to MED2.3
[modules/med.git] / src / MEDWrapper / V2_1 / Core / MEDdatasetStringEcrire.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 #include "med_outils.hxx"
21
22 /*
23  * - Nom de la fonction : _MEDdatasetStringEcrire
24  * - Description : ecriture d'un dataset tableau de caracteres
25  * - Parametres :
26  *     - pere (IN)     : l'ID de l'objet HDF pere ou placer l'attribut
27  *     - nom  (IN)     : le nom de l'attribut 
28  *     - dimd (IN)     : profil du tableau
29  *     - val  (IN)     : valeurs du tableau
30  *     - mode (IN)     : mode d'ecriture MED
31  * - Resultat : 0 en cas de succes, -1 sinon
32  */ 
33
34 namespace med_2_1{
35
36 med_err 
37 _MEDdatasetStringEcrire(med_idt pere,char *nom,med_size *dimd,
38                         char *val, med_mode_acces mode)
39 {
40   med_idt dataset;
41   med_idt datatype = 0;
42   med_idt dataspace = 0;
43   med_err ret;
44
45   if ((dataset = H5Dopen(pere,nom)) < 0)
46     {
47       if ((dataspace = H5Screate_simple(1,dimd,NULL)) < 0)
48         return -1;
49       if((datatype = H5Tcopy(H5T_C_S1)) < 0)
50         return -1;
51       if((ret = H5Tset_size(datatype,1)) < 0)
52         return -1;
53       if ((dataset = H5Dcreate(pere,nom,datatype,dataspace,
54                              H5P_DEFAULT)) < 0)
55         return -1;    
56     }
57   else
58     if (mode != MED_REMP)
59       {
60         H5Dclose(dataset);
61         return -1;
62       }
63     else
64       {
65       if ((dataspace = H5Screate_simple(1,dimd,NULL)) < 0)
66         return -1;
67       if((datatype = H5Tcopy(H5T_C_S1)) < 0)
68         return -1;
69       if((ret = H5Tset_size(datatype,1)) < 0)
70         return -1;
71       }
72   if ((ret = H5Dwrite(dataset,datatype,H5S_ALL,H5S_ALL,
73                       H5P_DEFAULT, val)) < 0)
74     return -1;
75   if (dataspace)
76     if((ret = H5Sclose(dataspace)) < 0)
77       return -1;
78   if (datatype)
79     if ((ret = H5Tclose(datatype)) < 0)
80       return -1;
81   if ((ret = H5Dclose(dataset)) < 0)
82     return -1;
83
84   return 0;
85 }
86
87 }