/*
* 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_INTLITERAL
#define SKSL_INTLITERAL
#include "SkSLContext.h"
#include "SkSLExpression.h"
namespace SkSL {
/**
* A literal integer.
*/
struct IntLiteral : public Expression {
// FIXME: we will need to revisit this if/when we add full support for both signed and unsigned
// 64-bit integers, but for right now an int64_t will hold every value we care about
IntLiteral(const Context& context, int offset, int64_t value)
: INHERITED(offset, kIntLiteral_Kind, *context.fInt_Type)
, fValue(value) {}
IntLiteral(int offset, int64_t value, const Type* type = nullptr)
: INHERITED(offset, kIntLiteral_Kind, *type)
, fValue(value) {}
String description() const override {
return to_string(fValue);
}
bool hasSideEffects() const override {
return false;
}
bool isConstant() const override {
return true;
}
bool compareConstant(const Context& context, const Expression& other) const override {
IntLiteral& i = (IntLiteral&) other;
return fValue == i.fValue;
}
int coercionCost(const Type& target) const override {
if (target.isUnsigned()) {
return 0;
}
return INHERITED::coercionCost(target);
}
int64_t getConstantInt() const override {
return fValue;
}
std::unique_ptr<Expression> clone() const override {
return std::unique_ptr<Expression>(new IntLiteral(fOffset, fValue, &fType));
}
const int64_t fValue;
typedef Expression INHERITED;
};
} // namespace
#endif