X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fglsl%2Fvalidate.h;h=f562043576e0b8db285b3a9d2a821c78977979c3;hb=abcd1fa06f9fab27c5934b4069523dd009862b18;hp=a09f9f643002b11ecae0bfba1237d07d76121cd9;hpb=efbce87192ce73ba577684369f759693dccec67c;p=libs%2Fgl.git diff --git a/source/glsl/validate.h b/source/glsl/validate.h index a09f9f64..f5620435 100644 --- a/source/glsl/validate.h +++ b/source/glsl/validate.h @@ -42,8 +42,11 @@ private: Features features; ScopeType scope = GLOBAL; InterfaceLayout *iface_layout = 0; - InterfaceBlock *iface_block = 0; + VariableDeclaration *iface_block = 0; VariableDeclaration *variable = 0; + bool have_input_primitive = false; + bool have_output_primitive = false; + bool have_output_vertex_count = false; public: void apply(Stage &, const Features &); @@ -57,7 +60,6 @@ private: virtual void visit(ImageTypeDeclaration &); virtual void visit(StructDeclaration &); virtual void visit(VariableDeclaration &); - virtual void visit(InterfaceBlock &); virtual void visit(FunctionDeclaration &); }; @@ -69,7 +71,7 @@ private: typedef std::map BlockDeclarationMap; std::map declarations; - std::map interface_blocks; + std::map interface_blocks; std::map overloaded_functions; bool anonymous_block = false; @@ -87,7 +89,6 @@ private: virtual void visit(ImageTypeDeclaration &t) { visit(static_cast(t)); } virtual void visit(StructDeclaration &); virtual void visit(VariableDeclaration &); - virtual void visit(InterfaceBlock &); virtual void visit(FunctionDeclaration &); }; @@ -102,10 +103,8 @@ private: virtual void visit(ImageTypeDeclaration &); virtual void visit(VariableReference &); virtual void visit(MemberAccess &); - virtual void visit(InterfaceBlockReference &); virtual void visit(FunctionCall &); virtual void visit(VariableDeclaration &); - virtual void visit(InterfaceBlock &); virtual void visit(FunctionDeclaration &); }; @@ -130,7 +129,6 @@ public: private: virtual void visit(VariableReference &); - virtual void visit(InterfaceBlockReference &); virtual void visit(Swizzle &); virtual void visit(UnaryExpression &); virtual void visit(BinaryExpression &); @@ -207,7 +205,6 @@ private: void check_uniform(const Uniform &); virtual void visit(VariableDeclaration &); - virtual void visit(InterfaceBlock &); virtual void visit(FunctionDeclaration &) { } };