/* Copyright 2016 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 . */ #include #include #include #include #include #include #include #include #include #include #include namespace Opm { namespace MissingFeatures { template void addSupported(std::multimap >& map, T itemValue) { std::pair > pair({Keyword::keywordName, PartiallySupported{Item::itemName , itemValue}}); map.insert(pair); } template void checkOptions(const DeckKeyword& keyword, std::multimap >& map) { // check for partially supported keywords. typename std::multimap >::iterator it, itlow, itup; itlow = map.lower_bound(keyword.name()); itup = map.upper_bound(keyword.name()); for (it = itlow; it != itup; ++it) { const auto& record = keyword.getRecord(0); if (record.getItem(it->second.item).template get(0) != it->second.item_value) { std::string msg = "For keyword '" + it->first + "' only value " + boost::lexical_cast(it->second.item_value) + " in item " + it->second.item + " is supported by flow.\n" + "In file " + keyword.getFileName() + ", line " + std::to_string(keyword.getLineNumber()) + "\n"; OpmLog::warning(msg); } } } void checkKeywords(const Deck& deck) { // These keywords are supported by opm-parser, but are not supported // by flow. For some of them, only part of the options are supported. // The list is used to output messages only. std::unordered_set unsupported_keywords = { "ADSALNOD", "API", "AQUCON", "AQUNUM" "COMPLUMP", "CONNECTION", "CPR", "DATE", "ECHO", "EDITNNC", "ENDNUM", "ENDSKIP", "ENKSRVD", "ENPTVD", "EQLNUM", "EQUALREG", "EXCEL", "EXTRAPMS", "FILLEPS", "FIPNUM", "FULLIMP", "GDORIENT", "GECON", "GEFAC", "GRIDUNIT", "GRUPNET", "IMKRVD", "IMPES", "IMPTVD", "MAPUNITS", "MAXVALUE", "MESSAGES", "MINVALUE", "MONITOR", "MSGFILE", "MULT_XYZ", "NETBALAN", "NEXTSTEP", "NOCASC", "NOECHO", "NOGGF", "NOINSPEC", "NOMONITO", "NONNC", "NORSSPEC", "NSTACK", "NUMRES", "NUPCOL", "OILVISCT", "OLDTRAN", "OPTIONS", "PARALLEL", "PBVD", "PCG", "PERMXY", "PERMYZ", "PERMZX", "PIMULTAB", "PLYADSS", "PLYDHFLF", "RADFIN4", "RKTRMDIR", "ROCKCOMP", "ROCKOPTS", "ROCKTAB", "RPTGRID", "RPTONLY", "RPTONLYO", "RPTPROS", "PRTRST", "RPTRUNSP", "RPTSCHED", "RPTSOL", "RTEMPVD", "RUNSUM", "SATOPTS", "SAVE", "SEPARATE", "SKIP", "SKIP100", "SKIP300", "SKIPREST", "SPECGRID", "SSOL", "SUMTHIN", "TEMP", "THCONR", "TRACER", "TRACERS", "VAPPARS", "VISCREF", "WATVISCT", "WPAVE", "WPIMULT", "WPITAB", "WTEMP", "WTEST", "WTRACER", "ZIPPY2" }; std::multimap > string_options; std::multimap > int_options; addSupported(string_options , "DEPTH"); addSupported(string_options, "NODIR"); addSupported(string_options, "REVER"); addSupported(string_options, "GAP"); addSupported(string_options, "TOPBOT"); addSupported(int_options , 0); // check deck and keyword for flow and parser. for (size_t idx = 0; idx < deck.size(); ++idx) { const auto& keyword = deck.getKeyword(idx); std::unordered_set::const_iterator it; it = unsupported_keywords.find(keyword.name()); if (it != unsupported_keywords.end()) { std::string msg = "Keyword '" + keyword.name() + "' is not supported by flow.\n" + "In file " + keyword.getFileName() + ", line " + std::to_string(keyword.getLineNumber()) + "\n"; OpmLog::warning(msg); } checkOptions(keyword, string_options); checkOptions(keyword, int_options); } } } // namespace MissingFeatures } // namespace Opm