diff options
author | Rémi Verschelde <rverschelde@gmail.com> | 2023-06-14 09:24:45 +0200 |
---|---|---|
committer | Rémi Verschelde <rverschelde@gmail.com> | 2023-06-14 09:24:45 +0200 |
commit | 56ac32feabf807d1d08fea35dabeb0ecfccc0450 (patch) | |
tree | 92c62182d43a4a0974da4d20156ee408f661ef80 /main | |
parent | adef9fb3d210409eda7355d497933f778dce85d2 (diff) | |
parent | 6eaff227ecbdb9535db8852089994cc71b5c5d1f (diff) | |
download | redot-engine-56ac32feabf807d1d08fea35dabeb0ecfccc0450.tar.gz |
Merge pull request #78054 from bruvzg/fix_res_errors
Fix "Resource file not found" error on editor start.
Diffstat (limited to 'main')
-rw-r--r-- | main/main.cpp | 25 |
1 files changed, 24 insertions, 1 deletions
diff --git a/main/main.cpp b/main/main.cpp index f7de02fb73..a9e2d357fa 100644 --- a/main/main.cpp +++ b/main/main.cpp @@ -2065,6 +2065,25 @@ error: return exit_code; } +Error _parse_resource_dummy(void *p_data, VariantParser::Stream *p_stream, Ref<Resource> &r_res, int &line, String &r_err_str) { + VariantParser::Token token; + VariantParser::get_token(p_stream, token, line, r_err_str); + if (token.type != VariantParser::TK_NUMBER && token.type != VariantParser::TK_STRING) { + r_err_str = "Expected number (old style sub-resource index) or String (ext-resource ID)"; + return ERR_PARSE_ERROR; + } + + r_res.unref(); + + VariantParser::get_token(p_stream, token, line, r_err_str); + if (token.type != VariantParser::TK_PARENTHESIS_CLOSE) { + r_err_str = "Expected ')'"; + return ERR_PARSE_ERROR; + } + + return OK; +} + Error Main::setup2() { Thread::make_main_thread(); // Make whatever thread call this the main thread. set_current_thread_safe_for_nodes(true); @@ -2112,12 +2131,16 @@ Error Main::setup2() { int lines = 0; String error_text; + VariantParser::ResourceParser rp_new; + rp_new.ext_func = _parse_resource_dummy; + rp_new.sub_func = _parse_resource_dummy; + while (true) { assign = Variant(); next_tag.fields.clear(); next_tag.name = String(); - err = VariantParser::parse_tag_assign_eof(&stream, lines, error_text, next_tag, assign, value, nullptr, true); + err = VariantParser::parse_tag_assign_eof(&stream, lines, error_text, next_tag, assign, value, &rp_new, true); if (err == ERR_FILE_EOF) { break; } |