/* * Copyright 2021 Google LLC * * Use of this source code is governed by a BSD-style license that can be * found in the LICENSE file. */ #ifndef SKSL_CONSTRUCTOR_SCALAR_CAST #define SKSL_CONSTRUCTOR_SCALAR_CAST #include "src/sksl/SkSLPosition.h" #include "src/sksl/ir/SkSLConstructor.h" #include "src/sksl/ir/SkSLExpression.h" #include "src/sksl/ir/SkSLIRNode.h" #include #include namespace SkSL { class Context; class ExpressionArray; class Type; /** * Represents the construction of a scalar cast, such as `float(intVariable)`. * * These always contain exactly 1 scalar of a differing type, and are never constant. */ class ConstructorScalarCast final : public SingleArgumentConstructor { public: inline static constexpr Kind kIRNodeKind = Kind::kConstructorScalarCast; ConstructorScalarCast(Position pos, const Type& type, std::unique_ptr arg) : INHERITED(pos, kIRNodeKind, &type, std::move(arg)) {} // ConstructorScalarCast::Convert will typecheck and create scalar-constructor expressions. // Reports errors via the ErrorReporter; returns null on error. static std::unique_ptr Convert(const Context& context, Position pos, const Type& rawType, ExpressionArray args); // ConstructorScalarCast::Make casts a scalar expression. Casts that can be evaluated at // compile-time will do so (e.g. `int(4.1)` --> `Literal(int 4)`). Errors reported via SkASSERT. static std::unique_ptr Make(const Context& context, Position pos, const Type& type, std::unique_ptr arg); std::unique_ptr clone(Position pos) const override { return std::make_unique(pos, this->type(), argument()->clone()); } private: using INHERITED = SingleArgumentConstructor; }; } // namespace SkSL #endif