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
|
|
|
|
{
|
2005-08-22 15:04:27 +00:00
|
|
|
namespace impl
|
|
|
|
{
|
2005-08-04 20:42:30 +00:00
|
|
|
|
2005-08-17 21:26:03 +00:00
|
|
|
template<class string_type, class string_adaptor>
|
2007-12-21 15:56:04 +00:00
|
|
|
class OrOperator : public BinaryExpression<string_type, string_adaptor>
|
2005-08-04 20:42:30 +00:00
|
|
|
{
|
2005-08-17 21:26:03 +00:00
|
|
|
typedef BinaryExpression<string_type, string_adaptor> baseT;
|
2005-08-04 20:42:30 +00:00
|
|
|
public:
|
2007-10-23 21:37:24 +00:00
|
|
|
OrOperator(XPathExpression_impl<string_type, string_adaptor>* lhs,
|
|
|
|
XPathExpression_impl<string_type, string_adaptor>* rhs) :
|
2005-08-17 21:26:03 +00:00
|
|
|
BinaryExpression<string_type, string_adaptor>(lhs, rhs) { }
|
2005-08-04 20:42:30 +00:00
|
|
|
|
2007-12-18 23:03:16 +00:00
|
|
|
virtual ValueType type() const { return BOOL; }
|
|
|
|
|
2007-10-22 17:42:50 +00:00
|
|
|
virtual XPathValue<string_type, string_adaptor> evaluate(const DOM::Node<string_type, string_adaptor>& context,
|
2005-08-17 21:26:03 +00:00
|
|
|
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.
|
2007-10-22 17:42:50 +00:00
|
|
|
if(baseT::lhs()->evaluate(context, executionContext).asBool())
|
2005-08-17 21:26:03 +00:00
|
|
|
return BoolValue<string_type, string_adaptor>::createValue(true);
|
2007-10-22 17:42:50 +00:00
|
|
|
return BoolValue<string_type, string_adaptor>::createValue(baseT::rhs()->evaluate(context, executionContext).asBool());
|
2005-08-04 20:42:30 +00:00
|
|
|
} // evaluate
|
|
|
|
}; // class OrOperator
|
|
|
|
|
2005-08-17 21:26:03 +00:00
|
|
|
template<class string_type, class string_adaptor>
|
2007-12-21 15:56:04 +00:00
|
|
|
class AndOperator : public BinaryExpression<string_type, string_adaptor>
|
2005-08-04 20:42:30 +00:00
|
|
|
{
|
2005-08-17 21:26:03 +00:00
|
|
|
typedef BinaryExpression<string_type, string_adaptor> baseT;
|
2005-08-04 20:42:30 +00:00
|
|
|
public:
|
2007-10-23 21:37:24 +00:00
|
|
|
AndOperator(XPathExpression_impl<string_type, string_adaptor>* lhs,
|
|
|
|
XPathExpression_impl<string_type, string_adaptor>* rhs) :
|
2005-08-17 21:26:03 +00:00
|
|
|
BinaryExpression<string_type, string_adaptor>(lhs, rhs) { }
|
2005-08-04 20:42:30 +00:00
|
|
|
|
2007-12-18 23:03:16 +00:00
|
|
|
virtual ValueType type() const { return BOOL; }
|
|
|
|
|
2007-10-22 17:42:50 +00:00
|
|
|
virtual XPathValue<string_type, string_adaptor> evaluate(const DOM::Node<string_type, string_adaptor>& context,
|
2005-08-17 21:26:03 +00:00
|
|
|
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.
|
2007-10-22 17:42:50 +00:00
|
|
|
if(!baseT::lhs()->evaluate(context, executionContext).asBool())
|
2005-08-17 21:26:03 +00:00
|
|
|
return BoolValue<string_type, string_adaptor>::createValue(false);
|
2007-10-22 17:42:50 +00:00
|
|
|
return BoolValue<string_type, string_adaptor>::createValue(baseT::rhs()->evaluate(context, executionContext).asBool());
|
2005-08-04 20:42:30 +00:00
|
|
|
} // evaluate
|
|
|
|
}; // class AndOperator
|
|
|
|
|
2005-08-22 15:04:27 +00:00
|
|
|
} // namespace impl
|
2005-08-04 20:42:30 +00:00
|
|
|
} // namespace XPath
|
|
|
|
} // namespace Arabica
|
|
|
|
#endif
|