Merge pull request #55250 from Chaosus/shader_fix_return_3.x
This commit is contained in:
commit
c0403b2ebe
|
@ -5385,11 +5385,6 @@ Error ShaderLanguage::_parse_block(BlockNode *p_block, const Map<StringName, Bui
|
||||||
//check return type
|
//check return type
|
||||||
BlockNode *b = p_block;
|
BlockNode *b = p_block;
|
||||||
|
|
||||||
if (b && b->parent_function && (b->parent_function->name == "vertex" || b->parent_function->name == "fragment" || b->parent_function->name == "light")) {
|
|
||||||
_set_error(vformat("Using 'return' in '%s' processor function results in undefined behavior!", b->parent_function->name));
|
|
||||||
return ERR_PARSE_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
while (b && !b->parent_function) {
|
while (b && !b->parent_function) {
|
||||||
b = b->parent_block;
|
b = b->parent_block;
|
||||||
}
|
}
|
||||||
|
@ -5399,6 +5394,11 @@ Error ShaderLanguage::_parse_block(BlockNode *p_block, const Map<StringName, Bui
|
||||||
return ERR_BUG;
|
return ERR_BUG;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (b && b->parent_function && (b->parent_function->name == "vertex" || b->parent_function->name == "fragment" || b->parent_function->name == "light")) {
|
||||||
|
_set_error(vformat("Using 'return' in '%s' processor function results in undefined behavior!", b->parent_function->name));
|
||||||
|
return ERR_PARSE_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
String return_struct_name = String(b->parent_function->return_struct_name);
|
String return_struct_name = String(b->parent_function->return_struct_name);
|
||||||
|
|
||||||
ControlFlowNode *flow = alloc_node<ControlFlowNode>();
|
ControlFlowNode *flow = alloc_node<ControlFlowNode>();
|
||||||
|
|
Loading…
Reference in New Issue