fix/improve static cleanup

This commit is contained in:
Mikhail 2026-03-04 14:00:52 +08:00
parent 7b75720999
commit b6ae601cff
7 changed files with 13 additions and 54 deletions

View File

@ -370,6 +370,14 @@ namespace DCFApixels.DragonECS
#endregion
#region Other
public static void ClearCache()
{
lock (_lock)
{
_metaCache.Clear();
_metaCache.Add(typeof(void), NullTypeMeta);
}
}
ITypeMeta ITypeMeta.BaseMeta
{
get { return null; }
@ -623,13 +631,5 @@ namespace DCFApixels.DragonECS
#endregion
}
#endregion
internal static void Clear()
{
lock (_lock)
{
_metaCache.Clear();
}
}
}
}

View File

@ -411,6 +411,10 @@ namespace DCFApixels.DragonECS
#endregion
#region Other
public static void ClearCache()
{
_staticMaskCache.Clear();
}
EcsMask IComponentMask.ToMask(EcsWorld world) { return _mask; }
#endregion
@ -467,11 +471,6 @@ namespace DCFApixels.DragonECS
public delegate void OnBuildApectHandler(object aspect, EcsMask mask);
public static event OnBuildApectHandler OnAfterInit = delegate { };
#endregion
internal static void Clear()
{
_staticMaskCache.Clear();
}
}
#region EcsAspect.Builder.Extensions

View File

@ -1,18 +0,0 @@
using DCFApixels.DragonECS.Core.Internal;
namespace DCFApixels.DragonECS
{
public static class EcsStaticCleaner
{
public static void ResetAll()
{
TypeMeta.Clear();
Injector.InjectionList.Clear();
// MemoryAllocator.Clear();
EcsTypeCodeManager.Clear();
ConfigContainer.Clear();
EcsAspect.Clear();
EcsWorld.Clear();
}
}
}

View File

@ -175,10 +175,6 @@ namespace DCFApixels.DragonECS
// тут сложно однозначно посчитать, так как нужно еще место под аспекты и запросы
int controllersCount = config.PoolsCapacity * 4;
_worldComponentPools = new StructList<WorldComponentPoolAbstract>(controllersCount);
if (controllersCount < _allWorldComponentPools.Capacity)
{
_allWorldComponentPools.Capacity = controllersCount;
}
if (worldID < 0 || (worldID == NULL_WORLD_ID && nullWorld == false))
{

View File

@ -147,10 +147,7 @@ namespace DCFApixels.DragonECS
private static short _recycledItemsCount;
private static readonly IEcsWorldComponent<T> _interface = EcsWorldComponentHandler<T>.instance;
private static readonly Abstract _controller = new Abstract();
static WorldComponentPool()
{
_allWorldComponentPools.Add(_controller);
}
[MethodImpl(MethodImplOptions.AggressiveInlining)]
public static ref T GetItem(int itemIndex)
{// ts
@ -346,10 +343,5 @@ namespace DCFApixels.DragonECS
return FindPoolInstance(componentType);
}
#endregion
internal static void Clear()
{
_allWorldComponentPools.Clear();
}
}
}

View File

@ -53,11 +53,6 @@ namespace DCFApixels.DragonECS.Core.Internal
return null;
}
public static IEnumerable<TypeCodeInfo> GetDeclaredTypes() { return _codes.Select(o => new TypeCodeInfo(o.Key, o.Value)); }
internal static void Clear()
{
_codes.Clear();
}
}
#if ENABLE_IL2CPP
[Il2CppSetOption(Option.NullChecks, false)]

View File

@ -102,11 +102,6 @@ namespace DCFApixels.DragonECS
{
return GetAllConfigs().GetEnumerator();
}
internal static void Clear()
{
Empty._storage.Clear();
}
}
public static class ConfigContainerExtensions
{