smesh/src/SMESHUtils/SMESH_File.hxx

125 lines
2.8 KiB
C++
Raw Normal View History

2022-05-05 18:51:12 +05:00
// Copyright (C) 2007-2022 CEA/DEN, EDF R&D, OPEN CASCADE
2012-08-09 16:03:55 +06:00
//
// 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
2014-02-20 18:25:37 +06:00
// version 2.1 of the License, or (at your option) any later version.
2012-08-09 16:03:55 +06:00
//
// 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 : SMESH_File.hxx
// Created : Wed Mar 10 10:33:04 2010
// Author : Edward AGAPOV (eap)
//
#ifndef __SMESH_File_HXX__
#define __SMESH_File_HXX__
#include "SMESH_Utils.hxx"
#include <string>
#include <vector>
#ifdef WIN32
2012-08-09 16:03:55 +06:00
#include <windows.h>
#else
#include <dlfcn.h>
#endif
/*!
* \brief High level util for effective file reading and other file operations
*/
class SMESHUtils_EXPORT SMESH_File
{
public:
SMESH_File(const std::string& name, bool openForReading=true);
2012-08-09 16:03:55 +06:00
~SMESH_File();
std::string getName() const { return _name; }
const std::string& error() const { return _error; }
2012-08-09 16:03:55 +06:00
void close();
bool remove();
long size();
bool exists();
bool isDirectory();
2012-08-09 16:03:55 +06:00
// ------------------------
// Access to file contents
// ------------------------
bool open(); // for reading
2012-08-09 16:03:55 +06:00
operator const char*() const { return _pos; }
bool operator++() { return ++_pos < _end; }
void operator +=(int posDelta) { _pos+=posDelta; }
bool eof() const { return _pos >= _end; }
const char* end() const { return _end; }
2012-08-09 16:03:55 +06:00
const char* getPos() const { return _pos; }
void setPos(const char* pos);
std::string getLine();
void rewind();
bool getInts(std::vector<int>& ids);
// ------------------------
// Writing a binary file
// ------------------------
bool openForWriting(); // binary writing only
template <typename T>
bool write( const T* values, size_t nbTValues )
{
return writeRaw((const void*) values, nbTValues * sizeof(T));
}
template <typename T>
bool write( const T& value )
{
return writeRaw((const void*) & value, sizeof(T));
}
bool writeRaw(const void* data, size_t size);
2012-08-09 16:03:55 +06:00
private:
std::string _name; //!< file name
long _size; //!< file size
std::string _error;
#ifdef WIN32
2012-08-09 16:03:55 +06:00
HANDLE _file, _mapObj;
#else
int _file;
#endif
void* _map;
const char* _pos; //!< current position
const char* _end; //!< position after file end
};
#endif