2
0
Эх сурвалжийг харах

Mono: Improve 'script class not found' error
No longer printed when using using placeholder script instances (for non-tool scripts in the editor).
Print different error if the project assembly is not loaded

Ignacio Etcheverry 7 жил өмнө
parent
commit
c8945fe7d8

+ 12 - 5
modules/mono/csharp_script.cpp

@@ -1954,11 +1954,6 @@ Variant CSharpScript::_new(const Variant **p_args, int p_argcount, Variant::Call
 
 
 ScriptInstance *CSharpScript::instance_create(Object *p_this) {
 ScriptInstance *CSharpScript::instance_create(Object *p_this) {
 
 
-	if (!script_class) {
-		ERR_EXPLAIN("Cannot find class " + name + " for script " + get_path());
-		ERR_FAIL_V(NULL);
-	}
-
 	ERR_FAIL_COND_V(!valid, NULL);
 	ERR_FAIL_COND_V(!valid, NULL);
 
 
 	if (!tool && !ScriptServer::is_scripting_enabled()) {
 	if (!tool && !ScriptServer::is_scripting_enabled()) {
@@ -1972,6 +1967,18 @@ ScriptInstance *CSharpScript::instance_create(Object *p_this) {
 		return NULL;
 		return NULL;
 #endif
 #endif
 	}
 	}
+	
+	if (!script_class) {
+		if (GDMono::get_singleton()->get_project_assembly() == NULL) {
+			// The project assembly is not loaded
+			ERR_EXPLAIN("Cannot instance script because the project assembly is not loaded. Script: " + get_path());
+			ERR_FAIL_V(NULL);
+		}
+		
+			// The project assembly is loaded, but the class could not found
+		ERR_EXPLAIN("Cannot instance script because the class '" + name + "' could not be found. Script: " + get_path());
+		ERR_FAIL_V(NULL);
+	}
 
 
 	update_signals();
 	update_signals();