2011-10-07 03:54:25 -05:00
|
|
|
|
//===========================================================================
|
|
|
|
|
//
|
|
|
|
|
// File: ParameterXML.cpp
|
|
|
|
|
//
|
|
|
|
|
// Created: Tue Jun 2 18:57:25 2009
|
|
|
|
|
//
|
|
|
|
|
// Author(s): B<>rd Skaflestad <bard.skaflestad@sintef.no>
|
|
|
|
|
// Atgeirr F Rasmussen <atgeirr@sintef.no>
|
|
|
|
|
//
|
|
|
|
|
// $Date$
|
|
|
|
|
//
|
|
|
|
|
// $Revision$
|
|
|
|
|
//
|
|
|
|
|
//===========================================================================
|
|
|
|
|
|
|
|
|
|
/*
|
2013-01-29 06:29:44 -06:00
|
|
|
|
Copyright 2009, 2010 SINTEF ICT, Applied Mathematics.
|
|
|
|
|
Copyright 2009, 2010 Statoil ASA.
|
2011-10-07 03:54:25 -05:00
|
|
|
|
|
2013-01-29 06:29:44 -06:00
|
|
|
|
This file is part of the Open Porous Media project (OPM).
|
2011-10-07 03:54:25 -05:00
|
|
|
|
|
2013-01-29 06:29:44 -06:00
|
|
|
|
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.
|
2011-10-07 03:54:25 -05:00
|
|
|
|
|
2013-01-29 06:29:44 -06:00
|
|
|
|
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.
|
2011-10-07 03:54:25 -05:00
|
|
|
|
|
2013-01-29 06:29:44 -06:00
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
|
along with OPM. If not, see <http://www.gnu.org/licenses/>.
|
2011-10-07 03:54:25 -05:00
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#if HAVE_CONFIG_H
|
|
|
|
|
#include "config.h"
|
|
|
|
|
#endif
|
2011-12-19 05:36:56 -06:00
|
|
|
|
#include <opm/core/utility/parameters/ParameterXML.hpp>
|
|
|
|
|
#include <opm/core/utility/parameters/Parameter.hpp>
|
|
|
|
|
#include <opm/core/utility/parameters/ParameterStrings.hpp>
|
2011-10-07 03:54:25 -05:00
|
|
|
|
|
|
|
|
|
#include <exception>
|
|
|
|
|
#include <iostream>
|
|
|
|
|
#include <string>
|
2013-08-08 05:32:01 -05:00
|
|
|
|
#include <memory>
|
2011-10-07 03:54:25 -05:00
|
|
|
|
#include <boost/filesystem.hpp>
|
2011-12-07 07:16:21 -06:00
|
|
|
|
|
2011-12-19 05:36:56 -06:00
|
|
|
|
#include <opm/core/utility/parameters/tinyxml/tinyxml.h>
|
2011-12-07 07:16:21 -06:00
|
|
|
|
|
2012-01-19 06:50:57 -06:00
|
|
|
|
namespace Opm {
|
2011-12-07 07:16:21 -06:00
|
|
|
|
namespace parameter {
|
|
|
|
|
|
|
|
|
|
namespace tinyxml {
|
2012-03-28 04:56:20 -05:00
|
|
|
|
std::string getProperty(const std::string& property,
|
|
|
|
|
const TiXmlElement* node_ptr);
|
2011-12-07 07:16:21 -06:00
|
|
|
|
void read_xml(ParameterGroup& pg, const std::string filename);
|
|
|
|
|
void fill_tree(ParameterGroup& pg,
|
|
|
|
|
const TiXmlNode* root,
|
|
|
|
|
const std::string& xml_file_path);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void fill_xml(ParameterGroup& pg, const std::string filename) {
|
|
|
|
|
tinyxml::read_xml(pg, filename);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
namespace tinyxml {
|
|
|
|
|
std::string getProperty(const std::string& property,
|
|
|
|
|
const TiXmlElement* node_ptr)
|
|
|
|
|
{
|
|
|
|
|
const char* prop_value_ptr = node_ptr->Attribute(property.c_str());
|
|
|
|
|
std::string property_value(prop_value_ptr ? prop_value_ptr : "");
|
|
|
|
|
return property_value;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void read_xml(ParameterGroup& pg, const std::string filename)
|
|
|
|
|
{
|
|
|
|
|
TiXmlDocument doc(filename);
|
|
|
|
|
bool ok = doc.LoadFile();
|
|
|
|
|
if (!ok) {
|
|
|
|
|
std::cerr << "ERROR: Failed to open XML file '" << filename << "'\n";
|
|
|
|
|
throw std::exception();
|
|
|
|
|
}
|
|
|
|
|
const TiXmlNode* root = doc.RootElement();
|
|
|
|
|
std::string xml_file_path = boost::filesystem::path(filename).branch_path().string();
|
|
|
|
|
fill_tree(pg, root, xml_file_path);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void fill_tree(ParameterGroup& pg,
|
|
|
|
|
const TiXmlNode* root,
|
|
|
|
|
const std::string& xml_file_path)
|
|
|
|
|
{
|
|
|
|
|
//std::cout << "GROUP '" << value << "' BEGIN\n";
|
|
|
|
|
for (const TiXmlNode* cur = root->FirstChild(); cur; cur = cur->NextSibling()) {
|
|
|
|
|
const TiXmlElement* elem = cur->ToElement();
|
|
|
|
|
if (elem) {
|
|
|
|
|
std::string tag_name = elem->ValueStr();
|
|
|
|
|
if (tag_name == ID_xmltag__file_params) {
|
|
|
|
|
std::string relative_filename = getProperty(ID_xmlatt__value, elem);
|
|
|
|
|
std::string filename = (boost::filesystem::path(xml_file_path) / relative_filename).string();
|
|
|
|
|
fill_xml(pg, filename);
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
std::string name = getProperty(ID_xmlatt__name, elem);
|
2013-08-08 05:32:01 -05:00
|
|
|
|
std::shared_ptr<ParameterMapItem> data;
|
2011-12-07 07:16:21 -06:00
|
|
|
|
if (tag_name == ID_xmltag__param) {
|
|
|
|
|
std::string value = getProperty(ID_xmlatt__value, elem);
|
|
|
|
|
std::string type = getProperty(ID_xmlatt__type, elem);
|
|
|
|
|
if (type == ID_param_type__file) {
|
|
|
|
|
value = (boost::filesystem::path(xml_file_path) / value).string();
|
|
|
|
|
type = ID_param_type__string;
|
|
|
|
|
}
|
|
|
|
|
data.reset(new Parameter(value, type));
|
|
|
|
|
} else if (tag_name == ID_xmltag__param_grp) {
|
|
|
|
|
std::string child_path = pg.path() + ID_delimiter_path + name;
|
|
|
|
|
data.reset(new ParameterGroup(child_path, &pg));
|
|
|
|
|
fill_tree(dynamic_cast<ParameterGroup&>(*data), elem, xml_file_path);
|
|
|
|
|
} else if (tag_name == ID_xmltag__file_param_grp) {
|
|
|
|
|
std::string child_path = pg.path() + ID_delimiter_path + name;
|
|
|
|
|
data.reset(new ParameterGroup(child_path, &pg));
|
|
|
|
|
std::string relative_filename = getProperty(ID_xmlatt__value, elem);
|
|
|
|
|
std::string filename = (boost::filesystem::path(xml_file_path) / relative_filename).string();
|
|
|
|
|
fill_xml(dynamic_cast<ParameterGroup&>(*data), filename);
|
|
|
|
|
} else {
|
|
|
|
|
std::cerr << "ERROR: '" << tag_name << "' is an unknown xml tag.\n";
|
|
|
|
|
throw std::exception();
|
|
|
|
|
}
|
|
|
|
|
pg.insert(name, data);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
//std::cout << "GROUP '" << id << "' END\n";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
} // namespace parameter
|
2012-01-19 06:50:57 -06:00
|
|
|
|
} // namespace Opm
|
2011-12-07 07:16:21 -06:00
|
|
|
|
|