bug 104042, more leaked exprResults. r=peterv, sr=jst

This commit is contained in:
axel%pike.org 2001-10-24 09:00:32 +00:00
parent 26da4e9456
commit b80e4721ee
3 changed files with 12 additions and 9 deletions

View File

@ -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:

View File

@ -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(&params);
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) {

View File

@ -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(&params);
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) {