summaryrefslogtreecommitdiffstats
path: root/main
diff options
context:
space:
mode:
authorRémi Verschelde <rverschelde@gmail.com>2023-06-14 09:24:45 +0200
committerRémi Verschelde <rverschelde@gmail.com>2023-06-14 09:24:45 +0200
commit56ac32feabf807d1d08fea35dabeb0ecfccc0450 (patch)
tree92c62182d43a4a0974da4d20156ee408f661ef80 /main
parentadef9fb3d210409eda7355d497933f778dce85d2 (diff)
parent6eaff227ecbdb9535db8852089994cc71b5c5d1f (diff)
downloadredot-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.cpp25
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;
}