X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Fglsl%2Foutput.h;h=dbdd888e5923aa69355c9fe75923bcadf7e12c61;hp=5b03420223c3f70fb57f7f900f6708e2da5efe39;hb=6f06479b765946bdd3174b2c05e7a1dda24c31c2;hpb=0ca367ce305ae6f2025739b3b199a7f75d4132db diff --git a/source/glsl/output.h b/source/glsl/output.h index 5b034202..dbdd888e 100644 --- a/source/glsl/output.h +++ b/source/glsl/output.h @@ -1,6 +1,7 @@ #ifndef MSP_GL_SL_OUTPUT_H_ #define MSP_GL_SL_OUTPUT_H_ +#include "compiler.h" #include "syntax.h" #include "visitor.h" @@ -8,21 +9,21 @@ namespace Msp { namespace GL { namespace SL { +/** Formats the syntax tree as GLSL. */ class Formatter: private TraversingVisitor { private: - Stage *stage; + Stage *stage = 0; std::string formatted; - unsigned source_index; - unsigned source_line; - unsigned indent; - bool parameter_list; - std::string block_interface; + unsigned source_index = 0; + unsigned source_line = 1; + unsigned indent = 0; + bool parameter_list = false; + bool omit_builtin = false; + bool r_empty_name = false; public: - Formatter(); - - const std::string &apply(Stage &); + std::string apply(Stage &); private: void append(const std::string &); @@ -30,13 +31,16 @@ private: void set_source(unsigned, unsigned); virtual void visit(Block &); + void visit_expression(Expression &, const Operator *, bool); virtual void visit(Literal &); - virtual void visit(ParenthesizedExpression &); virtual void visit(VariableReference &); + virtual void visit(InterfaceBlockReference &); virtual void visit(MemberAccess &); + virtual void visit(Swizzle &); virtual void visit(UnaryExpression &); virtual void visit(BinaryExpression &); virtual void visit(Assignment &); + virtual void visit(TernaryExpression &); virtual void visit(FunctionCall &); virtual void visit(ExpressionStatement &); virtual void visit(Import &); @@ -49,9 +53,9 @@ private: virtual void visit(FunctionDeclaration &); virtual void visit(Conditional &); virtual void visit(Iteration &); + virtual void visit(Passthrough &); virtual void visit(Return &); virtual void visit(Jump &); - using TraversingVisitor::visit; }; } // namespace SL