X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fglsl%2Fcompiler.cpp;h=40dfede3a68688e5ec9ef7a9fb23576af28d393e;hb=7a62eb7f7550df161656616f2ece5a094b754392;hp=e9933e2f9b67c4ec414999438a9e8c1c0ec60ba9;hpb=5e4204ecaf54f49b63587ef5cd669a1b3838e0e9;p=libs%2Fgl.git diff --git a/source/glsl/compiler.cpp b/source/glsl/compiler.cpp index e9933e2f..40dfede3 100644 --- a/source/glsl/compiler.cpp +++ b/source/glsl/compiler.cpp @@ -24,12 +24,14 @@ namespace SL { Compiler::Compiler(): features(Features::from_context()), module(0), + compiled(false), specialized(false) { } Compiler::Compiler(const Features &f): features(f), module(0), + compiled(false), specialized(false) { } @@ -96,10 +98,15 @@ void Compiler::compile(Mode mode) } for(list::iterator i=module->stages.begin(); i!=module->stages.end(); ++i) finalize(*i, mode); + + compiled = true; } string Compiler::get_combined_glsl() const { + if(!compiled) + throw invalid_operation("Compiler::get_combined_glsl"); + string glsl; unsigned source_count = module->source_map.get_count(); @@ -126,6 +133,8 @@ vector Compiler::get_stages() const string Compiler::get_stage_glsl(Stage::Type stage_type) const { + if(!compiled) + throw invalid_operation("Compiler::get_stage_glsl"); for(list::iterator i=module->stages.begin(); i!=module->stages.end(); ++i) if(i->type==stage_type) return Formatter().apply(*i); @@ -134,6 +143,8 @@ string Compiler::get_stage_glsl(Stage::Type stage_type) const const map &Compiler::get_vertex_attributes() const { + if(!compiled) + throw invalid_operation("Compiler::get_vertex_attributes"); for(list::const_iterator i=module->stages.begin(); i!=module->stages.end(); ++i) if(i->type==Stage::VERTEX) return i->locations; @@ -142,6 +153,8 @@ const map &Compiler::get_vertex_attributes() const const map &Compiler::get_fragment_outputs() const { + if(!compiled) + throw invalid_operation("Compiler::get_fragment_outputs"); for(list::const_iterator i=module->stages.begin(); i!=module->stages.end(); ++i) if(i->type==Stage::FRAGMENT) return i->locations; @@ -288,7 +301,7 @@ void Compiler::resolve(Stage &stage, unsigned flags) bool Compiler::validate(Stage &stage) { TypeValidator().apply(stage); - DeclarationValidator().apply(stage); + IdentifierValidator().apply(stage); ReferenceValidator().apply(stage); ExpressionValidator().apply(stage);