X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fglsl%2Fvalidate.cpp;h=6e90698c97b500c5dd2edcaebd7e3f8c70e90026;hb=3a1fe83;hp=1458d01eaaba8743d40e90bb9b030790dca3cad9;hpb=15562a0c458fd655b6907c285951085f38270e27;p=libs%2Fgl.git diff --git a/source/glsl/validate.cpp b/source/glsl/validate.cpp index 1458d01e..6e90698c 100644 --- a/source/glsl/validate.cpp +++ b/source/glsl/validate.cpp @@ -2,6 +2,7 @@ #include #include #include +#include #include "validate.h" using namespace std; @@ -239,7 +240,26 @@ void ReferenceValidator::visit(InterfaceBlockReference &iface) void ReferenceValidator::visit(FunctionCall &call) { if(!call.declaration && !call.constructor) - error(call, format("Call to undeclared function '%s'", call.name)); + { + map::iterator i = stage->functions.lower_bound(call.name); + if(i!=stage->functions.end() && i->second->name==call.name) + { + bool valid_types = true; + string signature; + for(NodeArray::const_iterator j=call.arguments.begin(); (valid_types && j!=call.arguments.end()); ++j) + { + if((*j)->type) + append(signature, ", ", (*j)->type->name); + else + valid_types = false; + } + + if(valid_types) + error(call, format("No matching overload found for call to '%s(%s)'", call.name, signature)); + } + else + error(call, format("Call to undeclared function '%s'", call.name)); + } TraversingVisitor::visit(call); } @@ -345,6 +365,20 @@ void ExpressionValidator::visit(Assignment &assign) TraversingVisitor::visit(assign); } +void ExpressionValidator::visit(TernaryExpression &ternary) +{ + if(ternary.condition->type) + { + BasicTypeDeclaration *basic_cond = dynamic_cast(ternary.condition->type); + if(!basic_cond || basic_cond->kind!=BasicTypeDeclaration::BOOL) + error(ternary, "Ternary operator condition is not a boolean"); + else if(!ternary.type && ternary.true_expr->type && ternary.false_expr->type) + error(ternary, format("Ternary operator has incompatible types '%s' and '%s'", + ternary.true_expr->type->name, ternary.false_expr->type->name)); + } + TraversingVisitor::visit(ternary); +} + void ExpressionValidator::visit(VariableDeclaration &var) { if(var.init_expression && var.init_expression->type && var.type_declaration && var.init_expression->type!=var.type_declaration)