/*
Copyright 2019 Statoil ASA.
This file is part of the Open Porous Media project (OPM).
OPM is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
OPM 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 General Public License for more details.
You should have received a copy of the GNU General Public License
along with OPM. If not, see .
*/
#ifndef OPM_IO_ECLOUTPUT_HPP
#define OPM_IO_ECLOUTPUT_HPP
#include
#include
#include
#include
#include
#include
#include
#include
namespace Opm { namespace EclIO { namespace OutputStream {
class Restart;
class SummarySpecification;
}}}
namespace Opm { namespace EclIO {
class EclOutput
{
public:
EclOutput(const std::string& filename,
const bool formatted,
const std::ios_base::openmode mode = std::ios::out);
template
void write(const std::string& name,
const std::vector& data)
{
eclArrType arrType = MESS;
if (typeid(T) == typeid(int))
arrType = INTE;
else if (typeid(T) == typeid(float))
arrType = REAL;
else if (typeid(T) == typeid(double))
arrType = DOUB;
else if (typeid(T) == typeid(bool))
arrType = LOGI;
else if (typeid(T) == typeid(char))
arrType = MESS;
if (isFormatted)
{
writeFormattedHeader(name, data.size(), arrType);
if (arrType != MESS)
writeFormattedArray(data);
}
else
{
writeBinaryHeader(name, data.size(), arrType);
if (arrType != MESS)
writeBinaryArray(data);
}
}
void message(const std::string& msg);
void flushStream();
friend class OutputStream::Restart;
friend class OutputStream::SummarySpecification;
private:
void writeBinaryHeader(const std::string& arrName, int64_t size, eclArrType arrType);
template
void writeBinaryArray(const std::vector& data);
void writeBinaryCharArray(const std::vector& data);
void writeBinaryCharArray(const std::vector>& data);
void writeFormattedHeader(const std::string& arrName, int size, eclArrType arrType);
template
void writeFormattedArray(const std::vector& data);
void writeFormattedCharArray(const std::vector& data);
void writeFormattedCharArray(const std::vector>& data);
void writeArrayType(const eclArrType arrType);
std::string make_real_string(float value) const;
std::string make_doub_string(double value) const;
bool isFormatted;
std::ofstream ofileH;
};
template<>
void EclOutput::write(const std::string& name,
const std::vector& data);
template <>
void EclOutput::write>
(const std::string& name,
const std::vector>& data);
}} // namespace Opm::EclIO
#endif // OPM_IO_ECLOUTPUT_HPP