arabica/include/XPath/impl/xpath_logical.hpp

67 lines
2.9 KiB
C++
Raw Normal View History

2005-08-04 20:42:30 +00:00
#ifndef ARABICA_XPATHIC_XPATH_LOGICAL_HPP
#define ARABICA_XPATHIC_XPATH_LOGICAL_HPP
#include "xpath_value.hpp"
namespace Arabica
{
namespace XPath
{
namespace impl
{
2005-08-04 20:42:30 +00:00
template<class string_type, class string_adaptor>
class OrOperator : public BinaryExpression<string_type, string_adaptor>
2005-08-04 20:42:30 +00:00
{
typedef BinaryExpression<string_type, string_adaptor> baseT;
2005-08-04 20:42:30 +00:00
public:
OrOperator(XPathExpression_impl<string_type, string_adaptor>* lhs,
XPathExpression_impl<string_type, string_adaptor>* rhs) :
BinaryExpression<string_type, string_adaptor>(lhs, rhs) { }
2005-08-04 20:42:30 +00:00
virtual ValueType type() const { return BOOL; }
virtual XPathValue<string_type, string_adaptor> evaluate(const DOM::Node<string_type, string_adaptor>& context,
const ExecutionContext<string_type, string_adaptor>& executionContext) const
2005-08-04 20:42:30 +00:00
{
// From XPath 1.0 Rec, section 3.4
// An or expression is evaluated by evaluating each operand and converting its value
// to a boolean as if by a call to the boolean function. The result is true if either
// value is true and false otherwise. The right operand is not evaluated if the
// left operand evaluates to true.
if(baseT::lhs()->evaluate(context, executionContext).asBool())
return BoolValue<string_type, string_adaptor>::createValue(true);
return BoolValue<string_type, string_adaptor>::createValue(baseT::rhs()->evaluate(context, executionContext).asBool());
2005-08-04 20:42:30 +00:00
} // evaluate
}; // class OrOperator
template<class string_type, class string_adaptor>
class AndOperator : public BinaryExpression<string_type, string_adaptor>
2005-08-04 20:42:30 +00:00
{
typedef BinaryExpression<string_type, string_adaptor> baseT;
2005-08-04 20:42:30 +00:00
public:
AndOperator(XPathExpression_impl<string_type, string_adaptor>* lhs,
XPathExpression_impl<string_type, string_adaptor>* rhs) :
BinaryExpression<string_type, string_adaptor>(lhs, rhs) { }
2005-08-04 20:42:30 +00:00
virtual ValueType type() const { return BOOL; }
virtual XPathValue<string_type, string_adaptor> evaluate(const DOM::Node<string_type, string_adaptor>& context,
const ExecutionContext<string_type, string_adaptor>& executionContext) const
2005-08-04 20:42:30 +00:00
{
// From XPath 1.0 Rec, section 3.4
// An and expression is evaluated by evaluating each operand and converting its value
// to a boolean as if by a call to the boolean function. The result is true if both
// values are true and false otherwise. The right operand is not evaluated if the left
// operand evaluates to false.
if(!baseT::lhs()->evaluate(context, executionContext).asBool())
return BoolValue<string_type, string_adaptor>::createValue(false);
return BoolValue<string_type, string_adaptor>::createValue(baseT::rhs()->evaluate(context, executionContext).asBool());
2005-08-04 20:42:30 +00:00
} // evaluate
}; // class AndOperator
} // namespace impl
2005-08-04 20:42:30 +00:00
} // namespace XPath
} // namespace Arabica
#endif