blob: 5b56689517323afd17e039b79d3a52c7222c77a1 [file] [log] [blame]
ethannicholasb3058bd2016-07-01 08:22:01 -07001/*
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_IRGENERATOR
9#define SKSL_IRGENERATOR
10
11#include "SkSLErrorReporter.h"
12#include "ast/SkSLASTBinaryExpression.h"
13#include "ast/SkSLASTBlock.h"
14#include "ast/SkSLASTBreakStatement.h"
15#include "ast/SkSLASTCallSuffix.h"
16#include "ast/SkSLASTContinueStatement.h"
17#include "ast/SkSLASTDiscardStatement.h"
18#include "ast/SkSLASTDoStatement.h"
19#include "ast/SkSLASTExpression.h"
20#include "ast/SkSLASTExpressionStatement.h"
21#include "ast/SkSLASTExtension.h"
22#include "ast/SkSLASTForStatement.h"
23#include "ast/SkSLASTFunction.h"
24#include "ast/SkSLASTIdentifier.h"
25#include "ast/SkSLASTIfStatement.h"
26#include "ast/SkSLASTInterfaceBlock.h"
27#include "ast/SkSLASTModifiers.h"
ethannicholas5961bc92016-10-12 06:39:56 -070028#include "ast/SkSLASTModifiersDeclaration.h"
ethannicholasb3058bd2016-07-01 08:22:01 -070029#include "ast/SkSLASTPrefixExpression.h"
30#include "ast/SkSLASTReturnStatement.h"
31#include "ast/SkSLASTStatement.h"
32#include "ast/SkSLASTSuffixExpression.h"
33#include "ast/SkSLASTTernaryExpression.h"
34#include "ast/SkSLASTVarDeclaration.h"
35#include "ast/SkSLASTVarDeclarationStatement.h"
36#include "ast/SkSLASTWhileStatement.h"
37#include "ir/SkSLBlock.h"
38#include "ir/SkSLExpression.h"
39#include "ir/SkSLExtension.h"
40#include "ir/SkSLFunctionDefinition.h"
41#include "ir/SkSLInterfaceBlock.h"
42#include "ir/SkSLModifiers.h"
ethannicholas5961bc92016-10-12 06:39:56 -070043#include "ir/SkSLModifiersDeclaration.h"
ethannicholasb3058bd2016-07-01 08:22:01 -070044#include "ir/SkSLSymbolTable.h"
45#include "ir/SkSLStatement.h"
46#include "ir/SkSLType.h"
47#include "ir/SkSLTypeReference.h"
ethannicholas22f939e2016-10-13 13:25:34 -070048#include "ir/SkSLVarDeclarations.h"
ethannicholasb3058bd2016-07-01 08:22:01 -070049
50namespace SkSL {
51
Ethan Nicholas3605ace2016-11-21 15:59:48 -050052struct CapValue {
53 CapValue()
54 : fKind(kInt_Kind)
55 , fValue(-1) {
56 ASSERT(false);
57 }
58
59 CapValue(bool b)
60 : fKind(kBool_Kind)
61 , fValue(b) {}
62
63 CapValue(int i)
64 : fKind(kInt_Kind)
65 , fValue(i) {}
66
67 enum {
68 kBool_Kind,
69 kInt_Kind,
70 } fKind;
71 int fValue;
72};
73
ethannicholasb3058bd2016-07-01 08:22:01 -070074/**
75 * Performs semantic analysis on an abstract syntax tree (AST) and produces the corresponding
76 * (unoptimized) intermediate representation (IR).
77 */
78class IRGenerator {
79public:
ethannicholasd598f792016-07-25 10:08:54 -070080 IRGenerator(const Context* context, std::shared_ptr<SymbolTable> root,
81 ErrorReporter& errorReporter);
ethannicholasb3058bd2016-07-01 08:22:01 -070082
ethannicholas14fe8cc2016-09-07 13:37:16 -070083 std::unique_ptr<VarDeclarations> convertVarDeclarations(const ASTVarDeclarations& decl,
84 Variable::Storage storage);
ethannicholasb3058bd2016-07-01 08:22:01 -070085 std::unique_ptr<FunctionDefinition> convertFunction(const ASTFunction& f);
86 std::unique_ptr<Statement> convertStatement(const ASTStatement& statement);
87 std::unique_ptr<Expression> convertExpression(const ASTExpression& expression);
ethannicholas5961bc92016-10-12 06:39:56 -070088 std::unique_ptr<ModifiersDeclaration> convertModifiersDeclaration(
89 const ASTModifiersDeclaration& m);
ethannicholasb3058bd2016-07-01 08:22:01 -070090
91private:
Ethan Nicholas3605ace2016-11-21 15:59:48 -050092 /**
93 * Prepare to compile a program. Pushes a new symbol table and installs the caps so that
94 * references to sk_Caps.<cap> can be resolved.
95 */
96 void start(std::unordered_map<SkString, CapValue>* caps);
97
98 /**
99 * Performs cleanup after compilation is complete.
100 */
101 void finish();
102
ethannicholasb3058bd2016-07-01 08:22:01 -0700103 void pushSymbolTable();
104 void popSymbolTable();
105
ethannicholasd598f792016-07-25 10:08:54 -0700106 const Type* convertType(const ASTType& type);
ethannicholasb3058bd2016-07-01 08:22:01 -0700107 std::unique_ptr<Expression> call(Position position,
ethannicholasd598f792016-07-25 10:08:54 -0700108 const FunctionDeclaration& function,
ethannicholasb3058bd2016-07-01 08:22:01 -0700109 std::vector<std::unique_ptr<Expression>> arguments);
ethannicholasd598f792016-07-25 10:08:54 -0700110 bool determineCallCost(const FunctionDeclaration& function,
ethannicholasb3058bd2016-07-01 08:22:01 -0700111 const std::vector<std::unique_ptr<Expression>>& arguments,
112 int* outCost);
113 std::unique_ptr<Expression> call(Position position, std::unique_ptr<Expression> function,
114 std::vector<std::unique_ptr<Expression>> arguments);
ethannicholasd598f792016-07-25 10:08:54 -0700115 std::unique_ptr<Expression> coerce(std::unique_ptr<Expression> expr, const Type& type);
ethannicholasb3058bd2016-07-01 08:22:01 -0700116 std::unique_ptr<Block> convertBlock(const ASTBlock& block);
117 std::unique_ptr<Statement> convertBreak(const ASTBreakStatement& b);
118 std::unique_ptr<Expression> convertConstructor(Position position,
ethannicholasd598f792016-07-25 10:08:54 -0700119 const Type& type,
ethannicholasb3058bd2016-07-01 08:22:01 -0700120 std::vector<std::unique_ptr<Expression>> params);
121 std::unique_ptr<Statement> convertContinue(const ASTContinueStatement& c);
122 std::unique_ptr<Statement> convertDiscard(const ASTDiscardStatement& d);
123 std::unique_ptr<Statement> convertDo(const ASTDoStatement& d);
124 std::unique_ptr<Expression> convertBinaryExpression(const ASTBinaryExpression& expression);
ethannicholas08a92112016-11-09 13:26:45 -0800125 // Returns null if it cannot fold the expression. Note that unlike most other functions here, a
126 // null return does not represent a compilation error.
127 std::unique_ptr<Expression> constantFold(const Expression& left,
128 Token::Kind op,
129 const Expression& right);
ethannicholasb3058bd2016-07-01 08:22:01 -0700130 std::unique_ptr<Extension> convertExtension(const ASTExtension& e);
131 std::unique_ptr<Statement> convertExpressionStatement(const ASTExpressionStatement& s);
132 std::unique_ptr<Statement> convertFor(const ASTForStatement& f);
133 std::unique_ptr<Expression> convertIdentifier(const ASTIdentifier& identifier);
134 std::unique_ptr<Statement> convertIf(const ASTIfStatement& s);
135 std::unique_ptr<Expression> convertIndex(std::unique_ptr<Expression> base,
136 const ASTExpression& index);
137 std::unique_ptr<InterfaceBlock> convertInterfaceBlock(const ASTInterfaceBlock& s);
138 Modifiers convertModifiers(const ASTModifiers& m);
139 std::unique_ptr<Expression> convertPrefixExpression(const ASTPrefixExpression& expression);
140 std::unique_ptr<Statement> convertReturn(const ASTReturnStatement& r);
Ethan Nicholas3605ace2016-11-21 15:59:48 -0500141 std::unique_ptr<Expression> getCap(Position position, SkString name);
ethannicholasb3058bd2016-07-01 08:22:01 -0700142 std::unique_ptr<Expression> convertSuffixExpression(const ASTSuffixExpression& expression);
143 std::unique_ptr<Expression> convertField(std::unique_ptr<Expression> base,
Ethan Nicholas9e1138d2016-11-21 10:39:35 -0500144 const SkString& field);
ethannicholasb3058bd2016-07-01 08:22:01 -0700145 std::unique_ptr<Expression> convertSwizzle(std::unique_ptr<Expression> base,
Ethan Nicholas9e1138d2016-11-21 10:39:35 -0500146 const SkString& fields);
ethannicholasb3058bd2016-07-01 08:22:01 -0700147 std::unique_ptr<Expression> convertTernaryExpression(const ASTTernaryExpression& expression);
148 std::unique_ptr<Statement> convertVarDeclarationStatement(const ASTVarDeclarationStatement& s);
149 std::unique_ptr<Statement> convertWhile(const ASTWhileStatement& w);
150
151 void checkValid(const Expression& expr);
ethannicholasd598f792016-07-25 10:08:54 -0700152 void markReadFrom(const Variable& var);
ethannicholasb3058bd2016-07-01 08:22:01 -0700153 void markWrittenTo(const Expression& expr);
154
ethannicholasd598f792016-07-25 10:08:54 -0700155 const Context& fContext;
156 const FunctionDeclaration* fCurrentFunction;
Ethan Nicholas3605ace2016-11-21 15:59:48 -0500157 const std::unordered_map<SkString, CapValue>* fCapsMap;
ethannicholasb3058bd2016-07-01 08:22:01 -0700158 std::shared_ptr<SymbolTable> fSymbolTable;
ethannicholas22f939e2016-10-13 13:25:34 -0700159 int fLoopLevel;
ethannicholasb3058bd2016-07-01 08:22:01 -0700160 ErrorReporter& fErrors;
161
162 friend class AutoSymbolTable;
ethannicholas22f939e2016-10-13 13:25:34 -0700163 friend class AutoLoopLevel;
ethannicholasb3058bd2016-07-01 08:22:01 -0700164 friend class Compiler;
165};
166
167}
168
169#endif