169 lines
5.5 KiB
C++
169 lines
5.5 KiB
C++
/*
|
|
Copyright 2013 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 <http://www.gnu.org/licenses/>.
|
|
*/
|
|
#ifndef PARSER_ITEM_H
|
|
#define PARSER_ITEM_H
|
|
|
|
#include <string>
|
|
#include <sstream>
|
|
#include <iostream>
|
|
#include <vector>
|
|
|
|
#include <boost/shared_ptr.hpp>
|
|
#include <boost/lexical_cast.hpp>
|
|
|
|
#include <opm/parser/eclipse/Parser/ParserEnums.hpp>
|
|
#include <opm/parser/eclipse/RawDeck/RawRecord.hpp>
|
|
|
|
namespace Opm {
|
|
|
|
class ParserItem {
|
|
public:
|
|
ParserItem(const std::string& itemName, ParserItemSizeEnum sizeType);
|
|
std::string name();
|
|
ParserItemSizeEnum sizeType();
|
|
|
|
static int defaultInt();
|
|
|
|
protected:
|
|
|
|
template<class T> void fillVectorFromStringToken(std::string token , std::vector<T>& dataVector, T defaultValue , bool& defaultActive) {
|
|
std::istringstream inputStream(token);
|
|
size_t starPos = token.find('*');
|
|
T value = defaultValue;
|
|
defaultActive = false;
|
|
|
|
if (starPos == std::string::npos) {
|
|
inputStream >> value;
|
|
dataVector.push_back( value );
|
|
} else {
|
|
if (starPos > 0) {
|
|
size_t multiplier;
|
|
int starChar;
|
|
|
|
inputStream >> multiplier;
|
|
starChar = inputStream.get();
|
|
if (starChar != '*')
|
|
throw std::invalid_argument("Error ...");
|
|
|
|
if (inputStream.peek() == std::char_traits<char>::eof())
|
|
defaultActive = true;
|
|
else
|
|
inputStream >> value;
|
|
|
|
for (size_t i = 0; i < multiplier; i++)
|
|
dataVector.push_back( value );
|
|
|
|
} else {
|
|
defaultActive = true;
|
|
inputStream.get();
|
|
if (token.size() > 1)
|
|
throw std::invalid_argument("Token : " + token + " is invalid.");
|
|
dataVector.push_back( defaultValue );
|
|
}
|
|
}
|
|
inputStream.get();
|
|
if (!inputStream.eof())
|
|
throw std::invalid_argument("Spurious data at the end of: <" + token + ">");
|
|
}
|
|
|
|
|
|
|
|
template<class T> std::vector<T> readFromRawRecord(RawRecordPtr rawRecord , bool scanAll , size_t expectedItems , T defaultValue , bool& defaultActive) {
|
|
bool cont = true;
|
|
std::vector<T> data;
|
|
do {
|
|
std::string token = rawRecord->pop_front();
|
|
fillVectorFromStringToken(token, data , defaultValue , defaultActive);
|
|
|
|
if (rawRecord->size() == 0)
|
|
cont = false;
|
|
else {
|
|
if (!scanAll)
|
|
if (data.size() >= expectedItems)
|
|
cont = false;
|
|
}
|
|
} while (cont);
|
|
return data;
|
|
}
|
|
|
|
|
|
template <class T> void pushBackToRecord( RawRecordPtr rawRecord , std::vector<T>& data , size_t expectedItems , bool defaultActive) {
|
|
size_t extraItems = data.size() - expectedItems;
|
|
|
|
for (size_t i=1; i <= extraItems; i++) {
|
|
if (defaultActive)
|
|
rawRecord->push_front("*");
|
|
else {
|
|
size_t offset = data.size();
|
|
int intValue = data[ offset - i ];
|
|
std::string stringValue = boost::lexical_cast<std::string>( intValue );
|
|
|
|
rawRecord->push_front( stringValue );
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
private:
|
|
std::string m_name;
|
|
ParserItemSizeEnum m_sizeType;
|
|
};
|
|
}
|
|
|
|
#endif
|
|
|
|
// bool scanItem(const std::string& itemString, T& value) {
|
|
// std::istringstream inputStream(itemString);
|
|
// T newValue;
|
|
// inputStream >> newValue;
|
|
//
|
|
// if (inputStream.fail())
|
|
// return false;
|
|
// else {
|
|
// char c;
|
|
// inputStream >> c;
|
|
// if (inputStream.eof() || c == ' ') {
|
|
// value = newValue;
|
|
// return true;
|
|
// } else
|
|
// return false;
|
|
// }
|
|
|
|
|
|
// int scanItems(const std::string& itemString, size_t items, std::vector<T>& values) {
|
|
// std::istringstream inputStream(itemString);
|
|
// unsigned int itemsRead = 0;
|
|
//
|
|
// while (inputStream.good() && itemsRead < items) {
|
|
// T value;
|
|
// inputStream >> value;
|
|
// values.push_back(value);
|
|
// itemsRead++;
|
|
// }
|
|
//
|
|
// return itemsRead;
|
|
// }
|
|
//
|
|
// int scanItems(const std::string& itemString, std::vector<T>& values) {
|
|
// return scanItems(itemString, m_itemSize->sizeValue(), values);
|
|
// }
|
|
|
|
|
|
// };
|