123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105 |
- namespace ET.Server
- {
- [ObjectSystem]
- public class LockInfoAwakeSystem: AwakeSystem<LockInfo, long, CoroutineLock>
- {
- protected override void Awake(LockInfo self, long lockInstanceId, CoroutineLock coroutineLock)
- {
- self.CoroutineLock = coroutineLock;
- self.LockInstanceId = lockInstanceId;
- }
- }
-
- [ObjectSystem]
- public class LockInfoDestroySystem: DestroySystem<LockInfo>
- {
- protected override void Destroy(LockInfo self)
- {
- self.CoroutineLock.Dispose();
- self.LockInstanceId = 0;
- }
- }
-
- [FriendOf(typeof(LocationComponent))]
- [FriendOf(typeof(LockInfo))]
- public static class LocationComponentSystem
- {
- public static async ETTask Add(this LocationComponent self, long key, long instanceId)
- {
- using (await CoroutineLockComponent.Instance.Wait(CoroutineLockType.Location, key))
- {
- self.locations[key] = instanceId;
- Log.Info($"location add key: {key} instanceId: {instanceId}");
- }
- }
- public static async ETTask Remove(this LocationComponent self, long key)
- {
- using (await CoroutineLockComponent.Instance.Wait(CoroutineLockType.Location, key))
- {
- self.locations.Remove(key);
- Log.Info($"location remove key: {key}");
- }
- }
- public static async ETTask Lock(this LocationComponent self, long key, long instanceId, int time = 0)
- {
- CoroutineLock coroutineLock = await CoroutineLockComponent.Instance.Wait(CoroutineLockType.Location, key);
- LockInfo lockInfo = self.AddChild<LockInfo, long, CoroutineLock>(instanceId, coroutineLock);
- self.lockInfos.Add(key, lockInfo);
- Log.Info($"location lock key: {key} instanceId: {instanceId}");
- if (time > 0)
- {
- async ETTask TimeWaitAsync()
- {
- long lockInfoInstanceId = lockInfo.InstanceId;
- await TimerComponent.Instance.WaitAsync(time);
- if (lockInfo.InstanceId != lockInfoInstanceId)
- {
- return;
- }
- Log.Info($"location timeout unlock key: {key} instanceId: {instanceId} newInstanceId: {instanceId}");
- self.UnLock(key, instanceId, instanceId);
- }
- TimeWaitAsync().Coroutine();
- }
- }
- public static void UnLock(this LocationComponent self, long key, long oldInstanceId, long newInstanceId)
- {
- if (!self.lockInfos.TryGetValue(key, out LockInfo lockInfo))
- {
- Log.Error($"location unlock not found key: {key} {oldInstanceId}");
- return;
- }
- if (oldInstanceId != lockInfo.LockInstanceId)
- {
- Log.Error($"location unlock oldInstanceId is different: {key} {oldInstanceId}");
- return;
- }
- Log.Info($"location unlock key: {key} instanceId: {oldInstanceId} newInstanceId: {newInstanceId}");
- self.locations[key] = newInstanceId;
- self.lockInfos.Remove(key);
- // 解锁
- lockInfo.Dispose();
- }
- public static async ETTask<long> Get(this LocationComponent self, long key)
- {
- using (await CoroutineLockComponent.Instance.Wait(CoroutineLockType.Location, key))
- {
- self.locations.TryGetValue(key, out long instanceId);
- Log.Info($"location get key: {key} instanceId: {instanceId}");
- return instanceId;
- }
- }
- }
- }
|