namespace GL {
namespace SL {
+/** Combines multiple declarations of the same identifier into one. */
class DeclarationCombiner: private TraversingVisitor
{
private:
private:
virtual void visit(Block &);
- virtual void visit(FunctionDeclaration &);
virtual void visit(VariableDeclaration &);
+ virtual void visit(FunctionDeclaration &) { }
};
+/** Manipulates specialization constants. If values are specified, turns
+specialization constants into normal constants. Without values assigns
+automatic constant_ids to specialization constants. */
class ConstantSpecializer: private TraversingVisitor
{
private:
virtual void visit(VariableDeclaration &);
};
-class BlockResolver: private TraversingVisitor
+/** Forms links between nested blocks in the syntax tree. */
+class BlockHierarchyResolver: private TraversingVisitor
{
public:
void apply(Stage &s) { s.content.visit(*this); }
virtual void enter(Block &);
};
+/** Resolves variable references. Variable references which match the name
+of an interface block are turned into interface block references. */
class VariableResolver: private TraversingVisitor
{
private:
Stage *stage;
- Block *builtins;
- std::map<std::string, VariableDeclaration *> *members;
- RefPtr<InterfaceBlockReference> iface_ref;
+ std::map<std::string, VariableDeclaration *> *r_members;
+ RefPtr<InterfaceBlockReference> r_iface_ref;
std::string block_interface;
bool record_target;
- VariableDeclaration *assignment_target;
- bool self_referencing;
+ VariableDeclaration *r_assignment_target;
+ bool r_self_referencing;
public:
VariableResolver();
void apply(Stage &);
private:
- Block *next_block(Block &);
-
virtual void enter(Block &);
virtual void visit(VariableReference &);
virtual void visit(InterfaceBlockReference &);
virtual void visit(InterfaceBlock &);
};
+/** Resolves function declarations and calls. */
class FunctionResolver: private TraversingVisitor
{
private:
- std::map<std::string, std::vector<FunctionDeclaration *> > functions;
+ Stage *stage;
+ std::map<std::string, std::vector<FunctionDeclaration *> > declarations;
public:
- void apply(Stage &s) { s.content.visit(*this); }
+ void apply(Stage &);
private:
virtual void visit(FunctionCall &);
virtual void visit(FunctionDeclaration &);
};
+/** Materializes implicitly declared interfaces.
+
+Out variable declarations inside functions are moved to the global scope.
+
+Passthrough statements are processed, generating out variables to match in
+variables and copying values.
+
+Unresolved variables are looked up in the previous stage's out variables. */
class InterfaceGenerator: private TraversingVisitor
{
private:
virtual void visit(Passthrough &);
};
-class DeclarationReorderer: private TraversingVisitor
-{
-private:
- enum DeclarationKind
- {
- NO_DECLARATION,
- LAYOUT,
- STRUCT,
- VARIABLE,
- FUNCTION
- };
-
- DeclarationKind kind;
- std::set<Node *> ordered_funcs;
- std::set<Node *> needed_funcs;
-
-public:
- DeclarationReorderer();
-
- void apply(Stage &s) { s.content.visit(*this); }
-
-private:
- virtual void visit(Block &);
- virtual void visit(FunctionCall &);
- virtual void visit(InterfaceLayout &) { kind = LAYOUT; }
- virtual void visit(StructDeclaration &) { kind = STRUCT; }
- virtual void visit(VariableDeclaration &);
- virtual void visit(InterfaceBlock &) { kind = VARIABLE; }
- virtual void visit(FunctionDeclaration &);
-};
-
} // namespace SL
} // namespace GL
} // namespace Msp