Files
opm-common/opm/parser/eclipse/Parser/ParserItem.hpp

104 lines
2.9 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>
#include <opm/parser/eclipse/Deck/DeckItem.hpp>
namespace Opm {
class ParserItem {
public:
ParserItem(const std::string& itemName, ParserItemSizeEnum sizeType);
virtual DeckItemConstPtr scan(RawRecordPtr rawRecord) const = 0;
virtual DeckItemConstPtr scan(size_t expectedItems, RawRecordPtr rawRecord) const = 0;
const std::string& name() const;
ParserItemSizeEnum sizeType() const;
static int defaultInt();
virtual ~ParserItem() {
}
protected:
#include "ParserItemTemplate.hpp"
private:
std::string m_name;
ParserItemSizeEnum m_sizeType;
};
typedef boost::shared_ptr<const ParserItem> ParserItemConstPtr;
typedef boost::shared_ptr<ParserItem> ParserItemPtr;
}
#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);
// }
// };