throw cxml::Error("Node has no internal xmlpp node; did you forget to call a read method on cxml::Document?");
}
+ auto const glib_name = Glib::ustring(name);
+
vector<shared_ptr<cxml::Node>> n;
for (auto i: _node->get_children()) {
- if (i->get_name() == name) {
+ if (i->get_name() == glib_name) {
n.push_back(make_shared<Node>(i));
}
}
- _taken.push_back (name);
+ _taken.push_back(glib_name);
return n;
}
cxml::Node::done () const
{
for (auto i: _node->get_children()) {
- if (dynamic_cast<xmlpp::Element *> (i) && find (_taken.begin(), _taken.end(), i->get_name()) == _taken.end ()) {
+ if (dynamic_cast<xmlpp::Element*>(i) && find(_taken.begin(), _taken.end(), i->get_name()) == _taken.end()) {
throw cxml::Error ("unexpected XML node " + i->get_name());
}
}
}
_node = _parser->get_document()->get_root_node ();
- if (!_root_name.empty() && _node->get_name() != _root_name) {
+ if (!_root_name.empty() && _node->get_name() != Glib::ustring(_root_name)) {
throw cxml::Error ("unrecognised root node " + _node->get_name() + " (expecting " + _root_name + ")");
} else if (_root_name.empty ()) {
_root_name = _node->get_name ();
xmlpp::Element*
cxml::add_child(xmlpp::Element* parent, string const& name, string const& ns_prefix)
{
+#if LIBXMLXX_MAJOR_VERSION == 2
return parent->add_child(name, ns_prefix);
+#else
+ return parent->add_child_element(name, ns_prefix);
+#endif
}
void
cxml::add_text_child(xmlpp::Element* parent, string const& name, string const& text)
{
- parent->add_child(name)->add_child_text(text);
+ add_child(parent, name)->add_child_text(text);
}
opt.add_option('--enable-debug', action='store_true', default=False, help='build with debugging information and without optimisation')
opt.add_option('--static', action='store_true', default=False, help='build statically')
opt.add_option('--disable-tests', action='store_true', default=False, help='disable building of tests')
+ opt.add_option('--c++17', action='store_true', default=False, help='build with C++17 and libxml++-4.0')
def configure(conf):
conf.load('compiler_cxx')
+
+ if vars(conf.options)['c++17']:
+ cpp_std = '17'
+ conf.env.XMLPP_API = '4.0'
+ conf.env.GLIBMM_API = '2.68'
+ else:
+ cpp_std = '11'
+ conf.env.XMLPP_API = '2.6'
+ conf.env.GLIBMM_API = '2.4'
+
if conf.options.enable_debug:
conf.env.append_value('CXXFLAGS', '-g')
- conf.env.append_value('CXXFLAGS', ['-Wall', '-Wextra', '-O2', '-Wno-deprecated-declarations', '-std=c++11', '-DBOOST_NO_CXX11_SCOPED_ENUMS'])
+ conf.env.append_value('CXXFLAGS', ['-Wall', '-Wextra', '-O2', '-Wno-deprecated-declarations', '-std=c++' + cpp_std, '-DBOOST_NO_CXX11_SCOPED_ENUMS'])
conf.env.TARGET_WINDOWS = conf.options.target_windows_32 or conf.options.target_windows_64
conf.env.STATIC = conf.options.static
boost_lib_suffix = ''
conf.env.append_value('CXXFLAGS', '-DLIBCXML_POSIX')
- conf.check_cfg(package='libxml++-2.6', args='--cflags --libs', uselib_store='LIBXML++', mandatory=True)
+ conf.check_cfg(package='libxml++-' + conf.env.XMLPP_API, args='--cflags --libs', uselib_store='LIBXML++', mandatory=True)
conf.check_cxx(fragment="""
#include <boost/filesystem.hpp>\n
conf.recurse('test')
def build(bld):
-
bld(source='libcxml.pc.in',
version=VERSION,
includedir='%s/include' % bld.env.PREFIX,
libs="-L${libdir} -lcxml",
- install_path='${LIBDIR}/pkgconfig')
+ install_path='${LIBDIR}/pkgconfig',
+ xmlpp_api=bld.env.XMLPP_API,
+ glibmm_api=bld.env.GLIBMM_API)
bld.recurse('src')
if not bld.env.DISABLE_TESTS: