-using namespace std;
+// SALOME HDFPersist : implementation of HDF persitent ( save/ restore )
+//
+// Copyright (C) 2003 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
+// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
+//
+// This library is free software; you can redistribute it and/or
+// modify it under the terms of the GNU Lesser General Public
+// License as published by the Free Software Foundation; either
+// version 2.1 of the License.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+// Lesser General Public License for more details.
+//
+// You should have received a copy of the GNU Lesser General Public
+// License along with this library; if not, write to the Free Software
+// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+//
+// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
+//
+//
+//
+// File : HDFconvert.cc
+// Module : SALOME
+
#include "HDFconvert.hxx"
+using namespace std;
+
+#ifdef WNT
+#include <io.h>
+#include <windows.h>
+#endif
int HDFConvert::FromAscii(const string& file, const HDFcontainerObject & hdf_container, const string& nomdataset)
{
return -1;
};
- // Lit l'état du fichier
+ // Lit l'\89tat du fichier
if ( fstat(fd,&status) < 0) {
perror("HDFConvert::FromAscii");
return -1;
#ifdef _POSIX_MAPPED_FILES
- // Map le fichier en mémoire
+ // Map le fichier en m\89moire
if ( (buffer = (char *) mmap(0,length,PROT_READ,MAP_SHARED,fd,0)) == MAP_FAILED ) {
perror("HDFConvert::FromAscii");
return -1;
};
-
+#elif defined WNT
+
+#define SHMEMSIZE 4096
+
+ HANDLE hMapObject = CreateFileMapping(
+ INVALID_HANDLE_VALUE, NULL, PAGE_READWRITE, 0, SHMEMSIZE, "");
+ if (hMapObject != NULL) {
+ // Get a pointer to the file-mapped shared memory.
+ buffer = ( char* ) MapViewOfFile(
+ hMapObject, FILE_MAP_WRITE, 0, 0, 0 );
+ if( buffer == NULL )
+ CloseHandle(hMapObject);
+ };
+
#else
// Sort de la compilation
#endif
// Creation du Dataset utilisateur
- hdf_dataset = new HDFdataset::HDFdataset( (char *) nomdataset.c_str(), /*discard const */
- (HDFcontainerObject*) &hdf_container, /*discard const, pas de constructeur par référence */
+ hdf_dataset = new HDFdataset( (char *) nomdataset.c_str(), /*discard const */
+ (HDFcontainerObject*) &hdf_container, /*discard const, pas de constructeur par r\89f\89rence */
HDF_STRING,
&length_long,1);
// Cree le Dataset sur le disk
return -1;
};
+
+ return length;
};