/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * This file incorporates work covered by the following license notice: * * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed * with this work for additional information regarding copyright * ownership. The ASF licenses this file to you under the Apache * License, Version 2.0 (the "License"); you may not use this file * except in compliance with the License. You may obtain a copy of * the License at http://www.apache.org/licenses/LICENSE-2.0 .
*/
usingnamespace com::sun::star::uno; using com::sun::star::xml::xpath::XPathAPI; using com::sun::star::xml::xpath::XXPathAPI; using com::sun::star::xml::xpath::XPathExtension; using com::sun::star::xml::xpath::XXPathExtension; using com::sun::star::xml::xpath::XPathObjectType_XPATH_UNDEFINED;
// our expression is static only if 1) we found our regexp, and 2) // the regexp goes from beginning to end. return ( nLength == 0 || bSearch )
&& ( nStart == 0 && nEnd == nLength );
}
bool ComputedExpression::isSimpleExpression() const
{ // actual work is done by setExpression return mbIsEmpty || mbIsSimple;
}
bool ComputedExpression::_evaluate( const xforms::EvaluationContext& rContext, const OUString& sExpression )
{
OSL_ENSURE( rContext.mxContextNode.is(), "no context node in context" );
// obtain value by evaluating XPath expression
mxResult.clear(); try
{
mxResult = _getXPathAPI(rContext)->eval( rContext.mxContextNode,
sExpression );
} catch( const Exception& )
{
; // ignore exception -> mxResult will be empty
}
return hasValue();
}
bool ComputedExpression::evaluate( const EvaluationContext& rContext )
{ // for simple expression we don't need to re-evaluate (if we have // an older result); neither for empty expressions if( mbIsEmpty || (mxResult.is() && mbIsSimple) ) returntrue;
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung ist noch experimentell.