1/*
2 * Copyright 2016 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
8#ifndef SKSL_FIELDACCESS
9#define SKSL_FIELDACCESS
10
11#include "src/sksl/SkSLUtil.h"
12#include "src/sksl/ir/SkSLExpression.h"
13
14namespace SkSL {
15
16/**
17 * An expression which extracts a field from a struct, as in 'foo.bar'.
18 */
19struct FieldAccess : public Expression {
20 enum OwnerKind {
21 kDefault_OwnerKind,
22 // this field access is to a field of an anonymous interface block (and thus, the field name
23 // is actually in global scope, so only the field name needs to be written in GLSL)
24 kAnonymousInterfaceBlock_OwnerKind
25 };
26
27 FieldAccess(std::unique_ptr<Expression> base, int fieldIndex,
28 OwnerKind ownerKind = kDefault_OwnerKind)
29 : INHERITED(base->fOffset, kFieldAccess_Kind, *base->fType.fields()[fieldIndex].fType)
30 , fBase(std::move(base))
31 , fFieldIndex(fieldIndex)
32 , fOwnerKind(ownerKind) {}
33
34 bool hasProperty(Property property) const override {
35 return fBase->hasProperty(property);
36 }
37
38 std::unique_ptr<Expression> clone() const override {
39 return std::unique_ptr<Expression>(new FieldAccess(fBase->clone(), fFieldIndex,
40 fOwnerKind));
41 }
42
43#ifdef SK_DEBUG
44 String description() const override {
45 return fBase->description() + "." + fBase->fType.fields()[fFieldIndex].fName;
46 }
47#endif
48
49 std::unique_ptr<Expression> fBase;
50 const int fFieldIndex;
51 const OwnerKind fOwnerKind;
52
53 typedef Expression INHERITED;
54};
55
56} // namespace
57
58#endif
59