summaryrefslogtreecommitdiff
path: root/src/xpath.cc
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2007-05-08 00:19:48 +0000
committerJohn Wiegley <johnw@newartisans.com>2008-04-13 03:38:40 -0400
commitee4a16743960122bf2b626f62827b7332680ebf5 (patch)
treedab8682d742718a86f0529dd86a0c832ffeb0102 /src/xpath.cc
parent30978b7fe5ee93413b2e05b54942f6550832b222 (diff)
downloadfork-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.cc16
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) {