#ifndef ARABICA_XPATHIC_MATCH_HPP #define ARABICA_XPATHIC_MATCH_HPP #include #include "xpath_expression.hpp" #include "xpath_value.hpp" namespace Arabica { namespace XPath { template > struct MatchExpr { MatchExpr(XPathExpression* match, double priority) : match_(match), priority_(priority) { } MatchExpr(const MatchExpr& rhs) : match_(rhs.match_), priority_(rhs.priority_) { } MatchExpr& operator=(const MatchExpr& rhs) { match_ = rhs.match_; priority_ = rhs.priority_; return *this; } XPathExpressionPtr match_; double priority_; }; // MatchExpr namespace impl { template class MatchExpressionWrapper : public XPathExpression { public: MatchExpressionWrapper(XPathExpression* expr, double priority) { add_match(expr, priority); } // MatchExpressionWrapper MatchExpressionWrapper(XPathExpression* expr) { add_matches(expr); } // MatchExpressionWrapper virtual XPathValuePtr evaluate(const DOM::Node& context, const ExecutionContext& executionContext) const { throw std::runtime_error("MatchExpressionWrapper - you should never see this"); } // evaluate const std::vector >& matches() const { return matches_; } // matches void add_match(XPathExpression* match, double priority) { matches_.push_back(MatchExpr(match, priority)); } // add_match void add_matches(XPathExpression* wrapper) { const std::vector >& more = static_cast*>(wrapper)->matches(); for(typename std::vector >::const_iterator m = more.begin(), me = more.end(); m != me; ++m) matches_.push_back(*m); delete wrapper; } // add_matches private: std::vector > matches_; }; // class MatchExpressionWrapper } // namespace impl } // namespace XPath } // namespace Arabica #endif