Skip to content

Commit

Permalink
Add async entrypoints
Browse files Browse the repository at this point in the history
  • Loading branch information
hadashiA committed Jan 29, 2021
1 parent 834120c commit 0788f9f
Show file tree
Hide file tree
Showing 11 changed files with 326 additions and 189 deletions.
16 changes: 13 additions & 3 deletions VContainer/Assets/VContainer/Runtime/Unity/LifetimeScope.cs
Original file line number Diff line number Diff line change
Expand Up @@ -312,10 +312,10 @@ void ActivateEntryPoints()
PlayerLoopHelper.Dispatch(PlayerLoopTiming.Startup, loopItem);
}

var postStartable = Container.Resolve<IReadOnlyList<IPostStartable>>();
if (postInitializables.Count > 0)
var postStartables = Container.Resolve<IReadOnlyList<IPostStartable>>();
if (postStartables.Count > 0)
{
var loopItem = new PostStartableLoopItem(postStartable);
var loopItem = new PostStartableLoopItem(postStartables);
disposable.Add(loopItem);
PlayerLoopHelper.Dispatch(PlayerLoopTiming.PostStartup, loopItem);
}
Expand Down Expand Up @@ -368,6 +368,16 @@ void ActivateEntryPoints()
PlayerLoopHelper.Dispatch(PlayerLoopTiming.PostLateUpdate, loopItem);
}

#if VCONTAINER_UNITASK_INTEGRATION
var asyncStartables = Container.Resolve<IReadOnlyList<IAsyncStartable>>();
if (asyncStartables.Count > 0)
{
var loopItem = new AsyncStartableLoopItem(asyncStartables);
disposable.Add(loopItem);
PlayerLoopHelper.Dispatch(PlayerLoopTiming.Startup, loopItem);
}
#endif

#if VCONTAINER_ECS_INTEGRATION
Container.Resolve<IEnumerable<ComponentSystemBase>>();

Expand Down
35 changes: 35 additions & 0 deletions VContainer/Assets/VContainer/Runtime/Unity/PlayerLoopItem.cs
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
using System;
using System.Collections.Generic;
#if VCONTAINER_UNITASK_INTEGRATION
using Cysharp.Threading.Tasks;
#endif

namespace VContainer.Unity
{
Expand Down Expand Up @@ -53,6 +56,13 @@ public interface IPostLateTickable
void PostLateTick();
}

#if VCONTAINER_UNITASK_INTEGRATION
public interface IAsyncStartable
{
UniTaskVoid StartAsync();
}
#endif

sealed class InitializationLoopItem : IPlayerLoopItem, IDisposable
{
readonly IEnumerable<IInitializable> entries;
Expand Down Expand Up @@ -282,4 +292,29 @@ public bool MoveNext()

public void Dispose() => disposed = true;
}

#if VCONTAINER_UNITASK_INTEGRATION
sealed class AsyncStartableLoopItem : IPlayerLoopItem, IDisposable
{
readonly IEnumerable<IAsyncStartable> entries;
bool disposed;

public AsyncStartableLoopItem(IEnumerable<IAsyncStartable> entries)
{
this.entries = entries;
}

public bool MoveNext()
{
if (disposed) return false;
foreach (var x in entries)
{
x.StartAsync().Forget();
}
return false;
}

public void Dispose() => disposed = true;
}
endif
}
9 changes: 8 additions & 1 deletion VContainer/Assets/VContainer/Runtime/VContainer.asmdef
Original file line number Diff line number Diff line change
@@ -1,7 +1,9 @@
{
"name": "VContainer",
"rootNamespace": "",
"references": [
"GUID:734d92eba21c94caba915361bd5ac177"
"GUID:734d92eba21c94caba915361bd5ac177",
"GUID:f51ebe6a0ceec4240a699833d6309b23"
],
"includePlatforms": [],
"excludePlatforms": [],
Expand All @@ -15,6 +17,11 @@
"name": "com.unity.entities",
"expression": "",
"define": "VCONTAINER_ECS_INTEGRATION"
},
{
"name": "com.cysharp.unitask",
"expression": "",
"define": "VCONTAINER_UNITASK_INTEGRATION"
}
],
"noEngineReferences": false
Expand Down
Original file line number Diff line number Diff line change
@@ -1,8 +1,9 @@
using Cysharp.Threading.Tasks;
using VContainer.Unity;

namespace VContainer.Tests.Unity
{
public sealed class SampleEntryPoint :
public class SampleEntryPoint :
IInitializable,
IPostInitializable,
IStartable,
Expand Down Expand Up @@ -36,4 +37,15 @@ public sealed class SampleEntryPoint :
void ILateTickable.LateTick() => LateTickCalls += 1;
void IPostLateTickable.PostLateTick() => PostLateTickCalls += 1;
}

public class SampleAsyncEntryPoint : IAsyncStartable
{
public bool Started;

public async UniTaskVoid StartAsync()
{
await UniTask.Yield();
Started = true;
}
}
}
26 changes: 26 additions & 0 deletions VContainer/Assets/VContainer/Tests/Unity/UniTaskTest.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
using System.Collections;
using Cysharp.Threading.Tasks;
using NUnit.Framework;
using UnityEngine.TestTools;
using VContainer.Unity;

namespace VContainer.Tests.Unity
{
public class UniTaskTest
{
[UnityTest]
public IEnumerator AsyncStartup() => UniTask.ToCoroutine(async () =>
{
var parentLifetimeScope = LifetimeScope.Create(builder =>
{
builder.RegisterEntryPoint<SampleAsyncEntryPoint>(Lifetime.Scoped).AsSelf();
});

var entryPoint = parentLifetimeScope.Container.Resolve<SampleAsyncEntryPoint>();

Assert.That(entryPoint.Started, Is.False);
await UniTask.Yield();
Assert.That(entryPoint.Started, Is.True);
});
}
}
3 changes: 3 additions & 0 deletions VContainer/Assets/VContainer/Tests/Unity/UniTaskTest.cs.meta

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

20 changes: 8 additions & 12 deletions VContainer/Assets/VContainer/Tests/VContainer.Tests.asmdef
Original file line number Diff line number Diff line change
@@ -1,10 +1,12 @@
{
"name": "VContainer.Tests",
"rootNamespace": "",
"references": [
"UnityEngine.TestRunner",
"UnityEditor.TestRunner",
"VContainer",
"GUID:734d92eba21c94caba915361bd5ac177"
"GUID:27619889b8ba8c24980f49ee34dbb44a",
"GUID:0acc523941302664db1f4e527237feb3",
"GUID:b0214a6008ed146ff8f122a6a9c2f6cc",
"GUID:734d92eba21c94caba915361bd5ac177",
"GUID:f51ebe6a0ceec4240a699833d6309b23"
],
"includePlatforms": [],
"excludePlatforms": [
Expand All @@ -19,12 +21,6 @@
"defineConstraints": [
"UNITY_INCLUDE_TESTS"
],
"versionDefines": [
{
"name": "com.unity.entities",
"expression": "",
"define": "VCONTAINER_ECS_INTEGRATION"
}
],
"versionDefines": [],
"noEngineReferences": false
}
}
7 changes: 6 additions & 1 deletion VContainer/Packages/manifest.json
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
{
"dependencies": {
"com.cysharp.unitask": "https://github.com/Cysharp/UniTask.git?path=src/UniTask/Assets/Plugins/UniTask",
"com.unity.entities": "0.11.1-preview.4",
"com.unity.ide.rider": "2.0.7",
"com.unity.ide.visualstudio": "2.0.5",
Expand All @@ -13,6 +14,10 @@
"com.unity.modules.imgui": "1.0.0",
"com.unity.modules.jsonserialize": "1.0.0",
"com.unity.modules.ui": "1.0.0",
"com.unity.modules.uielements": "1.0.0"
"com.unity.modules.uielements": "1.0.0",
"com.unity.modules.unitywebrequest": "1.0.0",
"com.unity.modules.physics": "1.0.0",
"com.unity.modules.physics2d": "1.0.0",
"com.unity.modules.particlesystem": "1.0.0"
}
}
31 changes: 31 additions & 0 deletions VContainer/Packages/packages-lock.json
Original file line number Diff line number Diff line change
@@ -1,5 +1,12 @@
{
"dependencies": {
"com.cysharp.unitask": {
"version": "https://github.com/Cysharp/UniTask.git?path=src/UniTask/Assets/Plugins/UniTask",
"depth": 0,
"source": "git",
"dependencies": {},
"hash": "7d21a75ea8abbc3ed43afedeb450c8d44f244ece"
},
"com.unity.burst": {
"version": "1.3.0-preview.12",
"depth": 1,
Expand Down Expand Up @@ -216,6 +223,24 @@
"source": "builtin",
"dependencies": {}
},
"com.unity.modules.particlesystem": {
"version": "1.0.0",
"depth": 0,
"source": "builtin",
"dependencies": {}
},
"com.unity.modules.physics": {
"version": "1.0.0",
"depth": 0,
"source": "builtin",
"dependencies": {}
},
"com.unity.modules.physics2d": {
"version": "1.0.0",
"depth": 0,
"source": "builtin",
"dependencies": {}
},
"com.unity.modules.ui": {
"version": "1.0.0",
"depth": 0,
Expand All @@ -242,6 +267,12 @@
"com.unity.modules.imgui": "1.0.0",
"com.unity.modules.jsonserialize": "1.0.0"
}
},
"com.unity.modules.unitywebrequest": {
"version": "1.0.0",
"depth": 0,
"source": "builtin",
"dependencies": {}
}
}
}
Loading

0 comments on commit 0788f9f

Please sign in to comment.