Mirror of Svelto.ECS because we're a fan of it
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

CHANGELOG.md 9.0KB

8 months ago
1 year ago
1 year ago
2 years ago
3 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. # Svelto.ECS Changelog
  2. All notable changes to this project will be documented in this file. Changes are listed in random order of importance.
  3. ## [3.5.0] - 09-2023
  4. * Introduced Serialization namespace for the serialization code
  5. * Unity: dropped 2020 support, minimum requirement is no 2021.3
  6. * Unity DOTS: added CreateDOTSToSveltoSyncEngine method in SveltoOnDOTSEnginesGroup
  7. * Refactor: split NB/MB struct from their internal logic that must be used only by the framework. Eventually NB and MB structs must be ref, as they are not supposed to be held (they may become invalid over the time). However due to the current DOTS patterns this is not possible. In future a sentinel pattern will allow to lease these buffers with the assumption that they can't be modified while held (and if a modification happens an exception will throw)
  8. * Improved managed EGIDMultiMapper. A MultiMapper can improve components fetching performance
  9. * Renamed IDisposableEngine interface to IDisposableEngine
  10. * added EntityReference Exists method to validate it against a given entity database
  11. * BUG FIXED: IReactOnDisposeEx callbacks were not correctly called
  12. * BUG FIXED: fixed serious bug that would pass wrong entities indices to the moveTO callback under specific conditions
  13. * Added Group Range functionality to GroupCompound
  14. * Added Offset to GroupCompound to know the index of a given group compared to the starting group ID of the compound range (check MiniExample 9, Groupsonly for example)
  15. * range and bitmask can be now set only in GroupTag and be inherited by GroupCompounds. GroupCompound bitmasks will be the OR of the group tags bitmasks, while the range will be the larger of the group tags ranges.
  16. * entity filters enumerator do not iterate anymore filters belonging to disabled groups
  17. * remove operations can now be executed in the same frame of a swap. a Remove will always supersed as Swap operation
  18. * engines added to a GreoupEngine are automatically added to the enginesgroup
  19. ## [3.4.6] - 05-2023
  20. * SveltoOnDOTS bug fixes/improvements
  21. * Comments and code cleanup
  22. ## [3.4.4] - 04-2023
  23. * refactored internal datastructures
  24. * added IReactOnDisposeEx interface
  25. * added code to warmup all the entity descriptors at startup to avoid first time allocations when an entitydescriptor is used for the very first time
  26. * added the option to iterate transient filters per component like it already happens with persistent filters. Transient filters are tracked optionally.
  27. * fixed huge bug in the filter enumerator, truly surprised this never showed up
  28. ## [3.4.2] - 03-2023
  29. * removed static caches used in performance critical paths as they were causing unexpected performance issues (the fetching of static data is slower than i imagined)
  30. * add Native prefix in front of the native memory utilities method names
  31. * largely improved the console logger system
  32. * minor improvements to the platform profiler structs
  33. * improvements to the ThreadSafeObjectPool class (some refactoring too)
  34. * added several datastructures previously belonging to Svelto.ECS
  35. * all the FastClear methods are gone. The standard clear method now is aware of the type used and will clear it in the fastest way possible
  36. * MemClear is added in case memory needs to be cleared explicitly
  37. * added new SveltoStream, Unmanaged and Managed stream classes, their use case will be documented one day
  38. * renamed the Svelto.Common.DataStructures namespace to Svelto.DataStructures
  39. * added FixedTypedArray* methods. Fixed size arrays embedded in structs are now possible
  40. * FasterList extension to convert to Span and ByteSpan
  41. * Fix reported bugs
  42. * Minor Svelto Dictionary improvements
  43. * Added ValueContainer, a simple int, Tvalue dictionary based on sparse set. It has very specific use cases at the moment. Mainly to be used for the new ECS OOP Abstraction resoruce manager
  44. * Added IReactOnSubmissionStarted interface
  45. ### SveltoOnDOTS changes
  46. * update to DOTS 1.0 (but still compatible with 0.51, although slower)
  47. * Deprecated the use of EntityCommandBuffer since was very slow
  48. * added faster batched DOTS operations, new DOTS creation patterns introduced (old one still compatible as long as EntityCommandBuffer was not used)
  49. * ISveltoOnDOTSSubmission interface exists only to allow the user to submit entities On DOTS explicitly, use this instead of
  50. * SveltoOnDOTSHandleCreationEngine is no more, you want to use ISveltoOnDOTSStructuralEngine and its DOTSOperations instead wherever EntityManager was used before
  51. * ISveltoOnDOTSStructuralEngine is no more, you want to use ISveltoOnDOTSStructuralEngine and its DOTSOperations instead
  52. * in all the case above, if you were relying on Update you probably want to use OnPostSubmission instead
  53. * DOTSOperations new AddJobToComplete method will allow to register jobs from inside ISveltoOnDOTSStructuralEngines that will be completed at the end of the submission
  54. ## [3.3.2] - 04-06-2022
  55. * Internal refactoring to support future features. Currently it may translate to a small performance boost
  56. * IEntityComponent and IEntityViewComponent now implements _IInternalEntityComponent. This shouldn't affect existing code
  57. * Improve thread-safety of entity building
  58. * Fixed serious bug that affected the integrity of the EntityIDs values during RemoveEX callbacks
  59. * The point above may result in a performance boost in the Filters updates during submission
  60. * Code is again 2019 compatible (this may have been broken for a while)
  61. * Fix a crash wit the EntityCollection deconstruction while trying to deconstruct an empty collection
  62. * Breaking: EntityFilterCollection GetGroupFilter will throw an exception if the filter doesn't exist. Use GetOrCreateGroupFilter in case.
  63. * Breaking: LocatorMap has been renamed to EntityReferenceMap
  64. * Breaking: GetEntityLocatorMap has been renamed to GetEntityReferenceMap
  65. ## [3.3.1] - 26-04-2022
  66. * Fixed serious bug that would affect the new IReactOnRemoveEx callbacks
  67. ## [3.3.0] - 11-04-2022
  68. * INeedEGID and INeedEntityReference interfaces are not deprecated, but still available for backwards compatibility through the define SLOW_SVELTO_SUBMISSION
  69. * There are some minor breaking changes, you may need to rename a bunch of methods calls
  70. * Drastically improved Submission phase performance
  71. * All the IReactOn interfaces are now replaced by much faster IReacOn\*Ex interfaces. Use those instead.
  72. * QueryEntities methods now optionally return also an array of Entity IDs that you can reference like a component (this supersedes INeedEGID)
  73. * Completely reworked and way more powerful filter API. The old one has been renamed to Legacy and left for backward compatibility
  74. * NativeEGIDMultiMapper doesn't need to be created every submission anymore. It can be created permanently and disposed when not used anymore (some caveats with it)
  75. * Improved Serialization system
  76. * Improved SveltoOnDots system
  77. * Tons of other improvements and bug fixes
  78. ## [3.2.5]
  79. * refactor and improved NativeBag and UnsafeBlob. This fix a previously known crash with Unity IL2CPP
  80. ## [3.2.0]
  81. * Improved checks on Svelto rules for the declaration of components and view components. This set of rules is not final yet (ideally one day they should be moved to static analyzers)
  82. * Introduce the concept of Entity Reference. It's a very light weight identifier to keep track of entities EGID that can change dynamically (EGIDs change when groups are swapped), Entity References never change. The underlying code will be optimised even further in future.
  83. * Introduced the concept of Disabled Group. Once a group is marked as disabled, queries will always ignore it.
  84. * Merged DispatchOnSet and DispatchOnChange and renamed to ReactiveValue. This class will be superseded by better patterns in future.
  85. * Added FindGroups with 4 components
  86. * Improved QueryGroups interface
  87. * Improved DynamicEntityDescriptor interface
  88. * Improved ExtendibleEntityDescriptor interface
  89. * Improved Native memory support
  90. * Improved Svelto and Unity DOTS integration
  91. * Improved and fixed Serialization code
  92. * Ensure that the creation of static groups is deterministic (GroupHashMap)
  93. ## [3.1.3]
  94. * bumped dependency of Svelto.Common due to an important fix there.
  95. ## [3.1.2]
  96. * improved async entity submission code (still experimental)
  97. * improved native entity operations debug info
  98. ## [3.1.1]
  99. * SubmissionEngine didn't need the EntityManager property, so it has been removed
  100. ## [3.1.0]
  101. * rearrange folders structures for clarity
  102. * added DoubleEntitiesEnumerator, as seen in MiniExample 4, to allow a double iteration of the same group skipping
  103. already checked tuples
  104. * reengineered the behaviour of WaitForSubmissionEnumerator
  105. * removed redudant SimpleEntitySubmissionSchedulerInterface interface
  106. * renamed BuildGroup in to ExclusiveBuildGroup
  107. * renamed EntityComponentInitializer to EntityInitializer
  108. * Entity Submission now can optionally be time sliced (based on number of entities to submit per slice)
  109. * working on the Unity extension Submission Engine, still WIP
  110. * added the possibility to hold a reference in a EntityViewComponent. This reference cannot be accesses as an object,
  111. but can be converted to the original object in OOP abstract layers
  112. * renamed NativeEntityComponentInitializer to NativeEntityInitializer