diff options
-rw-r--r-- | src/pugixml.cpp | 16 | ||||
-rw-r--r-- | src/pugixml.hpp | 4 |
2 files changed, 12 insertions, 8 deletions
diff --git a/src/pugixml.cpp b/src/pugixml.cpp index 7063fc3..0b76d1f 100644 --- a/src/pugixml.cpp +++ b/src/pugixml.cpp @@ -9016,9 +9016,6 @@ namespace pugi xpath_query::xpath_query(const char_t* query, xpath_variable_set* variables): _alloc(0), _root(0) { - _result.error = 0; - _result.offset = 0; - xpath_allocator* alloc = xpath_allocator::create(); if (!alloc) @@ -9035,10 +9032,11 @@ namespace pugi _root = xpath_parser::parse(query, variables, alloc, &_result); - #ifdef PUGIXML_NO_EXCEPTIONS - if (_root) // only store allocator if parsing was a success - #endif - _alloc = static_cast<xpath_allocator*>(alloc_holder.release()); + if (_root) + { + _alloc = static_cast<xpath_allocator*>(alloc_holder.release()); + _result.error = 0; + } } } @@ -9127,7 +9125,9 @@ namespace pugi #ifdef PUGIXML_NO_EXCEPTIONS return xpath_node_set(); #else - xpath_parse_result result = {"Expression does not evaluate to node set", 0}; + xpath_parse_result result; + result.error = "Expression does not evaluate to node set"; + throw xpath_exception(result); #endif } diff --git a/src/pugixml.hpp b/src/pugixml.hpp index 89494bf..b6f1710 100644 --- a/src/pugixml.hpp +++ b/src/pugixml.hpp @@ -1775,6 +1775,10 @@ namespace pugi /// Last parsed offset (in characters from string start) ptrdiff_t offset; + xpath_parse_result(): error("Internal error"), offset(0) + { + } + /// Cast to bool operator operator bool() const { |