diff options
author | John Wiegley <johnw@newartisans.com> | 2007-05-08 00:19:48 +0000 |
---|---|---|
committer | John Wiegley <johnw@newartisans.com> | 2008-04-13 03:38:40 -0400 |
commit | ee4a16743960122bf2b626f62827b7332680ebf5 (patch) | |
tree | dab8682d742718a86f0529dd86a0c832ffeb0102 /src/xpath.cc | |
parent | 30978b7fe5ee93413b2e05b54942f6550832b222 (diff) | |
download | fork-ledger-ee4a16743960122bf2b626f62827b7332680ebf5.tar.gz fork-ledger-ee4a16743960122bf2b626f62827b7332680ebf5.tar.bz2 fork-ledger-ee4a16743960122bf2b626f62827b7332680ebf5.zip |
Corrected memory crashes when running the register command.
Diffstat (limited to 'src/xpath.cc')
-rw-r--r-- | src/xpath.cc | 16 |
1 files changed, 6 insertions, 10 deletions
diff --git a/src/xpath.cc b/src/xpath.cc index d4a2fafd..a59126ae 100644 --- a/src/xpath.cc +++ b/src/xpath.cc @@ -1343,7 +1343,7 @@ xpath_t::op_t * xpath_t::op_t::compile(value_t * context, scope_t * scope, // First, look up the symbol as a node name within the current // context. If any exist, then return the set of names. - std::auto_ptr<value_t::sequence_t> nodes(new value_t::sequence_t); + value_t::sequence_t nodes; if (ptr->has_flags(XML_NODE_IS_PARENT)) { parent_node_t * parent = static_cast<parent_node_t *>(ptr); @@ -1353,10 +1353,10 @@ xpath_t::op_t * xpath_t::op_t::compile(value_t * context, scope_t * scope, if ((kind == NODE_NAME && std::strcmp(name->c_str(), node->name()) == 0) || (kind == NODE_ID && name_id == node->name_id)) - nodes->push_back(node); + nodes.push_back(node); } } - return wrap_value(nodes.release())->acquire(); + return wrap_value(nodes)->acquire(); } else { assert(ptr); int id = ptr->document->lookup_name_id(*name); @@ -1745,7 +1745,7 @@ xpath_t::op_t * xpath_t::op_t::compile(value_t * context, scope_t * scope, std::auto_ptr<scope_t> call_args(new scope_t(scope)); call_args->kind = scope_t::ARGUMENT; - std::auto_ptr<value_t::sequence_t> call_seq; + value_t::sequence_t call_seq; op_t * args = right; while (args) { @@ -1757,16 +1757,12 @@ xpath_t::op_t * xpath_t::op_t::compile(value_t * context, scope_t * scope, args = NULL; } - if (! call_seq.get()) - call_seq.reset(new value_t::sequence_t); - // jww (2006-09-15): Need to return a reference to these, if // there are undetermined arguments! - call_seq->push_back(arg->compile(context, scope, resolve)->value()); + call_seq.push_back(arg->compile(context, scope, resolve)->value()); } - if (call_seq.get()) - call_args->args = call_seq.release(); + call_args->args = call_seq; if (left->kind == FUNC_NAME) { if (resolve) { |