/* * Copyright 2005 Frerich Raabe * Copyright (C) 2006, 2013 Apple Inc. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #pragma once #include "XPathExpressionNode.h" namespace WebCore { namespace XPath { class Number final : public Expression { public: explicit Number(double); private: Value evaluate() const override; Value::Type resultType() const override { return Value::NumberValue; } Value m_value; }; class StringExpression final : public Expression { public: explicit StringExpression(String&&); private: Value evaluate() const override; Value::Type resultType() const override { return Value::StringValue; } Value m_value; }; class Negative final : public Expression { public: explicit Negative(std::unique_ptr); private: Value evaluate() const override; Value::Type resultType() const override { return Value::NumberValue; } }; class NumericOp final : public Expression { public: enum Opcode { OP_Add, OP_Sub, OP_Mul, OP_Div, OP_Mod }; NumericOp(Opcode, std::unique_ptr lhs, std::unique_ptr rhs); private: Value evaluate() const override; Value::Type resultType() const override { return Value::NumberValue; } Opcode m_opcode; }; class EqTestOp final : public Expression { public: enum Opcode { OP_EQ, OP_NE, OP_GT, OP_LT, OP_GE, OP_LE }; EqTestOp(Opcode, std::unique_ptr lhs, std::unique_ptr rhs); Value evaluate() const override; private: Value::Type resultType() const override { return Value::BooleanValue; } bool compare(const Value&, const Value&) const; Opcode m_opcode; }; class LogicalOp final : public Expression { public: enum Opcode { OP_And, OP_Or }; LogicalOp(Opcode, std::unique_ptr lhs, std::unique_ptr rhs); private: Value::Type resultType() const override { return Value::BooleanValue; } bool shortCircuitOn() const; Value evaluate() const override; Opcode m_opcode; }; class Union final : public Expression { public: Union(std::unique_ptr, std::unique_ptr); private: Value evaluate() const override; Value::Type resultType() const override { return Value::NodeSetValue; } }; bool evaluatePredicate(const Expression&); bool predicateIsContextPositionSensitive(const Expression&); } // namespace XPath } // namespace WebCore