summaryrefslogtreecommitdiffstats
path: root/gfx/skia/skia/src/sksl/ir/SkSLLiteral.h
diff options
context:
space:
mode:
Diffstat (limited to 'gfx/skia/skia/src/sksl/ir/SkSLLiteral.h')
-rw-r--r--gfx/skia/skia/src/sksl/ir/SkSLLiteral.h145
1 files changed, 145 insertions, 0 deletions
diff --git a/gfx/skia/skia/src/sksl/ir/SkSLLiteral.h b/gfx/skia/skia/src/sksl/ir/SkSLLiteral.h
new file mode 100644
index 0000000000..d4b0bd1be6
--- /dev/null
+++ b/gfx/skia/skia/src/sksl/ir/SkSLLiteral.h
@@ -0,0 +1,145 @@
+/*
+ * 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_FLOATLITERAL
+#define SKSL_FLOATLITERAL
+
+#include "include/core/SkTypes.h"
+#include "include/private/SkSLDefines.h"
+#include "include/private/SkSLIRNode.h"
+#include "include/sksl/SkSLPosition.h"
+#include "src/sksl/SkSLBuiltinTypes.h"
+#include "src/sksl/SkSLContext.h"
+#include "src/sksl/ir/SkSLExpression.h"
+#include "src/sksl/ir/SkSLType.h"
+
+#include <cstdint>
+#include <cinttypes>
+#include <memory>
+#include <optional>
+#include <string>
+
+namespace SkSL {
+
+enum class OperatorPrecedence : uint8_t;
+
+/**
+ * A literal value. These can contain ints, floats, or booleans.
+ */
+
+class Literal : public Expression {
+public:
+ inline static constexpr Kind kIRNodeKind = Kind::kLiteral;
+
+ Literal(Position pos, double value, const Type* type)
+ : INHERITED(pos, kIRNodeKind, type)
+ , fValue(value) {}
+
+ // Makes a literal of $floatLiteral type.
+ static std::unique_ptr<Literal> MakeFloat(const Context& context, Position pos,
+ float value) {
+ return std::make_unique<Literal>(pos, value, context.fTypes.fFloatLiteral.get());
+ }
+
+ // Makes a float literal of the specified type.
+ static std::unique_ptr<Literal> MakeFloat(Position pos, float value, const Type* type) {
+ SkASSERT(type->isFloat());
+ return std::make_unique<Literal>(pos, value, type);
+ }
+
+ // Makes a literal of $intLiteral type.
+ static std::unique_ptr<Literal> MakeInt(const Context& context, Position pos,
+ SKSL_INT value) {
+ return std::make_unique<Literal>(pos, value, context.fTypes.fIntLiteral.get());
+ }
+
+ // Makes an int literal of the specified type.
+ static std::unique_ptr<Literal> MakeInt(Position pos, SKSL_INT value, const Type* type) {
+ SkASSERT(type->isInteger());
+ SkASSERTF(value >= type->minimumValue(), "Value %" PRId64 " does not fit in type %s",
+ value, type->description().c_str());
+ SkASSERTF(value <= type->maximumValue(), "Value %" PRId64 " does not fit in type %s",
+ value, type->description().c_str());
+ return std::make_unique<Literal>(pos, value, type);
+ }
+
+ // Makes a literal of boolean type.
+ static std::unique_ptr<Literal> MakeBool(const Context& context, Position pos, bool value) {
+ return std::make_unique<Literal>(pos, value, context.fTypes.fBool.get());
+ }
+
+ // Makes a literal of boolean type. (Functionally identical to the above, but useful if you
+ // don't have access to the Context.)
+ static std::unique_ptr<Literal> MakeBool(Position pos, bool value, const Type* type) {
+ SkASSERT(type->isBoolean());
+ return std::make_unique<Literal>(pos, value, type);
+ }
+
+ // Makes a literal of the specified type, rounding as needed.
+ static std::unique_ptr<Literal> Make(Position pos, double value, const Type* type) {
+ if (type->isFloat()) {
+ return MakeFloat(pos, value, type);
+ }
+ if (type->isInteger()) {
+ return MakeInt(pos, value, type);
+ }
+ SkASSERT(type->isBoolean());
+ return MakeBool(pos, value, type);
+ }
+
+ float floatValue() const {
+ SkASSERT(this->type().isFloat());
+ return (SKSL_FLOAT)fValue;
+ }
+
+ SKSL_INT intValue() const {
+ SkASSERT(this->type().isInteger());
+ return (SKSL_INT)fValue;
+ }
+
+ SKSL_INT boolValue() const {
+ SkASSERT(this->type().isBoolean());
+ return (bool)fValue;
+ }
+
+ double value() const {
+ return fValue;
+ }
+
+ std::string description(OperatorPrecedence) const override;
+
+ ComparisonResult compareConstant(const Expression& other) const override {
+ if (!other.is<Literal>() || this->type().numberKind() != other.type().numberKind()) {
+ return ComparisonResult::kUnknown;
+ }
+ return this->value() == other.as<Literal>().value()
+ ? ComparisonResult::kEqual
+ : ComparisonResult::kNotEqual;
+ }
+
+ std::unique_ptr<Expression> clone(Position pos) const override {
+ return std::make_unique<Literal>(pos, this->value(), &this->type());
+ }
+
+ bool supportsConstantValues() const override {
+ return true;
+ }
+
+ std::optional<double> getConstantValue(int n) const override {
+ SkASSERT(n == 0);
+ return fValue;
+ }
+
+private:
+ double fValue;
+
+ using INHERITED = Expression;
+};
+
+} // namespace SkSL
+
+#endif