瀏覽代碼

Merge pull request #43788 from RandomShaper/ref_singleton

Make warning about Reference singletons more accurate
Rémi Verschelde 4 年之前
父節點
當前提交
18023cc3ed
共有 1 個文件被更改,包括 3 次插入2 次删除
  1. 3 2
      core/config/engine.cpp

+ 3 - 2
core/config/engine.cpp

@@ -224,8 +224,9 @@ Engine::Singleton::Singleton(const StringName &p_name, Object *p_ptr) :
 		name(p_name),
 		ptr(p_ptr) {
 #ifdef DEBUG_ENABLED
-	if (Object::cast_to<Reference>(p_ptr)) {
-		ERR_PRINT("A class intended to be used as a singleton must *not* inherit from Reference.");
+	Reference *ref = Object::cast_to<Reference>(p_ptr);
+	if (ref && !ref->is_referenced()) {
+		WARN_PRINT("You must use Ref<> to ensure the lifetime of a Reference object intended to be used as a singleton.");
 	}
 #endif
 }