Merge pull request #52 from Elringus/feature/support-disable-domain-reload
Support disable domain reload (fast enter play mode)master
commit
de3d491375
|
@ -96,8 +96,10 @@ namespace UniRx.Async
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
var dest = new PlayerLoopSystem[loopSystem.subSystemList.Length + 2];
|
var source = loopSystem.subSystemList // Remove items from previous initializations.
|
||||||
Array.Copy(loopSystem.subSystemList, 0, dest, 2, loopSystem.subSystemList.Length);
|
.Where(ls => ls.type != loopRunnerYieldType && ls.type != loopRunnerType).ToArray();
|
||||||
|
var dest = new PlayerLoopSystem[source.Length + 2];
|
||||||
|
Array.Copy(source, 0, dest, 2, source.Length);
|
||||||
dest[0] = yieldLoop;
|
dest[0] = yieldLoop;
|
||||||
dest[1] = runnerLoop;
|
dest[1] = runnerLoop;
|
||||||
return dest;
|
return dest;
|
||||||
|
@ -110,7 +112,15 @@ namespace UniRx.Async
|
||||||
unitySynchronizationContetext = SynchronizationContext.Current;
|
unitySynchronizationContetext = SynchronizationContext.Current;
|
||||||
mainThreadId = Thread.CurrentThread.ManagedThreadId;
|
mainThreadId = Thread.CurrentThread.ManagedThreadId;
|
||||||
|
|
||||||
|
#if UNITY_EDITOR && UNITY_2019_3_OR_NEWER
|
||||||
|
// When domain reload is disabled, re-initialization is required when entering play mode;
|
||||||
|
// otherwise, pending tasks will leak between play mode sessions.
|
||||||
|
var domainReloadDisabled = UnityEditor.EditorSettings.enterPlayModeOptionsEnabled &&
|
||||||
|
UnityEditor.EditorSettings.enterPlayModeOptions.HasFlag(UnityEditor.EnterPlayModeOptions.DisableDomainReload);
|
||||||
|
if (!domainReloadDisabled && runners != null) return;
|
||||||
|
#else
|
||||||
if (runners != null) return; // already initialized
|
if (runners != null) return; // already initialized
|
||||||
|
#endif
|
||||||
|
|
||||||
var playerLoop =
|
var playerLoop =
|
||||||
#if UNITY_2019_3_OR_NEWER
|
#if UNITY_2019_3_OR_NEWER
|
||||||
|
|
Loading…
Reference in New Issue