/* * Copyright 2016 Google Inc. * * Use of this source code is governed by a BSD-style license that can be * found in the LICENSE file. */ #ifndef SKSL_PREFIXEXPRESSION #define SKSL_PREFIXEXPRESSION #include "src/sksl/SkSLCompiler.h" #include "src/sksl/SkSLIRGenerator.h" #include "src/sksl/SkSLLexer.h" #include "src/sksl/ir/SkSLExpression.h" #include "src/sksl/ir/SkSLFloatLiteral.h" namespace SkSL { /** * An expression modified by a unary operator appearing before it, such as '!flag'. */ struct PrefixExpression : public Expression { PrefixExpression(Token::Kind op, std::unique_ptr operand) : INHERITED(operand->fOffset, kPrefix_Kind, operand->fType) , fOperand(std::move(operand)) , fOperator(op) {} bool isConstant() const override { return fOperator == Token::MINUS && fOperand->isConstant(); } bool hasSideEffects() const override { return fOperator == Token::PLUSPLUS || fOperator == Token::MINUSMINUS || fOperand->hasSideEffects(); } std::unique_ptr constantPropagate(const IRGenerator& irGenerator, const DefinitionMap& definitions) override { if (fOperand->fKind == Expression::kFloatLiteral_Kind) { return std::unique_ptr(new FloatLiteral( irGenerator.fContext, fOffset, -((FloatLiteral&) *fOperand).fValue)); } return nullptr; } SKSL_FLOAT getFVecComponent(int index) const override { SkASSERT(fOperator == Token::Kind::MINUS); return -fOperand->getFVecComponent(index); } SKSL_INT getIVecComponent(int index) const override { SkASSERT(fOperator == Token::Kind::MINUS); return -fOperand->getIVecComponent(index); } SKSL_FLOAT getMatComponent(int col, int row) const override { SkASSERT(fOperator == Token::Kind::MINUS); return -fOperand->getMatComponent(col, row); } std::unique_ptr clone() const override { return std::unique_ptr(new PrefixExpression(fOperator, fOperand->clone())); } String description() const override { return Compiler::OperatorName(fOperator) + fOperand->description(); } std::unique_ptr fOperand; const Token::Kind fOperator; typedef Expression INHERITED; }; } // namespace #endif