blob: 13872877c0afadf1054118d8aac9fa12fd6d28c9 [file] [log] [blame]
Ethan Nicholas8f7e28f2018-03-26 14:24:27 -04001/*
2 * Copyright 2018 Google Inc.
3 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
6 */
7
Mike Kleinc0bd9f92019-04-23 12:05:21 -05008#include "src/sksl/ir/SkSLVariableReference.h"
Ethan Nicholas8f7e28f2018-03-26 14:24:27 -04009
Mike Kleinc0bd9f92019-04-23 12:05:21 -050010#include "src/sksl/SkSLIRGenerator.h"
11#include "src/sksl/ir/SkSLConstructor.h"
12#include "src/sksl/ir/SkSLFloatLiteral.h"
13#include "src/sksl/ir/SkSLSetting.h"
Ethan Nicholas8f7e28f2018-03-26 14:24:27 -040014
15namespace SkSL {
16
Brian Osman79457ef2020-09-24 15:01:27 -040017VariableReference::VariableReference(int offset, const Variable* variable, RefKind refKind)
18 : INHERITED(offset, kExpressionKind, &variable->type())
19 , fVariable(variable)
20 , fRefKind(refKind) {
21 SkASSERT(fVariable);
Brian Osman26838062020-09-30 13:03:33 -040022 this->incrementRefs();
23}
24
25VariableReference::~VariableReference() {
26 this->decrementRefs();
27}
28
29void VariableReference::incrementRefs() const {
30 if (fRefKind != kRead_RefKind) {
Brian Osman79457ef2020-09-24 15:01:27 -040031 fVariable->fWriteCount++;
Ethan Nicholas8f7e28f2018-03-26 14:24:27 -040032 }
Brian Osman26838062020-09-30 13:03:33 -040033 if (fRefKind != kWrite_RefKind) {
Brian Osman79457ef2020-09-24 15:01:27 -040034 fVariable->fReadCount++;
Ethan Nicholas8f7e28f2018-03-26 14:24:27 -040035 }
36}
37
Brian Osman26838062020-09-30 13:03:33 -040038void VariableReference::decrementRefs() const {
Ethan Nicholas8f7e28f2018-03-26 14:24:27 -040039 if (fRefKind != kRead_RefKind) {
Brian Osman79457ef2020-09-24 15:01:27 -040040 fVariable->fWriteCount--;
Ethan Nicholas8f7e28f2018-03-26 14:24:27 -040041 }
42 if (fRefKind != kWrite_RefKind) {
Brian Osman79457ef2020-09-24 15:01:27 -040043 fVariable->fReadCount--;
Ethan Nicholas8f7e28f2018-03-26 14:24:27 -040044 }
45}
46
47void VariableReference::setRefKind(RefKind refKind) {
Brian Osman26838062020-09-30 13:03:33 -040048 this->decrementRefs();
Ethan Nicholas8f7e28f2018-03-26 14:24:27 -040049 fRefKind = refKind;
Brian Osman26838062020-09-30 13:03:33 -040050 this->incrementRefs();
Ethan Nicholas8f7e28f2018-03-26 14:24:27 -040051}
52
Brian Osman8e2ef022020-09-30 13:26:43 -040053void VariableReference::setVariable(const Variable* variable) {
54 this->decrementRefs();
55 fVariable = variable;
56 this->incrementRefs();
57}
58
Ethan Nicholas8f7e28f2018-03-26 14:24:27 -040059std::unique_ptr<Expression> VariableReference::constantPropagate(const IRGenerator& irGenerator,
60 const DefinitionMap& definitions) {
61 if (fRefKind != kRead_RefKind) {
62 return nullptr;
63 }
Brian Osman79457ef2020-09-24 15:01:27 -040064 if ((fVariable->fModifiers.fFlags & Modifiers::kConst_Flag) && fVariable->fInitialValue &&
65 fVariable->fInitialValue->isCompileTimeConstant() &&
Ethan Nicholas30d30222020-09-11 12:27:26 -040066 this->type().typeKind() != Type::TypeKind::kArray) {
Brian Osman79457ef2020-09-24 15:01:27 -040067 return fVariable->fInitialValue->clone();
Ethan Nicholas8f7e28f2018-03-26 14:24:27 -040068 }
Brian Osman79457ef2020-09-24 15:01:27 -040069 auto exprIter = definitions.find(fVariable);
Ethan Nicholas8f7e28f2018-03-26 14:24:27 -040070 if (exprIter != definitions.end() && exprIter->second &&
Brian Osmanb6b95732020-06-30 11:44:27 -040071 (*exprIter->second)->isCompileTimeConstant()) {
John Stiles8614e492020-09-21 09:28:48 -040072 return (*exprIter->second)->clone();
Ethan Nicholas8f7e28f2018-03-26 14:24:27 -040073 }
74 return nullptr;
75}
76
John Stilesa6841be2020-08-06 14:11:56 -040077} // namespace SkSL