Merge pull request #38279 from BigRed-118/assert_mark_as_safe_regression_bug

Fix for marking assert lines as safe bug
This commit is contained in:
Rémi Verschelde 2020-04-29 16:24:38 +02:00 committed by GitHub
commit 39a0cdac5f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 9 additions and 9 deletions

View File

@ -3358,15 +3358,10 @@ void GDScriptParser::_parse_block(BlockNode *p_block, bool p_static) {
} }
if (args.empty() || args.size() > 2) { if (args.empty() || args.size() > 2) {
_set_error("Wrong number of arguments, expected 1 or 2"); _set_error("Wrong number of arguments, expected 1 or 2", assert_line);
return; return;
} }
#ifdef DEBUG_ENABLED
// Mark as safe, let type check mark as unsafe if needed
_mark_line_as_safe(assert_line);
_reduce_node_type(args[0]);
#endif
AssertNode *an = alloc_node<AssertNode>(); AssertNode *an = alloc_node<AssertNode>();
an->condition = _reduce_expression(args[0], p_static); an->condition = _reduce_expression(args[0], p_static);
an->line = assert_line; an->line = assert_line;
@ -3383,7 +3378,7 @@ void GDScriptParser::_parse_block(BlockNode *p_block, bool p_static) {
p_block->statements.push_back(an); p_block->statements.push_back(an);
if (!_end_statement()) { if (!_end_statement()) {
_set_error("Expected end of statement after \"assert\"."); _set_error("Expected end of statement after \"assert\".", assert_line);
return; return;
} }
} break; } break;
@ -8133,10 +8128,15 @@ void GDScriptParser::_check_block_types(BlockNode *p_block) {
Node *statement = E->get(); Node *statement = E->get();
switch (statement->type) { switch (statement->type) {
case Node::TYPE_NEWLINE: case Node::TYPE_NEWLINE:
case Node::TYPE_BREAKPOINT: case Node::TYPE_BREAKPOINT: {
case Node::TYPE_ASSERT: {
// Nothing to do // Nothing to do
} break; } break;
case Node::TYPE_ASSERT: {
AssertNode *an = static_cast<AssertNode *>(statement);
_mark_line_as_safe(an->line);
_reduce_node_type(an->condition);
_reduce_node_type(an->message);
} break;
case Node::TYPE_LOCAL_VAR: { case Node::TYPE_LOCAL_VAR: {
LocalVarNode *lv = static_cast<LocalVarNode *>(statement); LocalVarNode *lv = static_cast<LocalVarNode *>(statement);
lv->datatype = _resolve_type(lv->datatype, lv->line); lv->datatype = _resolve_type(lv->datatype, lv->line);