Releases: needle-mirror/com.unity.entities
0.9.1-preview.15
[0.9.1] - 2020-04-15
Fixed
- Fixed NullReferenceException issue with Singleton access methods in SystemBase.
[0.9.0] - 2020-04-09
Added
public void GetCreatedAndDestroyedEntitiesAsync(NativeList<int> state, NativeList<Entity> createdEntities, NativeList<Entity> destroyedEntities)
detects which entities were created and destroyed since the last call to this method.- Added the ability to reimport a SubScene via an inspector button, which forces reconversion.
- Added
GameObjectConversionSystem.DeclareAssetDependency
which expresses that the conversion result of a GameObject depends on an Asset - Added
void EntityManager.Instantiate(NativeArray<Entity> srcEntities, NativeArray<Entity> dstEntities)
. It gives explicit control over the set of entities that are instantiated as a set. Entity references on components that are cloned to entities inside the set are remapped to the instantiated entities. - Added
void EntityManager.CopyEntitiesFrom(EntityManager srcEntityManager, NativeArray<Entity> srcEntities, NativeArray<Entity> outputEntities = default)
. It lets you copy a specific set of entities from one World to another. Entity references on components that are cloned to entities inside the set are remapped to the instantiated entities. - Added assembly for Mesh Deformation data structures.
Changed
- Systems are now constructed in two phases. First, ECS creates a new instance of all systems and invokes the constructor. Then, it invokes all
OnCreate
methods. This way, you can now useWorld.GetExistingSystem<OtherSystem>()
from insideOnCreate()
. - Systems are now destroyed in three phases. First, ECS stops all running systems (i.e. OnStopRunning() is invoked). Then it invokes all
OnDestroy
methods. Finally, ECS destroys all systems. This means you can perform safe and predictable cleanup of systems with cross-references to other systems. - EntityCommandBuffer Playback now Bursted through function pointers. When there's a mix of unmanaged and managed commands in a single buffer, unmanaged commands will be Bursted. When there are no managed commands, each chain's Playback is fully Bursted.
Entities.ForEach
in aGameObjectConversionSystem
no longer logs a warning if there are multiples of a queried authoring component on a matching GameObject. It now returns the first component instance of the desired type, so conversion systems can optionally callGetComponents<T>()
in order to handle multiples if desired.- Declaring a non-Prefab object as a referenced Prefab during conversion now emits a warning
- Improved performance of access to singletons through
SetSingleton
andGetSingleton
in SystemBase (peformance is also improved through these methods on EntityQuery). - Updated package
com.unity.properties
to version1.1.0-preview
. - Updated package
com.unity.serialization
to version1.1.0-preview
. - Updated package
com.unity.platforms
to version0.2.2-preview.7
.
Deprecated
- Deprecated
public T World.CreateSystem<T>(params object[] constructorArguments)
. Please useWorld.AddSystem(new MySystem(myParams));
instead. - Deprecated
LiveLinkBuildImport.GetHash/GetDependencies/GetBundlePath
.
Removed
- Removed expired API
TypeManager.CreateTypeIndexForComponent<T>()
- Removed expired API
TypeManager.CreateTypeIndexForSharedComponent<T>()
- Removed expired API
TypeManager.CreateTypeIndexForBufferElement<T>()
- Removed expired API
DynamicBuffer.Reserve(int)
- Removed expired API
World.Active
Fixed
- Fix BlobAssetSafetyVerifier to generate a better error message when
readonly
is used with BlobAsset references. - Fixed incorrect comparison in
EntityChunk.CompareTo()
. SceneManager.IsSceneLoaded
now works for converted entity Scenes and returns whether all sections of an entity Scene have loaded.- Fixed Exception in conversion code when trying to delete entities that are part of a Prefab.
- Fixed Hybrid Component conversion failing when multiple components were added for the same GameObject.
- Fixed use of component access methods (GetComponent/SetComponent/HasComponent) inside Entities.ForEach with nested captures.
- Fix compilation issue when
ENABLE_SIMPLE_SYSTEM_DEPENDENCIES
is enabled.
Known Issues
- System groups do not currently apply to systems running as part of
EntitySceneOptimizations
0.9.0-preview.6
[0.9.0] - 2020-04-08
Added
public void GetCreatedAndDestroyedEntitiesAsync(NativeList<int> state, NativeList<Entity> createdEntities, NativeList<Entity> destroyedEntities)
detects which entities were created and destroyed since the last call to this method.- Added the ability to reimport a SubScene via an inspector button, which forces reconversion.
- Added
GameObjectConversionSystem.DeclareAssetDependency
which expresses that the conversion result of a GameObject depends on an Asset - Added
void EntityManager.Instantiate(NativeArray<Entity> srcEntities, NativeArray<Entity> dstEntities)
. It gives explicit control over the set of entities that are instantiated as a set. Entity references on components that are cloned to entities inside the set are remapped to the instantiated entities. - Added
void EntityManager.CopyEntitiesFrom(EntityManager srcEntityManager, NativeArray<Entity> srcEntities, NativeArray<Entity> outputEntities = default)
. It lets you copy a specific set of entities from one World to another. Entity references on components that are cloned to entities inside the set are remapped to the instantiated entities. - Added assembly for Mesh Deformation data structures.
Changed
- Systems are now constructed in two phases. First, ECS creates a new instance of all systems and invokes the constructor. Then, it invokes all
OnCreate
methods. This way, you can now useWorld.GetExistingSystem<OtherSystem>()
from insideOnCreate()
. - Systems are now destroyed in three phases. First, ECS stops all running systems (i.e. OnStopRunning() is invoked). Then it invokes all
OnDestroy
methods. Finally, ECS destroys all systems. This means you can perform safe and predictable cleanup of systems with cross-references to other systems. - EntityCommandBuffer Playback now Bursted through function pointers. When there's a mix of unmanaged and managed commands in a single buffer, unmanaged commands will be Bursted. When there are no managed commands, each chain's Playback is fully Bursted.
Entities.ForEach
in aGameObjectConversionSystem
no longer logs a warning if there are multiples of a queried authoring component on a matching GameObject. It now returns the first component instance of the desired type, so conversion systems can optionally callGetComponents<T>()
in order to handle multiples if desired.- Declaring a non-Prefab object as a referenced Prefab during conversion now emits a warning
- Improved performance of access to singletons through
SetSingleton
andGetSingleton
in SystemBase (peformance is also improved through these methods on EntityQuery). - Updated package
com.unity.properties
to version1.1.0-preview
. - Updated package
com.unity.serialization
to version1.1.0-preview
. - Updated package
com.unity.platforms
to version0.2.2-preview.7
.
Deprecated
- Deprecated
public T World.CreateSystem<T>(params object[] constructorArguments)
. Please useWorld.AddSystem(new MySystem(myParams));
instead. - Deprecated
LiveLinkBuildImport.GetHash/GetDependencies/GetBundlePath
.
Removed
- Removed expired API
TypeManager.CreateTypeIndexForComponent<T>()
- Removed expired API
TypeManager.CreateTypeIndexForSharedComponent<T>()
- Removed expired API
TypeManager.CreateTypeIndexForBufferElement<T>()
- Removed expired API
DynamicBuffer.Reserve(int)
- Removed expired API
World.Active
Fixed
- Fix BlobAssetSafetyVerifier to generate a better error message when
readonly
is used with BlobAsset references. - Fixed incorrect comparison in
EntityChunk.CompareTo()
. SceneManager.IsSceneLoaded
now works for converted entity Scenes and returns whether all sections of an entity Scene have loaded.- Fixed Exception in conversion code when trying to delete entities that are part of a Prefab.
- Fixed Hybrid Component conversion failing when multiple components were added for the same GameObject.
- Fixed use of component access methods (GetComponent/SetComponent/HasComponent) inside Entities.ForEach with nested captures.
- Fix compilation issue when
ENABLE_SIMPLE_SYSTEM_DEPENDENCIES
is enabled.
Security
Known Issues
- System groups do not currently apply to systems running as part of
EntitySceneOptimizations
[0.8.0] - 2020-03-12
Added
- Added missing dynamic component version API:
ArchetypeChunk.GetComponentVersion(ArchetypeChunkComponentTypeDynamic)
- Added missing dynamic component has API:
ArchetypeChunk.Has(ArchetypeChunkComponentTypeDynamic)
EntityArchetype
didn't expose whether it was Prefab or not. Added boolEntityArchetype.Prefab
. This is needed for meta entity queries, because meta entity queries don't avoid Prefabs.- Added Build Configurations and Build Pipelines for Linux
- LiveLink now gives an error if a LiveLink player attempts to connect to the wrong Editor, and advises the user on how to correct this.
Changed
- Optimized
ArchetypeChunkComponentTypeDynamic
memory layout. 48->40 bytes. - LiveLink: Editor no longer freezes when sending LiveLink assets to a LiveLinked player.
- LiveLink: No longer includes every Asset from builtin_extra to depend on a single Asset, and sends only what is used. This massively speeds up the first-time LiveLink to a Player.
- Upgraded Burst to fix multiple issues and introduced native debugging feature.
Deprecated
- Types that implement
IJobForEach
interfaces have been deprecated. UseIJobChunk
andEntities.ForEach
for these jobs.
Fixed
- Fixed LiveLinking with SubScene Sections indices that were not contiguous (0, 1, 2..). Now works with whatever index you use.
- Fixed warning when live converting disabled GameObjects.
- Allow usage of
Entities.WithReadOnly
,Entities.WithDeallocateOnJobCompletion
,Entities.WithNativeDisableContainerSafetyRestriction
, andEntities.WithNativeDisableParallelForRestriction
on types that contain valid NativeContainers.
0.8.0-preview.8
[0.8.0] - 2020-03-13
Added
- Added missing dynamic component version API:
ArchetypeChunk.GetComponentVersion(ArchetypeChunkComponentTypeDynamic)
- Added missing dynamic component has API:
ArchetypeChunk.Has(ArchetypeChunkComponentTypeDynamic)
EntityArchetype
didn't expose whether it was Prefab or not. Added boolEntityArchetype.Prefab
. This is needed for meta entity queries, because meta entity queries don't avoid Prefabs.- Added Build Configurations and Build Pipelines for Linux
- LiveLink now gives an error if a LiveLink player attempts to connect to the wrong Editor, and advises the user on how to correct this.
Changed
- Optimized
ArchetypeChunkComponentTypeDynamic
memory layout. 48->40 bytes. - LiveLink: Editor no longer freezes when sending LiveLink assets to a LiveLinked player.
- LiveLink: No longer includes every Asset from builtin_extra to depend on a single Asset, and sends only what is used. This massively speeds up the first-time LiveLink to a Player.
- Upgraded Burst to fix multiple issues and introduced native debugging feature.
Deprecated
- Types that implement
IJobForEach
interfaces have been deprecated. UseIJobChunk
andEntities.ForEach
for these jobs.
Fixed
- Fixed LiveLinking with SubScene Sections indices that were not contiguous (0, 1, 2..). Now works with whatever index you use.
- Fixed warning when live converting disabled GameObjects.
- Allow usage of
Entities.WithReadOnly
,Entities.WithDeallocateOnJobCompletion
,Entities.WithNativeDisableContainerSafetyRestriction
, andEntities.WithNativeDisableParallelForRestriction
on types that contain valid NativeContainers.
[0.7.0] - 2020-03-03
Added
- Added
HasComponent
/GetComponent
/SetComponent
methods that streamline access to components through entities when using theSystemBase
class. These methods call through toEntityManager
methods when in OnUpdate code and codegen access throughComponentDataFromEntity
when inside ofEntities.ForEach
. SubScene
support for hybrid components, allowing Editor LiveLink (Player LiveLink is not supported yet).- Added
GameObjectConversionSettings.Systems
to allow users to explicitly specify what systems should be included in the conversion
Changed
- Fixed an issue where shared component filtering could be broken until the shared component data is manually set/added when using a deserialized world.
- Users can control the update behaviour of a
ComponentSystemGroup
via an update callback. See the documentation forComponentSystemGroup.UpdateCallback
, as well as examples inFixedRateUtils
. IDisposable
andICloneable
are now supported on managed components.World
now exposes aFlags
field allowing the editor to improve how it filters world to show in various tooling windows.World.Systems
is now a read only collection that does not allocate managed memory while being iterated over.- Updated package
com.unity.platforms
to version0.2.1-preview.4
.
Deprecated
- Property
World.AllWorlds
is now replaced byWorld.All
which now returns a read only collection that does not allocate managed memory while being iterated over.
Removed
- Removed expired API
implicit operator GameObjectConversionSettings(World)
- Removed expired API
implicit operator GameObjectConversionSettings(Hash128)
- Removed expired API
implicit operator GameObjectConversionSettings(UnityEditor.GUID)
- Removed expired API
TimeData.deltaTime
- Removed expired API
TimeData.time
- Removed expired API
TimeData.timeSinceLevelLoad
- Removed expired API
TimeData.captureFramerate
- Removed expired API
TimeData.fixedTime
- Removed expired API
TimeData.frameCount
- Removed expired API
TimeData.timeScale
- Removed expired API
TimeData.unscaledTime
- Removed expired API
TimeData.captureDeltaTime
- Removed expired API
TimeData.fixedUnscaledTime
- Removed expired API
TimeData.maximumDeltaTime
- Removed expired API
TimeData.realtimeSinceStartup
- Removed expired API
TimeData.renderedFrameCount
- Removed expired API
TimeData.smoothDeltaTime
- Removed expired API
TimeData.unscaledDeltaTime
- Removed expired API
TimeData.fixedUnscaledDeltaTime
- Removed expired API
TimeData.maximumParticleDeltaTime
- Removed expired API
TimeData.inFixedTimeStep
- Removed expired API
ComponentSystemBase.OnCreateManager()
- Removed expired API
ComponentSystemBase.OnDestroyManager()
- Removed expired API
ConverterVersionAttribute(int)
Fixed
- Non-moving children in transform hierarchies no longer trigger transform system updates.
- Fixed a bug where dynamic buffer components would sometimes leak during live link.
- Fixed crash that would occur if only method in a module was generated from a
[GenerateAuthoringComponent]
type. Entities.ForEach
now throws a correct error message when it is used with a delegate stored in a variable, field or returned from a method.- Fix IL2CPP compilation error with
Entities.ForEach
that uses a tag component andWithStructuralChanges
. Entities.ForEach
now marshals lambda parameters for DOTS Runtime when the lambda is burst compiled and has collection checks enabled. Previously usingEntityCommandBuffer
or other types with aDisposeSentinel
field as part of your lambda function (when using DOTS Runtime) may have resulted in memory access violation..Run()
onIJobChunk
may have dereferenced null or invalid chunk on filtered queries.
Security
- Throw correct error message if accessing
ToComponentDataArrayAsync
CopyFromComponentDataArray
orCopyFromComponentDataArrayAsync
from an unrelated query.
0.7.0-preview.19
[0.7.0] - 2020-03-03
Added
- Added
HasComponent
/GetComponent
/SetComponent
methods that streamline access to components through entities when using theSystemBase
class. These methods call through toEntityManager
methods when in OnUpdate code and codegen access throughComponentDataFromEntity
when inside ofEntities.ForEach
. SubScene
support for hybrid components, allowing Editor LiveLink (Player LiveLink is not supported yet).
Changed
- Fixed an issue where shared component filtering could be broken until the shared component data is manually set/added when using a deserialized world.
- Users can control the update behaviour of a
ComponentSystemGroup
via an update callback. See the documentation forComponentSystemGroup.UpdateCallback
, as well as examples inFixedRateUtils
. IDisposable
andICloneable
are now supported on managed components.World
now exposes aFlags
field allowing the editor to improve how it filters world to show in various tooling windows.World.Systems
is now a read only collection that does not allocate managed memory while being iterated over.- Updated package
com.unity.platforms
to version0.2.1-preview.4
.
Deprecated
- Property
World.AllWorlds
is now replaced byWorld.All
which now returns a read only collection that does not allocate managed memory while being iterated over.
Removed
- Removed expired API
implicit operator GameObjectConversionSettings(World)
- Removed expired API
implicit operator GameObjectConversionSettings(Hash128)
- Removed expired API
implicit operator GameObjectConversionSettings(UnityEditor.GUID)
- Removed expired API
TimeData.deltaTime
- Removed expired API
TimeData.time
- Removed expired API
TimeData.timeSinceLevelLoad
- Removed expired API
TimeData.captureFramerate
- Removed expired API
TimeData.fixedTime
- Removed expired API
TimeData.frameCount
- Removed expired API
TimeData.timeScale
- Removed expired API
TimeData.unscaledTime
- Removed expired API
TimeData.captureDeltaTime
- Removed expired API
TimeData.fixedUnscaledTime
- Removed expired API
TimeData.maximumDeltaTime
- Removed expired API
TimeData.realtimeSinceStartup
- Removed expired API
TimeData.renderedFrameCount
- Removed expired API
TimeData.smoothDeltaTime
- Removed expired API
TimeData.unscaledDeltaTime
- Removed expired API
TimeData.fixedUnscaledDeltaTime
- Removed expired API
TimeData.maximumParticleDeltaTime
- Removed expired API
TimeData.inFixedTimeStep
- Removed expired API
ComponentSystemBase.OnCreateManager()
- Removed expired API
ComponentSystemBase.OnDestroyManager()
- Removed expired API
ConverterVersionAttribute(int)
Fixed
- Non-moving children in transform hierarchies no longer trigger transform system updates.
- Fixed a bug where dynamic buffer components would sometimes leak during live link.
- Fixed crash that would occur if only method in a module was generated from a
[GenerateAuthoringComponent]
type. Entities.ForEach
now throws a correct error message when it is used with a delegate stored in a variable, field or returned from a method.- Fix IL2CPP compilation error with
Entities.ForEach
that uses a tag component andWithStructuralChanges
. Entities.ForEach
now marshals lambda parameters for DOTS Runtime when the lambda is burst compiled and has collection checks enabled. Previously usingEntityCommandBuffer
or other types with aDisposeSentinel
field as part of your lambda function (when using DOTS Runtime) may have resulted in memory access violation.- Throw correct error message if accessing
ToComponentDataArrayAsync
CopyFromComponentDataArray
orCopyFromComponentDataArrayAsync
from an unrelated query.
[0.6.0] - 2020-02-17
Added
- The
[GenerateAuthoringComponent]
attribute is now allowed on structs implementingIBufferElementData
. An authoring component is automatically generated to support adding aDynamicBuffer
of the type implementingIBufferElementData
to an entity. - Added new
SystemBase
base class for component systems. This new way of defining component systems manages dependencies for the user (manual dependency management is still possible by accessing theSystemBase.Dependency
field directly). - New
ScheduleParallel
methods inIJobChunk
andEntities.ForEach
(inSystemBase
) to make parallel scheduling of jobs explicit.ScheduleSingle
inIJobChunk
indicates scheduling work to be done in a non-parallel manner. - New editor workflow to quickly and easily build LiveLink player using the
BuildConfiguration
API. - Adds Live Link support for
GameObject
scenes. - The
SceneSystem
API now also loadsGameObject
scenes viaLoadSceneAsync
API. - Added new build component for LiveLink settings in
Unity.Scenes.Editor
to control how initial scenes are handled (LiveLink all, embed all, embed first). - Users can now inspect post-procssed IL code inside Unity Editor:
DOTS
->DOTS Compiler
->Open Inspector
Changed
- The package
com.unity.build
has been merged into the packagecom.unity.platforms
. As such, removed the dependency on[email protected]
and replaced it with[email protected]
. Please read the changelog ofcom.unity.platforms
for more details. - Managed components are now stored in a way that will generate less GC allocations when entities change archetype.
- Moved
Unity.Entities.ICustomBootstrap
from Unity.Entities.Hybrid to Unity.Entities. World.Dispose()
now completes all reader/writer jobs on theWorld
'sEntityManager
before releasing any resources, to avoid use-after-free errors.- Fix
AssemblyResolveException
when loading a project with dependent packages that are using Burst in static initializers orInitializeOnLoad
. .sceneWithBuildSettings
files that are stored in Assets/SceneDependencyCache are no longer rebuilt constantly. Because they are required for SubScene behaviour to work in the editor, if these are deleted they are recreated by OnValidate of the SubScene in the edited Scene. They should also be recreated on domain reload (restarting unity, entering/exiting playmode, etc).EntityQuery.cs
: Overloads ofCreateArchetypeChunkArray
,ToComponentDataArray
,ToEntityArray
, andCopyFromComponentDataArray
that return a JobHandle (allowing the work to be done asynchronously) have been renamed to addAsync
to the title (i.e.ToComponentDataArrayAsync
). The old overloads have been deprecated and an API Updater clause has been added.Entities.WithName
now only accepts names that use letters, digits, and underscores (not starting with a digit, no two consecutive underscores)- Updated package
com.unity.properties
to version0.10.4-preview
. - Updated package
com.unity.serialization
to version0.6.4-preview
. - The entity debugger now remembers whether chunk info panel is visible
- The entity debugger now displays the full name for nested types in the system list
- The entity debugger now sorts previously used filter components to the top of the filter GUI
- Bumped burst version to include the new features and fixes including:
- Fix an issue with function pointers being corrupted after a domain reload that could lead to hard crashes.
- Fix potential deadlock between Burst and the AssetDatabase if burst is being used when building the database.
Deprecated
- Method
GetBuildSettingsComponent
on classGameObjectConversionSystem
has been renamed toGetBuildConfigurationComponent
. - Method
TryGetBuildSettingsComponent
on classGameObjectConversionSystem
has been renamed toTryGetBuildConfigurationComponent
. - Member
BuildSettings
on classGameObjectConversionSettings
has been renamed toBuildConfiguration
. - Member
BuildSettingsGUID
on classSceneSystem
has been renamed toBuildConfigurationGUID
.
Removed
- Removed expired API
SceneSectionData.SharedComponentCount
- Removed expired API
struct SceneData
- Removed expired API
SubScene._SceneEntities
- Removed expired API
World.Active
Fixed
- Ability to open and close SubScenes from the scene hierarchy window (Without having to move cursor to inspector window).
- Ability to create a new empty Sub Scene without first creating a game object.
- Improve performance of SubScene loading and change tracking in the editor.
- Fixed regression where
GetSingleton
would create a new query on every call. - Fixed SubScenes trying to load an already loaded AssetBundle when loaded multiple times on the same player, but with different Worlds.
- Make it clear that SubScenes in Prefabs are not supported.
- Lambda job codegen tests now fail if the error message does not contain the expected contents.
- Improved performance of setting up the world required for game object conversion
- The
chunkIndex
parameter passed toIJobChunk.Execute()
now has the correct value. - Fixed an error which caused entities with
ISystemStateSharedComponentData
components to not be cleaned up correctly. - Managed components containing
Entity
fields will now correctly serialize. - Fixed issue where
BlobAssetVerifier
will throw error if it can't resolve a type. - Exposed the Managed Component extensions for
EntityQuery
. Entities.ForEach
now identifies whenthis
of the enclosing system is captured due to calling an extension method on it when compilation fails since the lambda was emitted as a member functionEntities.ForEach
now reports when a field of the outer system is captured and used by reference when compilation fails since the lambda was emitted as a member functionEntities.ForEach
does not erronously point to calling static functions as the source of the error when compilation fails since the lambda was emitted as a member function- Debugging inside of
Entities.ForEach
with Visual Studio 2017/2019 (some debugging features will need an upcoming update of the com.unity.ide.v...
0.6.0-preview.24
[0.6.0] - 2020-02-17
Added
- The
[GenerateAuthoringComponent]
attribute is now allowed on structs implementingIBufferElementData
. An authoring component is automatically generated to support adding aDynamicBuffer
of the type implementingIBufferElementData
to an entity. - Added new
SystemBase
base class for component systems. This new way of defining component systems manages dependencies for the user (manual dependency management is still possible by accessing theSystemBase.Dependency
field directly). - New
ScheduleParallel
methods inIJobChunk
andEntities.ForEach
(inSystemBase
) to make parallel scheduling of jobs explicit.ScheduleSingle
inIJobChunk
indicates scheduling work to be done in a non-parallel manner. - New editor workflow to quickly and easily build LiveLink player using the
BuildConfiguration
API. - Adds Live Link support for
GameObject
scenes. - The
SceneSystem
API now also loadsGameObject
scenes viaLoadSceneAsync
API. - Added new build component for LiveLink settings in
Unity.Scenes.Editor
to control how initial scenes are handled (LiveLink all, embed all, embed first). - Users can now inspect post-procssed IL code inside Unity Editor:
DOTS
->DOTS Compiler
->Open Inspector
Changed
- The package
com.unity.build
has been merged into the packagecom.unity.platforms
. As such, removed the dependency on[email protected]
and replaced it with[email protected]
. Please read the changelog ofcom.unity.platforms
for more details. - Managed components are now stored in a way that will generate less GC allocations when entities change archetype.
- Moved
Unity.Entities.ICustomBootstrap
from Unity.Entities.Hybrid to Unity.Entities. World.Dispose()
now completes all reader/writer jobs on theWorld
'sEntityManager
before releasing any resources, to avoid use-after-free errors.- Fix
AssemblyResolveException
when loading a project with dependent packages that are using Burst in static initializers orInitializeOnLoad
. .sceneWithBuildSettings
files that are stored in Assets/SceneDependencyCache are no longer rebuilt constantly. Because they are required for SubScene behaviour to work in the editor, if these are deleted they are recreated by OnValidate of the SubScene in the edited Scene. They should also be recreated on domain reload (restarting unity, entering/exiting playmode, etc).EntityQuery.cs
: Overloads ofCreateArchetypeChunkArray
,ToComponentDataArray
,ToEntityArray
, andCopyFromComponentDataArray
that return a JobHandle (allowing the work to be done asynchronously) have been renamed to addAsync
to the title (i.e.ToComponentDataArrayAsync
). The old overloads have been deprecated and an API Updater clause has been added.Entities.WithName
now only accepts names that use letters, digits, and underscores (not starting with a digit, no two consecutive underscores)- Updated package
com.unity.properties
to version0.10.4-preview
. - Updated package
com.unity.serialization
to version0.6.4-preview
. - The entity debugger now remembers whether chunk info panel is visible
- The entity debugger now displays the full name for nested types in the system list
- The entity debugger now sorts previously used filter components to the top of the filter GUI
- Bumped burst version to include the new features and fixes including:
- Fix an issue with function pointers being corrupted after a domain reload that could lead to hard crashes.
- Fix potential deadlock between Burst and the AssetDatabase if burst is being used when building the database.
Deprecated
- Method
GetBuildSettingsComponent
on classGameObjectConversionSystem
has been renamed toGetBuildConfigurationComponent
. - Method
TryGetBuildSettingsComponent
on classGameObjectConversionSystem
has been renamed toTryGetBuildConfigurationComponent
. - Member
BuildSettings
on classGameObjectConversionSettings
has been renamed toBuildConfiguration
. - Member
BuildSettingsGUID
on classSceneSystem
has been renamed toBuildConfigurationGUID
.
Removed
- Removed expired API
SceneSectionData.SharedComponentCount
- Removed expired API
struct SceneData
- Removed expired API
SubScene._SceneEntities
- Removed expired API
World.Active
Fixed
- Ability to open and close SubScenes from the scene hierarchy window (Without having to move cursor to inspector window).
- Ability to create a new empty Sub Scene without first creating a game object.
- Improve performance of SubScene loading and change tracking in the editor.
- Fixed regression where
GetSingleton
would create a new query on every call. - Fixed SubScenes trying to load an already loaded AssetBundle when loaded multiple times on the same player, but with different Worlds.
- Make it clear that SubScenes in Prefabs are not supported.
- Lambda job codegen tests now fail if the error message does not contain the expected contents.
- Improved performance of setting up the world required for game object conversion
- The
chunkIndex
parameter passed toIJobChunk.Execute()
now has the correct value. - Fixed an error which caused entities with
ISystemStateSharedComponentData
components to not be cleaned up correctly. - Managed components containing
Entity
fields will now correctly serialize. - Fixed issue where
BlobAssetVerifier
will throw error if it can't resolve a type. - Exposed the Managed Component extensions for
EntityQuery
. Entities.ForEach
now identifies whenthis
of the enclosing system is captured due to calling an extension method on it when compilation fails since the lambda was emitted as a member functionEntities.ForEach
now reports when a field of the outer system is captured and used by reference when compilation fails since the lambda was emitted as a member functionEntities.ForEach
does not erronously point to calling static functions as the source of the error when compilation fails since the lambda was emitted as a member function- Debugging inside of
Entities.ForEach
with Visual Studio 2017/2019 (some debugging features will need an upcoming update of the com.unity.ide.visualstudio package). EntityQuery.ToComponentArray<T>
withT
deriving fromUnityEngine.Component
now correctly collects all data in a chunk- Fixed an issue with
ComponentSystemBase.GetEntityQuery
andEntityManager.CreateEntityQuery
calls made withEntityQueryDesc
not respecting read-only permissions.
[0.5.1] - 2020-01-28
Changed
- Constructor-related exceptions thrown during
World.CreateSystem
will now included the inner exception details. DefaultWorldInitialization.GetAllSystems
now returnsIReadOnlyList<Type>
instead ofList<Type>
DefaultWorldInitialization.AddSystemsToRootLevelSystemGroups
now takesIEnumerable<Type>
instead ofList<Type>
Fixed
- Fixed an issue where
BlobAssetReference
types was not guaranteed to be 8-byte aligned on all platforms which could result in failing to read Blob data in components correctly on 32-bit platforms. - Fixed issue in
MinMaxAABB.Equals()
comparingMin
to itself rather thanother
. Entities.ForEach
now properly treatsin
parameters ofDynamicBuffer
type as read-only- Fixed potential crash caused by a leaked job after an exception is thrown during a call to
IJobChunk.Schedule
. - Fixed regression in
ComponentSystemBase.GetSingleton()
where a new query would be created every timee the function is called.
0.5.1-preview.11
[0.5.1] - 2020-01-28
Fixed
- Constructor-related exceptions thrown during
World.CreateSystem
will now included the inner exception details. - Fixed an issue where
BlobAssetReference
types was not guaranteed to be 8-byte aligned on all platforms which could result in failing to read Blob data in components correctly on 32-bit platforms. - Fixed issue in MinMaxAABB Equals() comparing Min to itself rather than other.
Entities.ForEach
now properly treatsin
parameters ofDynamicBuffer
type as read-only- Fixed potential crash caused by a leaked job after an exception is thrown during a call to
IJobChunk.Schedule
. DefaultWorldInitialization.GetAllSystems
now returnsIReadOnlyList<Type>
instead ofList<Type>
DefaultWorldInitialization.AddSystemsToRootLevelSystemGroups
now takesIEnumerable<Type>
instead ofList<Type>
Changed
- Updated dependencies for this package.
[0.5.0] - 2020-01-16
Added
- Added AndroidHybrid.buildpipeline with RunStepAndroid
- EntityManager.MoveEntitiesFrom now has the full method overload combination of output, filter, remapping parameters.
Changed
Entities.WithReadOnly
,Entities.WithNativeDisableParallelForRestriction
,Entities.WithDeallocateOnJobCompletion
,Entities.WithNativeDisableSafetyRestriction
andEntities.WithNativeDisableUnsafePtrRestriction
now check their argument types for the proper attributes ([NativeContainer]
,[NativeContainerSupportsDeallocateOnJobCompletion]
) at compile time and throw an error when used on a field of a user defined type.- Log entries emitted during subscene conversion without a context object are now displayed in the subscene inspector instead of discarded
Deprecated
- Adding removal dates to the API that have been deprecated but did not have the date set.
BlobAssetReference<T>
:Release()
was deprecated, useDispose()
instead.
Removed
EntityQuery.cs
: Removed expired APICalculateLength()
,SetFilter()
andSetFilterChanged()
.
Fixed
- Fixed an issue where trying to perform EntityRemapping on Managed Components could throw if a component field was null.
- EntityManager.MoveEntitiesFrom with query was not bumping shared component versions, order versions or dirty versions correctly. Now it does.
- Fixed that adding a Sub Scene component from the Add Components dropdown was not reflected in the Hierarchy.
- Fixed so that Undo/Redo of changes to SceneAsset objectfield in the Sub Scene Inspector is reflected in the Hierarchy.
- Make it clear when Sub Scene duplicates are present: shown in Hierarchy and by showing a warning box in the Inspector.
- Support Undo for 'Create Sub Scene From Selection' context menu item.
- Better file name error handling for the 'New Sub Scene From Selection' context menu item.
- Keep sibling order for new Sub Scene when created using 'New Sub Scene From Selection' (prevents the new Sub Scene from ending as the last sibling).
- Handle if selection contains part of a Prefab instance when creating Sub Scene from Selection.
- Fix dangling loaded Sub Scenes not visualized in the Hierarchy when removing Scene Asset reference in Sub Scene component.
- Fixed an issue with invalid IL generated by Entities.ForEach when structs are captured as locals from two different scopes and their fields are accessed.
- Make it clear in the Hierarchy and Sub Scene Inspector that nesting Sub Scenes is not yet supported.
- Fixed an issue with BinaryWriter where serializing a System.String[] with a single element would throw an exception.
- Fixed an issue with
ComponentSystem.GetEntityQuery
andJobComponentSystem.GetEntityQuery
which caused improper caching of queries when using "None" or "Any" fields.
0.5.0-preview.17
[0.5.0] - 2020-01-16
Added
- Added AndroidHybrid.buildpipeline with RunStepAndroid
- EntityManager.MoveEntitiesFrom now has the full method overload combination of output, filter, remapping parameters.
Changed
Entities.WithReadOnly
,Entities.WithNativeDisableParallelForRestriction
,Entities.WithDeallocateOnJobCompletion
,Entities.WithNativeDisableSafetyRestriction
andEntities.WithNativeDisableUnsafePtrRestriction
now check their argument types for the proper attributes ([NativeContainer]
,[NativeContainerSupportsDeallocateOnJobCompletion]
) at compile time and throw an error when used on a field of a user defined type.- Log entries emitted during subscene conversion without a context object are now displayed in the subscene inspector instead of discarded
Deprecated
- Adding removal dates to the API that have been deprecated but did not have the date set.
BlobAssetReference<T>
:Release()
was deprecated, useDispose()
instead.
Removed
EntityQuery.cs
: Removed expired APICalculateLength()
,SetFilter()
andSetFilterChanged()
.
Fixed
- Fixed an issue where trying to perform EntityRemapping on Managed Components could throw if a component field was null.
- EntityManager.MoveEntitiesFrom with query was not bumping shared component versions, order versions or dirty versions correctly. Now it does.
- Fixed that adding a Sub Scene component from the Add Components dropdown was not reflected in the Hierarchy.
- Fixed so that Undo/Redo of changes to SceneAsset objectfield in the Sub Scene Inspector is reflected in the Hierarchy.
- Make it clear when Sub Scene duplicates are present: shown in Hierarchy and by showing a warning box in the Inspector.
- Support Undo for 'Create Sub Scene From Selection' context menu item.
- Better file name error handling for the 'New Sub Scene From Selection' context menu item.
- Keep sibling order for new Sub Scene when created using 'New Sub Scene From Selection' (prevents the new Sub Scene from ending as the last sibling).
- Handle if selection contains part of a Prefab instance when creating Sub Scene from Selection.
- Fix dangling loaded Sub Scenes not visualized in the Hierarchy when removing Scene Asset reference in Sub Scene component.
- Fixed an issue with invalid IL generated by Entities.ForEach when structs are captured as locals from two different scopes and their fields are accessed.
- Make it clear in the Hierarchy and Sub Scene Inspector that nesting Sub Scenes is not yet supported.
- Fixed an issue with BinaryWriter where serializing a System.String[] with a single element would throw an exception.
- Fixed an issue with
ComponentSystem.GetEntityQuery
andJobComponentSystem.GetEntityQuery
which caused improper caching of queries when using "None" or "Any" fields.
[0.4.0] - 2019-12-16
This version requires Unity 2019.3.0f1+
New Features
- Two new methods added to the public API:
void EntityCommandBuffer.AddComponent<T>(EntityQuery entityQuery)
void EntityCommandBuffer.RemoveComponent<T>(EntityQuery entityQuery)
- BlobArray, BlobString & BlobPtr are not allowed to be copied by value since they carry offset pointers that aree relative to the location of the memory. This could easily result in programming mistakes. The compiler now prevents incorrect usage by enforcing any type attributed with [MayOnlyLiveInBlobStorage] to never be copied by value.
Upgrade guide
Changes
-
Deprecates
TypeManager.CreateTypeIndexForComponent
and it's other component type variants. Types can be dynamically added (in Editor builds) by instead passing the new unregistered types toTypeManager.AddNewComponentTypes
instead. -
RequireForUpdate(EntityQuery)
andRequireSingletonForUpdate
on a system with[AlwaysUpdate]
will now throw an exception instead of being ignored. -
ChangeVersionUtility.IncrementGlobalSystemVersion & ChangeVersionUtility.InitialGlobalSystemVersion is now internal. They were accidentally public previously.
-
Entity inspector now shows entity names and allows to rename the selected entity
-
Improved entity debugger UI
-
Create WorldRenderBounds for prefabs and disabled entities with renderers during conversion, this make instantiation of those entities significantly faster.
-
Reduced stack depth of System.Update / OnUpdate method (So it looks better in debugger)
-
Assert when using EntityQuery from another world
-
Using an EntityQuery created in one world on another world was resulting in memory corruption. We now detect it in the EntityManager API and throw an argument exception
-
Structural changes now go through a bursted codepath and are significantly faster
-
DynamicBuffer.Capacity is now settable
Fixes
- Remove unnecessary & incorrect warning in DeclareReferencedPrefab when the referenced game object is a scene object
- GameObjects with ConvertAndInject won't get detached from a non-converted parent (fixes regression)
- Fixed a crash that could occur when destroying an entity with an empty LinkedEntityGroup.
- Updated performance package dependency to 1.3.2 which fixes an obsoletion warning
- The
EntityCommandBuffer
can be replayed repeatedly. - Fixed exception in entity binary scene serialization when referencing a null UnityEngine.Object from a shared component
- Moving scripts between assemblies now triggers asset bundle rebuilds where necessary for live link
- Fixed LiveLink on Android
0.4.0-preview.10
[0.4.0] - 2019-12-16
This version requires Unity 2019.3.0f1+
New Features
- Two new methods added to the public API:
void EntityCommandBuffer.AddComponent<T>(EntityQuery entityQuery)
void EntityCommandBuffer.RemoveComponent<T>(EntityQuery entityQuery)
- BlobArray, BlobString & BlobPtr are not allowed to be copied by value since they carry offset pointers that aree relative to the location of the memory. This could easily result in programming mistakes. The compiler now prevents incorrect usage by enforcing any type attributed with [MayOnlyLiveInBlobStorage] to never be copied by value.
Upgrade guide
Changes
-
Deprecates
TypeManager.CreateTypeIndexForComponent
and it's other component type variants. Types can be dynamically added (in Editor builds) by instead passing the new unregistered types toTypeManager.AddNewComponentTypes
instead. -
RequireForUpdate(EntityQuery)
andRequireSingletonForUpdate
on a system with[AlwaysUpdate]
will now throw an exception instead of being ignored. -
ChangeVersionUtility.IncrementGlobalSystemVersion & ChangeVersionUtility.InitialGlobalSystemVersion is now internal. They were accidentally public previously.
-
Entity inspector now shows entity names and allows to rename the selected entity
-
Improved entity debugger UI
-
Create WorldRenderBounds for prefabs and disabled entities with renderers during conversion, this make instantiation of those entities significantly faster.
-
Reduced stack depth of System.Update / OnUpdate method (So it looks better in debugger)
-
Assert when using EntityQuery from another world
-
Using an EntityQuery created in one world on another world was resulting in memory corruption. We now detect it in the EntityManager API and throw an argument exception
-
Structural changes now go through a bursted codepath and are significantly faster
-
DynamicBuffer.Capacity is now settable
Fixes
- Remove unnecessary & incorrect warning in DeclareReferencedPrefab when the referenced game object is a scene object
- GameObjects with ConvertAndInject won't get detached from a non-converted parent (fixes regression)
- Fixed a crash that could occur when destroying an entity with an empty LinkedEntityGroup.
- Updated performance package dependency to 1.3.2 which fixes an obsoletion warning
- The
EntityCommandBuffer
can be replayed repeatedly. - Fixed exception in entity binary scene serialization when referencing a null UnityEngine.Object from a shared component
- Moving scripts between assemblies now triggers asset bundle rebuilds where necessary for live link
- Fixed LiveLink on Android
[0.3.0] - 2019-12-03
New Features
- ENABLE_SIMPLE_SYSTEM_DEPENDENCIES define can now be used to replace the automatic dependency chaining with a much simplified strategy. With ENABLE_SIMPLE_SYSTEM_DEPENDENCIES it simply chains jobs in the order of the systems against previous jobs. Without ENABLE_SIMPLE_SYSTEM_DEPENDENCIES, dependencies are automatically chained based on read / write access of component data of each system. In cases when there game code is forced to very few cores or there are many systems, this can improve performance since it reduces overhead in calculating optimal dependencies.
- Added
DebuggerTypeProxy
forMultiListEnumerator<T>
(e.g. this makes the results ofGameObjectConversionSystem.GetEntities
calls readable in the debugger) - Two new methods added to the public API:
- EntityManager.CreateEntity(Archetype type, int count, Allocator allocator);
- EntityManager.Instantiate(Entity entity, int count, Allocator allocator);
Both methods return aNativeArray<Entity>
.
Changes
Removed the following deprecated API as announced in/before 0.1.1-preview
:
- From GameObjectConversionUtility.cs:
ConvertIncrementalInitialize()
andConvertScene()
. - From Translation.cs:
struct Position
. - From EditorEntityScenes.cs:
WriteEntityScene()
. - From GameObjectConversionSystem.cs:
AddReferencedPrefab()
,AddDependency()
,AddLinkedEntityGroup()
,DstWorld
. - From DefaultWorld.cs:
class EndPresentationEntityCommandBufferSystem
.
Fixes
- ConvertAndInject won't destroy the root GameObject anymore (fixes regression introduced in 0.2.0)
- Fix Android/iOS build when using new build pipeline
- Provide correct application extension apk, aab or empty for project export when building to Android
0.3.0-preview.4
[0.3.0] - 2019-12-03
New Features
- ENABLE_SIMPLE_SYSTEM_DEPENDENCIES define can now be used to replace the automatic dependency chaining with a much simplified strategy. With ENABLE_SIMPLE_SYSTEM_DEPENDENCIES it simply chains jobs in the order of the systems against previous jobs. Without ENABLE_SIMPLE_SYSTEM_DEPENDENCIES, dependencies are automatically chained based on read / write access of component data of each system. In cases when there game code is forced to very few cores, this can improve performance since it reduces overhead in calculating optimal dependencies.
- Two new methods added to the public API:
- EntityManager.CreateEntity(Archetype type, int count, Allocator allocator);
- EntityManager.Instantiate(Entity entity, int count, Allocator allocator);
Both methods return aNativeArray<Entity>
.
Changes
Removed the following deprecated API as announced in/before 0.1.1-preview
:
- From GameObjectConversionUtility.cs:
ConvertIncrementalInitialize()
andConvertScene()
. - From Translation.cs:
struct Position
. - From EditorEntityScenes.cs:
WriteEntityScene()
. - From GameObjectConversionSystem.cs:
AddReferencedPrefab()
,AddDependency()
,AddLinkedEntityGroup()
,DstWorld
. - From DefaultWorld.cs:
class EndPresentationEntityCommandBufferSystem
.
Fixes
- ConvertAndInject won't destroy the root GameObject anymore (fixes regression introduced in 0.2.0)
- Fix Android build when using new build pipeline
- Provide correct application extension apk, aab or empty for project export
- Set package name to be com.UnityTechnologies.Samples
- Set API Compatibility to be .NET Standard 2.0
[0.2.0] - 2019-11-22
This version requires Unity 2019.3 0b11+
New Features
-
Automatically generate authoring components for IComponentData with IL post-processing. Any component data marked with a GenerateAuthoringComponent attribute will generate the corresponding authoring MonoBehaviour with a Convert method.
-
BuildSettings assets are now used to define a single build recipe asset on disk. This gives full control over the build pipeline in a modular way from C# code.
- BuildSettings let you attach builtin or your own custom IBuildSettingsComponents for full configurability
- BuildPipelines let you define the exact IBuildStep that should be run and in which order
- IBuildStep is either builtin or your own custom build step
- BuildSettings files can be inherited so you can easily make base build settings with most configuration complete and then do minor adjustments per build setting
- Right now most player configuration is still in the existing PlayerSettings, our plan is to over time expose all Player Settings via BuildSettings as well to ease configuration of complex projects with many build recipes & artifacts
-
SubScenes are now automatically converted to entity binary files & cached by the asset pipeline. The entity cache files previously present in the project folder should be removed. Conversion systems can use the ConverterVersion attribute to convert to trigger a reconversion if the conversion system has changed behaviour. The conversion happens asynchronously in another process. Thus on first open the subscenes might not show up immediately.
-
Live link builds can be built with the new BuildSettings pipeline.
Open sub scene- Closed Entity scenes are built by the asset pipeline and loaded via livelink on demand
- Opened Entity scenes are send via live entity patcher with patches on a per component / entity basis based on what has changed
- Assets referenced by entity scenes are transferred via livelink when saving the asset
- Scenes loaded as game objects are currently not live linked (This is in progress)
by assigning the LiveLink build pipeline
-
Entities.ForEach
syntax for supplying jobified code in aJobComponentSystem
'sOnUpdate
method directly by using a lambda (instead of supplying an additionalIJobForEach
). -
EntityQueryMask
has been added, which allows for quick confirmation of if an Entity would be returned by anEntityQuery
without filters viaEntityQueryMask.Matches(Entity entity)
. An EntityQueryMask can be obtained by callingEntityManager.GetEntityQueryMask(EntityQuery query).
-
Unity Entities now supports the Fast Enter playmode which can be enabled in the project settings. It is recommended to be turned on for all dots projects.
-
The UnityEngine component
StopConvertToEntity
can be used to interruptConvertToEntity
recursion, and should be preferred over aConvertToEntity
set to "convert and inject" for that purpose. -
EntityDebugger now shows IDs in a separate column, so you can still see them when entities have custom names
-
Entity references in the Entity Inspector have a "Show" button which will select the referenced Entity in the Debugger.
-
An
ArchetypeChunkIterator
can be created by callingGetArchetypeChunkIterator
on anEntityQuery
. You may run anIJobChunk
while bypassing the Jobs API by passing anArchetypeChunkIterator
intoIJobChunk.RunWithoutJobs()
. -
The
[AlwaysSynchronizeSystem]
attribute has been added, which can be applied to aJobComponentSystem
to force it to synchronize on all of its dependencies before every update. -
BoneIndexOffset
has been added, which allows the Animation system to communicate a bone index offset to the Hybrid Renderer. -
Initial support for using Hybrid Components during conversion, see the HybridComponent sample in the StressTests folder.
-
New
GameObjectConversionSystem.ForkSettings()
that provides a very specialized method for creating a fork of the current conversion settings with a different "EntityGuid namespace", which can be used for nested conversions. This is useful for example in net code where multiple root-level variants of the same authoring object need to be created in the destination world. -
EntityManager
LockChunkOrder
andUnlockChunkOrder
are deprecated. -
Entity Scenes can be loaded synchronously (during the next streaming system update) by using
SceneLoadFlags.BlockOnStreamIn
inSceneSystem.LoadParameters
. -
EntityCommandBuffer
can now be played back on anExclusiveEntityTransaction
as well as anEntityManager
. This allows ECB playback to be invoked from a job (though exclusive access to the EntityManager data is still required for the duration of playback).
Upgrade guide
- If you are using SubScenes you must use the new BuildSettings assets to make a build & run it. SubScenes are not supported from the File -> BuildSettings... & File -> Build and Run workflows.
- Entities requires AssetDatabase V2 for certain new features, we do not provide support for AssetDatabase V1.
Fixes
- Setting
ComponentSystemGroup.Enabled
tofalse
now callsOnStopRunning()
recursively on the group's member systems, not just on the group itself. - Updated Properties pacakge to
0.10.3-preview
to fix an exception when showing Physics ComponentData in the inspector as well as fix IL2CPP Ahead of Time linker errors for generic virtual function calls. - The
LocalToParentSystem
will no longer write to theLocalToWorld
component of entities that have a component with theWriteGroup(typeof(LocalToWorld))
. - Entity Debugger styling work better with Pro theme
- Entity Inspector no longer has runaway indentation
- Fixed issue where
AddSharedComponentData
,SetSharedComponentData
did not always updateSharedComponentOrderVersion
. - Fixes serialization issue when reading in managed
IComponentData
containing array types andUnityEngine.Object
references. - No exception is thrown when re-adding a tag component with
EntityQuery
. AddComponent<T>(NativeArray<Entity>)
now reliably throws anArgumentException
if any of the target entities are invalid.- Fixed an issue where the Entity Debugger would not repaint in edit mode
- Marking a system as
[UpdateInGroup(typeof(LateSimulationSystemGroup))]
no longer emits a warning about[DisableAutoCreation]
. - Fixed rendering of chunk info to be compatible with HDRP
- Fixed issue where
ToComponentDataArray
ignored the filter settings on theEntityQuery
for managed component types.
Changes
- Moved
NativeString
code from Unity.Entities to Unity.Collections. - Updated dependencies for this package.
- Significantly improved
Entity
instantiation performance when running in-Editor. - Added support for managed
IComponentData
types such asclass MyComponent : IComponentData {}
which allows managed types such as GameObjects or List<>s to be stored in components. Users should use managed components sparingly in production code when possible as these components cannot be used by the Job System or archetype chunk storage and thus will be significantly slower to work with. Refer to the documentation for component data for more details on managed component use, implications and prevention. - 'SubSceneStreamingSystem' has been renamed to
SceneSectionStreamingSystem
and is now internal - Deprecated
_SceneEntities
inSubScene.cs
. Please useSceneSystem.LoadAsync
/Unload
with the respective SceneGUID instead. This API will be removed after 2019-11-22. - Updated
com.unity.serialization
to0.6.3-preview
. - The deprecated
GetComponentGroup()
APIs are nowprotected
and can only be called from inside a System like theirGetEntityQuery()
successors. - All GameObjects with a ConvertToEntity set to "Convert and Destroy" will all be processed within the same conversion pass, this allows cross-referencing.
- Duplicate component adds are always ignored
- When adding component to single entity via EntityQuery, entity is moved to matching chunk instead of chunk achetype changing.
- "Used by Systems" list skips queries with filters
- Managed
IComponentData
no longer require all fields to be non-null after default construction. ISharedComponentData
is serialized inline with entity and managed ...
0.2.0-preview.18
[0.2.0] - 2019-11-22
This version requires Unity 2019.3 0b11+
New Features
-
Automatically generate authoring components for IComponentData with IL post-processing. Any component data marked with a GenerateAuthoringComponent attribute will generate the corresponding authoring MonoBehaviour with a Convert method.
-
BuildSettings assets are now used to define a single build recipe asset on disk. This gives full control over the build pipeline in a modular way from C# code.
- BuildSettings let you attach builtin or your own custom IBuildSettingsComponents for full configurability
- BuildPipelines let you define the exact IBuildStep that should be run and in which order
- IBuildStep is either builtin or your own custom build step
- BuildSettings files can be inherited so you can easily make base build settings with most configuration complete and then do minor adjustments per build setting
- Right now most player configuration is still in the existing PlayerSettings, our plan is to over time expose all Player Settings via BuildSettings as well to ease configuration of complex projects with many build recipes & artifacts
-
SubScenes are now automatically converted to entity binary files & cached by the asset pipeline. The entity cache files previously present in the project folder should be removed. Conversion systems can use the ConverterVersion attribute to convert to trigger a reconversion if the conversion system has changed behaviour. The conversion happens asynchronously in another process. Thus on first open the subscenes might not show up immediately.
-
Live link builds can be built with the new BuildSettings pipeline.
Open sub scene- Closed Entity scenes are built by the asset pipeline and loaded via livelink on demand
- Opened Entity scenes are send via live entity patcher with patches on a per component / entity basis based on what has changed
- Assets referenced by entity scenes are transferred via livelink when saving the asset
- Scenes loaded as game objects are currently not live linked (This is in progress)
by assigning the LiveLink build pipeline
-
Entities.ForEach
syntax for supplying jobified code in aJobComponentSystem
'sOnUpdate
method directly by using a lambda (instead of supplying an additionalIJobForEach
). -
EntityQueryMask
has been added, which allows for quick confirmation of if an Entity would be returned by anEntityQuery
without filters viaEntityQueryMask.Matches(Entity entity)
. An EntityQueryMask can be obtained by callingEntityManager.GetEntityQueryMask(EntityQuery query).
-
Unity Entities now supports the Fast Enter playmode which can be enabled in the project settings. It is recommended to be turned on for all dots projects.
-
The UnityEngine component
StopConvertToEntity
can be used to interruptConvertToEntity
recursion, and should be preferred over aConvertToEntity
set to "convert and inject" for that purpose. -
EntityDebugger now shows IDs in a separate column, so you can still see them when entities have custom names
-
Entity references in the Entity Inspector have a "Show" button which will select the referenced Entity in the Debugger.
-
An
ArchetypeChunkIterator
can be created by callingGetArchetypeChunkIterator
on anEntityQuery
. You may run anIJobChunk
while bypassing the Jobs API by passing anArchetypeChunkIterator
intoIJobChunk.RunWithoutJobs()
. -
The
[AlwaysSynchronizeSystem]
attribute has been added, which can be applied to aJobComponentSystem
to force it to synchronize on all of its dependencies before every update. -
BoneIndexOffset
has been added, which allows the Animation system to communicate a bone index offset to the Hybrid Renderer. -
Initial support for using Hybrid Components during conversion, see the HybridComponent sample in the StressTests folder.
-
New
GameObjectConversionSystem.ForkSettings()
that provides a very specialized method for creating a fork of the current conversion settings with a different "EntityGuid namespace", which can be used for nested conversions. This is useful for example in net code where multiple root-level variants of the same authoring object need to be created in the destination world. -
EntityManager
LockChunkOrder
andUnlockChunkOrder
are deprecated. -
Entity Scenes can be loaded synchronously (during the next streaming system update) by using
SceneLoadFlags.BlockOnStreamIn
inSceneSystem.LoadParameters
. -
EntityCommandBuffer
can now be played back on anExclusiveEntityTransaction
as well as anEntityManager
. This allows ECB playback to be invoked from a job (though exclusive access to the EntityManager data is still required for the duration of playback).
Upgrade guide
- If you are using SubScenes you must use the new BuildSettings assets to make a build & run it. SubScenes are not supported from the File -> BuildSettings... & File -> Build and Run workflows.
- Entities requires AssetDatabase V2 for certain new features, we do not provide support for AssetDatabase V1.
Fixes
- Setting
ComponentSystemGroup.Enabled
tofalse
now callsOnStopRunning()
recursively on the group's member systems, not just on the group itself. - Updated Properties pacakge to
0.10.3-preview
to fix an exception when showing Physics ComponentData in the inspector as well as fix IL2CPP Ahead of Time linker errors for generic virtual function calls. - The
LocalToParentSystem
will no longer write to theLocalToWorld
component of entities that have a component with theWriteGroup(typeof(LocalToWorld))
. - Entity Debugger styling work better with Pro theme
- Entity Inspector no longer has runaway indentation
- Fixed issue where
AddSharedComponentData
,SetSharedComponentData
did not always updateSharedComponentOrderVersion
. - Fixes serialization issue when reading in managed
IComponentData
containing array types andUnityEngine.Object
references. - No exception is thrown when re-adding a tag component with
EntityQuery
. AddComponent<T>(NativeArray<Entity>)
now reliably throws anArgumentException
if any of the target entities are invalid.- Fixed an issue where the Entity Debugger would not repaint in edit mode
- Marking a system as
[UpdateInGroup(typeof(LateSimulationSystemGroup))]
no longer emits a warning about[DisableAutoCreation]
. - Fixed rendering of chunk info to be compatible with HDRP
- Fixed issue where
ToComponentDataArray
ignored the filter settings on theEntityQuery
for managed component types.
Changes
- Moved
NativeString
code from Unity.Entities to Unity.Collections. - Updated dependencies for this package.
- Significantly improved
Entity
instantiation performance when running in-Editor. - Added support for managed
IComponentData
types such asclass MyComponent : IComponentData {}
which allows managed types such as GameObjects or List<>s to be stored in components. Users should use managed components sparingly in production code when possible as these components cannot be used by the Job System or archetype chunk storage and thus will be significantly slower to work with. Refer to the documentation for component data for more details on managed component use, implications and prevention. - 'SubSceneStreamingSystem' has been renamed to
SceneSectionStreamingSystem
and is now internal - Deprecated
_SceneEntities
inSubScene.cs
. Please useSceneSystem.LoadAsync
/Unload
with the respective SceneGUID instead. This API will be removed after 2019-11-22. - Updated
com.unity.serialization
to0.6.3-preview
. - The deprecated
GetComponentGroup()
APIs are nowprotected
and can only be called from inside a System like theirGetEntityQuery()
successors. - All GameObjects with a ConvertToEntity set to "Convert and Destroy" will all be processed within the same conversion pass, this allows cross-referencing.
- Duplicate component adds are always ignored
- When adding component to single entity via EntityQuery, entity is moved to matching chunk instead of chunk achetype changing.
- "Used by Systems" list skips queries with filters
- Managed
IComponentData
no longer require all fields to be non-null after default construction. ISharedComponentData
is serialized inline with entity and managedIComponentData
. If a shared component references aUnityEngine.Object
type, that type is serialized separately in an "objrefs" resource asset.EntityManager
callsEntityComponentStore
via burst delegates forAdd
/Remove
components.EntityComponentStore
cannot throw exceptions (since called as burst delegate from main thread.)bool ICustomBootstrap.Initialize(string defaultWorldName)
has changed API with no deprecated fallback. It now simply gives you a chance to completely replace the default world initialization by returning true.ICustomBootstrap
&DefaultWorldInitialization
is now composable like this:
class MyCustomBootStrap : ICustomBootstrap
{
public bool Initialize(string defaultWorldName)
{
Debug.Log("Executing bootstrap");
var world = new World("Custom world");
World.DefaultGameObjectInjectionWorld = world;
var systems = DefaultWorldInitialization.GetAllSystems(WorldSystemFilterFlags.Default);
DefaultWorldInitialization.AddSystemsToRootLevelSystemGroups(world, systems);
ScriptBehaviourUpdateOrder.UpdatePlayerLoop(world);
return true;
}
}
ICustomBootstrap
can now be inherited and only the most deepest subclass bootstrap will be executed.DefaultWorldInitialization.GetAllSystems
is not affected by bootstrap, it simply returns a list of systems based on the present dlls & attributes.Time
is now available per-World, and is a property in aComponentSystem
. It is updated from theUnityEngine.Time
during theInitializationSystemGroup
of each world. If you need access to time in a sytem that runs in the `Ini...