Skip to content

Commit

Permalink
Browse files Browse the repository at this point in the history
## [1.0.0-pre.65] - 2023-03-21

### Added

* Added support for automatic data mode switching to the Entities Hierarchy window and the Inspector window.
* Added BlobAsset safety check for passing blob assets into methods without using `ref`.
* Added the `LocalTransform.ComputeWorldTransformMatrix()` which synchronously computes an entity's world-space transform matrix, in the rare cases where an accurate world transform is needed in simulation code and is otherwise be unavailable.
* Added `RefRW<T> SystemAPI.GetComponentRW<T>(Entity,bool)`
* Bulk SetComponentEnabled operations on EntityManager: `EntityManager.SetComponentEnabled<T>(EntityQuery, bool)` and `EntityManager.SetComponentEnabled(EntityQuery, ComponentType, bool)`.
* A `Unity.Transforms.Helpers` class with assorted transform-related helper functions:
  * A simple `float4x4` extension methods for field extraction, such as `.Up()`, `.Forward()` and `.Translation()`
  * Added utilities to apply a transformation matrix to a `float3` point or direction, or to a `quaternion` rotation
  * A method to synchronously compute an entity's world-space transform, `.ComputeWorldTransformMatrix()`
  * A method to compute the "LookAt" `quaternion` rotation for a position that would cause its "forward" direction to point towards some target.
* `TypeIndex.IsChunkSerializable` property has been added to identify if a component type is valid in a chunk that is intended to be serialized. If `SerializeUtility.SerializeWorld` (such as might be called while exporting a subscene) is used to serialize chunks that contain components whose `TypeIndex.IsChunkSerializable` returns false, an exception will be thrown telling you why the component type is inappropriate for serialization.
* Added `WeakSceneReference Unload(Scene scene)` method to unload the scene instance and release its resources.
* Added guidance to GetSingleton error message
* Transform Usage Flags
* Added support for managed (shared) components serialization in DOTS runtime.

### Changed

* Moved the tool for adding missing `partial` keywords to system and job types from Edit &gt; Preferences &gt; Entities into a Roslyn codefix. Your IDE of choice should now be able to fix this for you, and give you a red squiggly line if it's missing.
* IJobEntity no longer gives a compile error if you have a reference type field. This improves iteration time, and has the added benefit that you can now write managed code in an IJobEntity. Simply add a managed component to your IJE's Execute (that forces running without the jobsystem). Your job can now validly use that field. If you try to schedule this job rather than running it on the main thread, you'll correctly get thrown a runtime error for having a reference type in your job.
* Improved performance of IJobEntity generator, speeding up compile times. Attributes like WithAll, WithAny etc. now use syntax information directly. This mean that you can't make your own attribute on an IJobEntity named `WithAll` `WithAny`, `WithNone`, `WithDisabled`, `WithAbsent`, `WithOptions`, or `WithChangeFilter`.
* Updated Burst dependency version to 1.8.3.
* What was PostTransformScale as a float3x3 is now PostTransformMatrix as a float4x4. This is more general and offers maximum flexibility. You can, for example, use it to scale from a secondary pivot.
* ParentSystem removes the Parent component if said component points to an entity that doesn't exist anymore.
* Refactored how additive scenes are handled within the Runtime Content Manager. A scene is now returned, and that is used as the key to unload. This change required some API changes.
* Changed `WeakObjectSceneReference.LoadAsync` to return the Scene instance, which should be used to check the loading status and for unloading.
* Changed `RuntimeContentManager.UnloadScene` method to take the Scene instance as the only parameter.
* The BlobAssetStore used during baking now uses garbage collection instead of an explicit refcount. It is not required anymore to register blobs with authoring GameObjects nor to do explicit cleanup in incremental baking systems.
* Source generators for Systems and Aspects no longer default to outputting generated files in `Temp/GeneratedCode/***`. To turn it on, add `DOTS_OUTPUT_SOURCEGEN_FILES` to your Scripting Defines in Player Settings. Turning it on will cost compilation time. (The source generator for IJobEntity already made this change earlier.)
* Moved InternalCompilerInterface, EntityQueryEnumerator (now InternalEntityQueryEnumerator) and some other types and methods to the Unity.Entities.Internal namespace.  These types and methods are not intended for use by user code. We would make them internal, but source generators won't work correctly that way unfortunately.

### Deprecated

* Deprecated `WeakSceneReference` Release method. Unload should now be used and the scene instance returned by LoadAsync needs to be passed in as a ref.
* `RegisterBindingAttribute(Type runtimeComponent, string runtimeField, bool generated)`. Vector type fields can now be registered automatically without the `generated` option.
* SceneSystem.UnloadParameters and the overload of SceneSystem.UnloadScene receiving SceneSystem.UnloadParameters as parameters.
* `EntityQuery.SetEnabledBitsOnAllChunks` as the only bulk operation on EntityQuery instead of EntityManager. Use the newly added bulk `SetComponentEnabled` overloads instead.
* WeakSceneReference properties LoadingStatus, SceneResult, SceneFileResult.
* RuntimeContentManager methods GetSceneLoadingStatus, GetSceneFileValue, GetSceneValue

### Removed

* `ENABLE_TRANSFORM_V1` define and existing transform v1 code. Transform v2 is now the only transform system.
* Tooling to re-write user files to add missing partial keywords to systems.
* The `TransformAspect` struct was removed. Recent changes to the Entities transform systems made the current implementation of `TransformAspect` much less useful, and we've decided to remove it from the package until we can provide a more valuable abstraction over the DOTS transform components.
* The `EntityQueryEnumerator.EntityCount` field has been removed from the public API. Note that `EntityQueryEnumerator` is only intended for use by DOTS source generators.
* `BlobAssetComputationContext` made internal.

### Fixed

* Baker IEntitiesPlayerSettings were not setup correctly if the com.unity.platforms package was not installed/present in the project.
* IJobEntity now no longer caches the default query when scheduling with a dynamic query. For example. `new MyJob().Schedule();` will use the query matching its execute signature whereas `new MyJob().Schedule(myQuery)` will now only use myQuery. This is useful in cases like RequireMatchingQueriesForUpdate, where you don't want to accidentally create extra queries.
* Jobs implementing IJobEntity can now be created in one assembly and scheduled in another.
* The `[WithDisabled]` attribute when applied to a job implementing `IJobEntity` now overrides the implicit `All` query defined by the signature of `Execute`. E.g. `Execute(MyComp a)` and `[WithDisabled(typeof(MyComp))]` now defines a query of EntityQuery(all={}, disabled=MyComp). This is useful in cases where you want to enable all components of type X which are present, but disabled.
* `WriteGroup` support in transform v2 `LocalToWorldSystem` code should now work correctly.
* Fixed compilation issue with 23.1/23.2*
* Detection of circular ordering dependencies between systems is now correct.
* Chaining `EntityQuery` methods with bulk operation methods is now supported.
* Docs and samples for ECB systems now accurately reflect recommended usage. Fixed issue during `TypeManager.Initialize` where managed components with a field containing a circular type definition may throw `ArgumentException: An item with the same key has already been added.`
* Calling Release on a `WeakObjectReference<GameObject>` will no longer log errors in the editor.
* Zero-sized ("tag") enableable components were not always correctly enabled by default, when added to an entire chunk (such as via `EntityManager.AddComponent<EnableableTag>(query)`).
* Fixed issue with DotsGlobalSettings reporting the incorrect PlayType when switching from DedicatedServer to another standalone build target.
* Fixed TypeManager initialization causing a crash in the Entities Hierarchy.
* If you schedule an `IJobEntity` instance with a custom query that doesn't contain the components required for the `Execute()` method to run, a readable and actionable runtime exception is now thrown when safety checks are enabled.
* `EntityCommandBuffer.Dispose()` can no longer trigger a stack overflow when disposing large command buffers.
* Throw a readable, actionable compile-time error informing users that `RefRO<T>`, `RefRW<T>`, `EnabledRefRO<T>`,  `EnabledRefRW<T>`, `DynamicBuffer<T>` and `UnityEngineComponent<T>` may not be used with generic types.
* A `foreach` iterating over an `EntityQuery` with enableable components now iterates over the correct entities.
* Re-added obsolete baker functions
* The accidental exposure of package internals to "Assembly-CSharp" was reverted.
* Default the build system to use the client settings if the package com.unity.netcode is not installed when the active  platform is dedicated server.
* `Entities.WithStructuralChanges().ForEach()` now correctly handles enableable components.
* Allow components to contain nested native containers. Previously the TypeManager would throw during initialization if a component contained a a nested NativeContainer field. Note: NativeContainers still cannot be verified to be safely accessed when used in jobs. So, if a component contains a nested NativeContainer field, that component can only be accessed from the main thread.
* Entities Hierarchy correctly selects the subscenes
* Invalid entity warning in Inspector window with runtime data mode is only applied to entities or game objects that can be converted to entities.
* Issue with IJobEntity source-generators not getting re-run in IDE. This could cause Rider and Visual Studio to not be able to find/debug generated code for IJobEntity types.
* Adding managed components to entities via an `EntityCommandBuffer` on the main thread no longer triggers the `NullReferenceException`.
* Fixed an issue where entities with enableable components loaded from a subscene could reference the wrong component's enabled/disabled state.
* Fixed an issue where idiomatic foreach (IFE) would not iterate over all entities that matched its query, if the query contains enableable components
* Issue where recompilation would retrigger baking unnecessarily.
  • Loading branch information
Unity Technologies committed Mar 21, 2023
1 parent 2b7ad3a commit ddbc05e
Show file tree
Hide file tree
Showing 606 changed files with 17,155 additions and 20,656 deletions.
511 changes: 404 additions & 107 deletions CHANGELOG.md

Large diffs are not rendered by default.

12 changes: 6 additions & 6 deletions DocCodeSamples.Tests/AspectExamples.cs
Original file line number Diff line number Diff line change
Expand Up @@ -19,18 +19,18 @@ struct CannonBall : IComponentData
public readonly Entity Self;

// Aspects can contain other aspects.
readonly TransformAspect Transform;

// A RefRW field provides read write access to a component. If the aspect is taken as an "in"
// parameter, the field behaves as if it was a RefRO and throws exceptions on write attempts.
readonly RefRW<LocalTransform> Transform;
readonly RefRW<CannonBall> CannonBall;

// Properties like this aren't mandatory. The Transform field can be public instead.
// But they improve readability by avoiding chains of "aspect.aspect.aspect.component.value.value".
public float3 Position
{
get => Transform.LocalPosition;
set => Transform.LocalPosition = value;
get => Transform.ValueRO.Position;
set => Transform.ValueRW.Position = value;
}

public float3 Speed
Expand All @@ -46,11 +46,11 @@ public partial struct MySystem : ISystem
{
public void OnUpdate(ref SystemState state)
{
foreach (var transform in SystemAPI.Query<TransformAspect>())
foreach (var cannonball in SystemAPI.Query<CannonBallAspect>())
{
// use transform aspect here
// use cannonball aspect here
}
}
}
#endregion
}
}
110 changes: 4 additions & 106 deletions DocCodeSamples.Tests/BlobAssetBakingExamples.cs
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,8 @@ public override void Bake(MarketDataAuthoring authoring)

// Register the Blob Asset to the Baker for de-duplication and reverting.
AddBlobAsset<MarketData>(ref blobReference, out var hash);
AddComponent(new MarketDataComponent() {Blob = blobReference});
var entity = GetEntity(TransformUsageFlags.None);
AddComponent(entity, new MarketDataComponent() {Blob = blobReference});
}
}
#endregion
Expand Down Expand Up @@ -96,111 +97,8 @@ public override void Bake(MarketDataAuthoring authoring)
AddBlobAssetWithCustomHash<MarketData>(ref blobReference, customHash);
}

AddComponent(new MarketDataComponent() {Blob = blobReference});
}
}
#endregion


public struct BBBlobAsset
{
public float3 MinBoundingBox;
public float3 MaxBoundingBox;
}

public struct MeshComponent : IComponentData
{
public float3 MinBoundingBox;
public float3 MaxBoundingBox;
public Unity.Entities.Hash128 Hash;
}

public struct BoundingBoxComponent : IComponentData
{
public BlobAssetReference<BBBlobAsset> BlobData;
}

#region BlobAssetBakingSystemSetup
public struct CleanupComponent : ICleanupComponentData
{
public Unity.Entities.Hash128 Hash;
}
#endregion

#region BlobAssetBakingSystem
[BurstCompile]
[WorldSystemFilter(WorldSystemFilterFlags.BakingSystem)]
public partial struct ComputeBlobAssetSystem : ISystem
{
public void OnUpdate(ref SystemState state)
{
// Get the BlobAssetStore from the BakingSystem
var blobAssetStore =
state.World.GetExistingSystemManaged<BakingSystem>().BlobAssetStore;

// Handles the cleanup of BlobAssets for when BakingSystems are reverted
HandleCleanup(ref state, blobAssetStore);

foreach (var (mesh, bb, cleanup) in SystemAPI
.Query<RefRO<MeshComponent>, RefRW<BoundingBoxComponent>,
RefRW<CleanupComponent>>())
{
var hash = mesh.ValueRO.Hash;
BlobAssetReference<BBBlobAsset> blobAssetReference;

// If the BlobAsset doesn't exist yet
if (!blobAssetStore.TryGet<BBBlobAsset>(hash, out blobAssetReference))
{
// Create a new BlobAsset
var builder = new BlobBuilder(Allocator.Temp);
ref var root = ref builder.ConstructRoot<BBBlobAsset>();

root.MinBoundingBox = mesh.ValueRO.MinBoundingBox;
root.MaxBoundingBox = mesh.ValueRO.MaxBoundingBox;

blobAssetReference =
builder.CreateBlobAssetReference<BBBlobAsset>(Allocator.Persistent);

// Make sure to dispose the builder itself so all internal memory is disposed.
builder.Dispose();
}

// Update the Entity and BlobAssetStore with the new BlobAsset if it has changed
// since last run or is newly created
if (cleanup.ValueRO.Hash != hash || !bb.ValueRO.BlobData.IsCreated)
{
// Add the new BlobAsset to the component and the BlobAssetStore
blobAssetStore.TryAdd(hash, ref blobAssetReference);
bb.ValueRW.BlobData = blobAssetReference;

// Cleanup of the 'previous' BlobAsset if it existed.
blobAssetStore.TryRemove<BBBlobAsset>(cleanup.ValueRO.Hash, true);

// Update the cleanup component with the current hash
cleanup.ValueRW.Hash = hash;
}
}
}

public void HandleCleanup(ref SystemState state, BlobAssetStore blobAssetStore)
{
// Add the Cleanup Component to the newly created Entities, that do not have it yet
var addCleanupQuery = SystemAPI.QueryBuilder()
.WithAll<BoundingBoxComponent>().WithNone<CleanupComponent>().Build();
state.EntityManager.AddComponent<CleanupComponent>(addCleanupQuery);

// Cleanup the BlobAssets and Cleanup Components of newly destroyed Entities
// Cleanup of the BlobAssets through the BlobAssetStore
foreach (var cleanup in SystemAPI
.Query<RefRO<CleanupComponent>>().WithNone<BoundingBoxComponent>())
{
blobAssetStore.TryRemove<BBBlobAsset>(cleanup.ValueRO.Hash, true);
}

// Remove the Cleanup Component from the destroyed Entities
var removeCleanupQuery = SystemAPI.QueryBuilder()
.WithAll<CleanupComponent>().WithNone<BoundingBoxComponent>().Build();
state.EntityManager.RemoveComponent<CleanupComponent>(removeCleanupQuery);
var entity = GetEntity(TransformUsageFlags.None);
AddComponent(entity, new MarketDataComponent() {Blob = blobReference});
}
}
#endregion
Expand Down
77 changes: 62 additions & 15 deletions DocCodeSamples.Tests/DynamicBufferExamples.cs
Original file line number Diff line number Diff line change
Expand Up @@ -186,9 +186,9 @@ public partial struct AccessDynamicBufferJob : IJobEntity
{
[ReadOnly] public BufferLookup<ExampleBufferComponent> BufferLookup;
public void Execute()
{
{
// ...
}
}
}
#endregion

Expand All @@ -203,7 +203,7 @@ protected override void OnUpdate()

Entities.ForEach((DynamicBuffer<MyBufferElement> buffer) =>
{
for(int i = 0; i < buffer.Length; i++)
for (int i = 0; i < buffer.Length; i++)
{
sum += buffer[i].Value;
}
Expand All @@ -230,7 +230,7 @@ public struct SumResult : IJob
public void Execute()
{
int sum = 0;
for(int i = 0; i < sums.Length; i++)
for (int i = 0; i < sums.Length; i++)
{
sum += sums[i];
}
Expand All @@ -252,7 +252,7 @@ NativeArray<int> intermediateSums
Entities
.WithStoreEntityQueryInField(ref query)
.ForEach((int entityInQueryIndex, Entity entity, in DynamicBuffer<MyBufferElement> buffer) => {
for(int i = 0; i < buffer.Length; i++)
for (int i = 0; i < buffer.Length; i++)
{
intermediateSums[entityInQueryIndex] += buffer[i].Value;
}
Expand All @@ -267,7 +267,7 @@ NativeArray<int> intermediateSums
.WithDisposeOnCompletion(intermediateSums)
.WithCode(() =>
{
for(int i = 0; i < intermediateSums.Length; i++)
for (int i = 0; i < intermediateSums.Length; i++)
{
sum[0] += intermediateSums[i];
}
Expand Down Expand Up @@ -354,11 +354,11 @@ BufferAccessor<MyBufferElement> buffers
ChunkEntityEnumerator enumerator =
new ChunkEntityEnumerator(useEnabledMask, chunkEnabledMask, chunk.Count);

while(enumerator.NextEntityIndex(out var e))
while (enumerator.NextEntityIndex(out var e))
{
//An individual dynamic buffer for a specific entity
DynamicBuffer<MyBufferElement> buffer = buffers[e];
for(int i = 0; i < buffer.Length; i++)
for (int i = 0; i < buffer.Length; i++)
{
sums[e] += buffer[i].Value;
}
Expand All @@ -373,7 +373,7 @@ public struct SumResult : IJob
public NativeArray<int> result;
public void Execute()
{
for(int i = 0; i < sums.Length; i++)
for (int i = 0; i < sums.Length; i++)
{
result[0] += sums[i];
}
Expand Down Expand Up @@ -424,7 +424,7 @@ public static implicit operator float(FloatBufferElement e)

public static implicit operator FloatBufferElement(float e)
{
return new FloatBufferElement {Value = e};
return new FloatBufferElement { Value = e };
}
}

Expand All @@ -436,7 +436,7 @@ protected override void OnUpdate()

Entities.ForEach((DynamicBuffer<FloatBufferElement> buffer) =>
{
for(int i = 0; i < buffer.Length; i++)
for (int i = 0; i < buffer.Length; i++)
{
sum += buffer[i].Value;
}
Expand All @@ -463,15 +463,15 @@ private void ShowAdd()

#region dynamicbuffer.addrange

int[] source = {1, 2, 3, 4, 5};
int[] source = { 1, 2, 3, 4, 5 };
NativeArray<int> newElements = new NativeArray<int>(source, Allocator.Persistent);
buffer.AddRange(newElements);

#endregion

#region dynamicbuffer.asnativearray

int[] intArray = {1, 2, 3, 4, 5};
int[] intArray = { 1, 2, 3, 4, 5 };
NativeArray<int>.Copy(intArray, buffer.AsNativeArray());

#endregion
Expand All @@ -494,7 +494,7 @@ private void ShowAdd()

#region dynamicbuffer.copyfrom.nativearray

int[] sourceArray = {1, 2, 3, 4, 5};
int[] sourceArray = { 1, 2, 3, 4, 5 };
NativeArray<int> nativeArray = new NativeArray<int>(source, Allocator.Persistent);
buffer.CopyFrom(nativeArray);

Expand All @@ -509,7 +509,7 @@ private void ShowAdd()

#region dynamicbuffer.copyfrom.array

int[] integerArray = {1, 2, 3, 4, 5};
int[] integerArray = { 1, 2, 3, 4, 5 };
buffer.CopyFrom(integerArray);

#endregion
Expand Down Expand Up @@ -619,4 +619,51 @@ protected override void OnUpdate()
#endregion
}
}

/// Entity command buffer example code
public class DynamicBufferECB
{
[InternalBufferCapacity(16)]
public struct MyElement : IBufferElementData
{
public int Value;
}

#region dynamicbuffer.ecb

private void Example(Entity e, Entity otherEntity)
{
EntityCommandBuffer ecb = new(Allocator.TempJob);

// Record a command to remove the MyElement dynamic buffer from an entity.
ecb.RemoveComponent<MyElement>(e);

// Record a command to add a MyElement dynamic buffer to an existing entity.
// This doesn't fail if the target entity already contains the buffer component.
// The data of the returned DynamicBuffer is stored in the EntityCommandBuffer,
// so changes to the returned buffer are also recorded changes.
DynamicBuffer<MyElement> myBuff = ecb.AddBuffer<MyElement>(e);

// After playback, the entity will have a MyElement buffer with
// Length 20 and these recorded values.
myBuff.Length = 20;
myBuff[0] = new MyElement { Value = 5 };
myBuff[3] = new MyElement { Value = -9 };

// SetBuffer is like AddBuffer, but safety checks will throw an exception at playback if
// the entity doesn't already have a MyElement buffer.
DynamicBuffer<MyElement> otherBuf = ecb.SetBuffer<MyElement>(otherEntity);

// Records a MyElement value to append to the buffer. Throws an exception at
// playback if the entity doesn't already have a MyElement buffer.
// ecb.AddComponent<MyElement>(otherEntity) is a safe way to ensure a buffer
// exists before appending to it.
ecb.AppendToBuffer(otherEntity, new MyElement { Value = 12 });
}

#endregion

}


}
Loading

0 comments on commit ddbc05e

Please sign in to comment.