mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-01-09 05:14:24 +00:00
bug 104042, more leaked exprResults. r=peterv, sr=jst
This commit is contained in:
parent
26da4e9456
commit
b80e4721ee
@ -1228,10 +1228,11 @@ void XSLTProcessor::processAction
|
||||
{
|
||||
expr = ps->getExpr(xslTemplate->getAttribute(TEST_ATTR));
|
||||
ExprResult* result = expr->evaluate(node, ps);
|
||||
if ( result->booleanValue() ) {
|
||||
if (result && result->booleanValue()) {
|
||||
processChildren(node, xslTemplate, ps);
|
||||
caseFound = MB_TRUE;
|
||||
}
|
||||
delete result;
|
||||
break;
|
||||
}
|
||||
case XSLType::OTHERWISE:
|
||||
|
@ -65,11 +65,11 @@ ExprResult* ElementAvailableFunctionCall::evaluate(Node* context, ContextState*
|
||||
ExprResult* result = NULL;
|
||||
|
||||
if ( requireParams(1,1,cs) ) {
|
||||
ListIterator* iter = params.iterator();
|
||||
Expr* param = (Expr*) iter->next();
|
||||
delete iter;
|
||||
ListIterator iter(¶ms);
|
||||
Expr* param = (Expr*) iter.next();
|
||||
ExprResult* exprResult = param->evaluate(context, cs);
|
||||
if (exprResult->getResultType() == ExprResult::STRING) {
|
||||
if (exprResult &&
|
||||
exprResult->getResultType() == ExprResult::STRING) {
|
||||
String property;
|
||||
exprResult->stringValue(property);
|
||||
if (XMLUtils::isValidQName(property)) {
|
||||
@ -122,6 +122,7 @@ ExprResult* ElementAvailableFunctionCall::evaluate(Node* context, ContextState*
|
||||
delete result;
|
||||
result = new StringResult(err);
|
||||
}
|
||||
delete exprResult;
|
||||
}
|
||||
|
||||
if (!result) {
|
||||
|
@ -66,11 +66,11 @@ ExprResult* FunctionAvailableFunctionCall::evaluate(Node* context, ContextState*
|
||||
ExprResult* result = NULL;
|
||||
|
||||
if ( requireParams(1,1,cs) ) {
|
||||
ListIterator* iter = params.iterator();
|
||||
Expr* param = (Expr*) iter->next();
|
||||
delete iter;
|
||||
ListIterator iter(¶ms);
|
||||
Expr* param = (Expr*)iter.next();
|
||||
ExprResult* exprResult = param->evaluate(context, cs);
|
||||
if (exprResult->getResultType() == ExprResult::STRING) {
|
||||
if (exprResult &&
|
||||
exprResult->getResultType() == ExprResult::STRING) {
|
||||
String property;
|
||||
exprResult->stringValue(property);
|
||||
if (XMLUtils::isValidQName(property)) {
|
||||
@ -122,6 +122,7 @@ ExprResult* FunctionAvailableFunctionCall::evaluate(Node* context, ContextState*
|
||||
delete result;
|
||||
result = new StringResult(err);
|
||||
}
|
||||
delete exprResult;
|
||||
}
|
||||
|
||||
if (!result) {
|
||||
|
Loading…
Reference in New Issue
Block a user