diff --git a/Assets/Plugins/UniRx/Scripts/UnityEngineBridge/MainThreadDispatcher.cs b/Assets/Plugins/UniRx/Scripts/UnityEngineBridge/MainThreadDispatcher.cs index 91cc8c45..f6f51102 100644 --- a/Assets/Plugins/UniRx/Scripts/UnityEngineBridge/MainThreadDispatcher.cs +++ b/Assets/Plugins/UniRx/Scripts/UnityEngineBridge/MainThreadDispatcher.cs @@ -497,7 +497,9 @@ void Awake() updateMicroCoroutine = new MicroCoroutine(ex => unhandledExceptionCallback(ex)); fixedUpdateMicroCoroutine = new MicroCoroutine(ex => unhandledExceptionCallback(ex)); endOfFrameMicroCoroutine = new MicroCoroutine(ex => unhandledExceptionCallback(ex)); - + + Application.quitting += OnApplicationQuitting; + StartCoroutine(RunUpdateMicroCoroutine()); StartCoroutine(RunFixedUpdateMicroCoroutine()); StartCoroutine(RunEndOfFrameMicroCoroutine()); @@ -590,7 +592,7 @@ void OnDestroy() { instance = GameObject.FindObjectOfType(); initialized = instance != null; - + Application.quitting -= OnApplicationQuitting; /* // Although `this` still refers to a gameObject, it won't be found. var foundDispatcher = GameObject.FindObjectOfType(); @@ -669,7 +671,7 @@ public static IObservable OnApplicationPauseAsObservable() Subject onApplicationQuit; - void OnApplicationQuit() + void OnApplicationQuitting() { isQuitting = true; if (onApplicationQuit != null) onApplicationQuit.OnNext(Unit.Default); @@ -680,4 +682,4 @@ public static IObservable OnApplicationQuitAsObservable() return Instance.onApplicationQuit ?? (Instance.onApplicationQuit = new Subject()); } } -} \ No newline at end of file +}