Files
opm-common/opm/parser/eclipse/Parser/ParserRecord.cpp
Andreas Lauser ea38a25af4 remove all trailing white space
this is just the result of

```
find -iname "*.[ch]pp" | xargs sed -i "s/ *$//"
find opm/parser/share/keywords -type f |  xargs sed -i "s/ *$//"
```

so if it causes conflicts with other patches, the others should get
priority. The rationale behind this patch is that some people tell
their editor to remove white space which leads to larger than
necessary patches...
2014-12-08 16:34:28 +01:00

135 lines
4.8 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/>.
*/
#include <opm/parser/eclipse/Deck/Deck.hpp>
#include <opm/parser/eclipse/Parser/ParserRecord.hpp>
#include <opm/parser/eclipse/Parser/ParserItem.hpp>
namespace Opm {
ParserRecord::ParserRecord() {
}
size_t ParserRecord::size() const {
return m_items.size();
}
void ParserRecord::addItem(ParserItemConstPtr item) {
if (m_itemMap.find(item->name()) == m_itemMap.end()) {
m_items.push_back(item);
m_itemMap[item->name()] = item;
} else
throw std::invalid_argument("Itemname: " + item->name() + " already exists.");
}
std::vector<ParserItemConstPtr>::const_iterator ParserRecord::begin() const {
return m_items.begin();
}
std::vector<ParserItemConstPtr>::const_iterator ParserRecord::end() const {
return m_items.end();
}
bool ParserRecord::hasDimension() const {
bool hasDim = false;
for (auto iter=begin(); iter != end(); ++iter) {
if ((*iter)->hasDimension())
hasDim = true;
}
return hasDim;
}
void ParserRecord::applyUnitsToDeck(std::shared_ptr<const Deck> deck , std::shared_ptr<const DeckRecord> deckRecord) const {
for (auto iter=begin(); iter != end(); ++iter) {
if ((*iter)->hasDimension()) {
std::shared_ptr<DeckItem> deckItem = deckRecord->getItem( (*iter)->name() );
std::shared_ptr<const ParserItem> parserItem = get( (*iter)->name() );
for (size_t idim=0; idim < (*iter)->numDimensions(); idim++) {
std::shared_ptr<const Dimension> activeDimension = deck->getActiveUnitSystem()->getNewDimension( parserItem->getDimension(idim) );
std::shared_ptr<const Dimension> defaultDimension = deck->getDefaultUnitSystem()->getNewDimension( parserItem->getDimension(idim) );
deckItem->push_backDimension( activeDimension , defaultDimension );
}
}
}
}
ParserItemConstPtr ParserRecord::get(size_t index) const {
if (index < m_items.size())
return m_items[ index ];
else
throw std::out_of_range("Out of range");
}
ParserItemConstPtr ParserRecord::get(const std::string& itemName) const {
if (m_itemMap.find(itemName) == m_itemMap.end())
throw std::invalid_argument("Itemname: " + itemName + " does not exist.");
else {
std::map<std::string, ParserItemConstPtr>::const_iterator theItem = m_itemMap.find(itemName);
return (*theItem).second;
}
}
DeckRecordConstPtr ParserRecord::parse(RawRecordPtr rawRecord) const {
std::string recordBeforeParsing = rawRecord->getRecordString();
DeckRecordPtr deckRecord(new DeckRecord());
for (size_t i = 0; i < size(); i++) {
ParserItemConstPtr parserItem = get(i);
DeckItemPtr deckItem = parserItem->scan(rawRecord);
deckRecord->addItem(deckItem);
}
const size_t recordSize = rawRecord->size();
if (recordSize > 0)
throw std::invalid_argument("The RawRecord for keyword \"" + rawRecord->getKeywordName() + "\" in file\"" + rawRecord->getFileName() + "\" contained " +
boost::lexical_cast<std::string>(recordSize) +
" too many items according to the spec. RawRecord was: " + recordBeforeParsing);
return deckRecord;
}
bool ParserRecord::equal(const ParserRecord& other) const {
bool equal_ = true;
if (size() == other.size()) {
size_t itemIndex = 0;
while (true) {
if (itemIndex == size())
break;
{
ParserItemConstPtr item = get(itemIndex);
ParserItemConstPtr otherItem = other.get(itemIndex);
if (!item->equal(*otherItem)) {
equal_ = false;
break;
}
}
itemIndex++;
}
} else
equal_ = false;
return equal_;
}
}