| m Fix redirect Tag: Redirect target changed |  unmanaged type -> passes unmanaged type constraint | ||
| (14 intermediate revisions by 2 users not shown) | |||
| Line 1: | Line 1: | ||
| # | <languages /> | ||
| <translate> | |||
| <!--T:1--> | |||
| A '''value type''' is a delegation of types within the [[FrooxEngine]] [[data model]] and [[ProtoFlux]]. In contrast to [[reference types]], fields containing a value type store the value directly, rather than a reference to the value. | |||
| </translate> | |||
| == <translate><!--T:3--> In FrooxEngine</translate> == | |||
| <translate> | |||
| <!--T:4--> | |||
| What types are defined as value types in FrooxEngine are managed through a complicated autogenerated class called <code>Coder<T></code>. As such, it is much better to refer to [[:Category:Value types|the list of all value types]] for determining what is a value type in FrooxEngine. Overall, though, all FrooxEngine value types share the property that they <em>do not</em> implement the [[Type:IWorldElement]] interface, unlike reference types. | |||
| </translate> | |||
| <translate> | |||
| <!--T:5--> | |||
| In a [[Scene Inspector]], fields holding a value type are easily identifiable by the ability to directly edit the value within them, rather than needing to drag in a reference to the type. | |||
| </translate> | |||
| <translate> | |||
| <!--T:6--> | |||
| A [[Component:ValueField|ValueField]] component is only able to be created for types that are FrooxEngine value types, so one can enter the type name while attaching the component to test whether it is a value type or not. | |||
| </translate> | |||
| == <translate><!--T:7--> In ProtoFlux</translate> == | |||
| <translate> | |||
| <!--T:8--> | |||
| In ProtoFlux, in short, if a type can be used within the [https://learn.microsoft.com/en-us/dotnet/csharp/programming-guide/generics/constraints-on-type-parameters#unmanaged-constraint unmanaged type constraint in C#], it is recognized as a value type. Otherwise, it is an [[object type]]. This makes ProtoFlux's type categorization a direct interface to C#'s type categorization. | |||
| </translate> | |||
| <translate> | |||
| <!--T:9--> | |||
| To expand on the definition: in ProtoFlux, a value type must either (criteria not useful to Resonite excluded): | |||
| </translate> | |||
| * <translate><!--T:10--> Be one of <code>[[Type:sbyte|sbyte]]</code>, <code>[[Type:byte|byte]]</code>, <code>[[Type:Short|short]]</code>, <code>[[Type:ushort|ushort]]</code>, <code>[[Type:int|int]]</code>, <code>[[Type:uint|uint]]</code>, <code>[[Type:long|long]]</code>, <code>[[Type:ulong|ulong]]</code>, <code>[[Type:char|char]]</code>, <code>[[Type:float|float]]</code>, <code>[[Type:double|double]]</code>, <code>[[Type:decimal|decimal]]</code>, or <code>[[Type:bool|bool]]</code>.</translate> | |||
| * <translate><!--T:11--> Be an [[Enum]] type.</translate> | |||
| * <translate><!--T:12--> Be defined as a non-nullable <code>struct</code> internally that only contains other value types.</translate> | |||
| ** <translate><!--T:13--> This encompasses many different types, such as [[Type:float3|float3]], [[Type:DateTime|DateTime]], and [[Type:TangentPointFloat|TangentPointFloat]].</translate> | |||
| ** <translate><!--T:14--> This <em>excludes</em> [[Type:Nullable|Nullable]] types from being a ProtoFlux value type, such as <code>int?</code>.</translate> | |||
| <translate> | |||
| <!--T:15--> | |||
| This discrepency between the definition of a value type in FrooxEngine and in ProtoFlux can cause some confusion. For example, a [[Type:string|string]] is a value type in FrooxEngine, but an object type in ProtoFlux. This means you would use a [[Component:ValueField|ValueField]]<string> to store a string on a slot, but an [[ProtoFlux:Write|ObjectWrite]]<string> to write to the value within ProtoFlux. This is also the case with nullable types. | |||
| </translate> | |||
| <translate> | |||
| <!--T:16--> | |||
| All in all, every value type in ProtoFlux is also a value type in FrooxEngine, but not every value type in FrooxEngine is a value type in ProtoFlux. | |||
| </translate> | |||
| == <translate><!--T:17--> See also</translate> == | |||
| * <translate><!--T:18--> [[:Category:Value types]] for a list of all value types.</translate> | |||
| * <translate><!--T:19--> [[Reference type]], for the other type of types within the FrooxEngine data model.</translate> | |||
| * <translate><!--T:20--> [[Type:Object]], for the other type of types within ProtoFlux.</translate> | |||
| [[Category:Data model]] | |||
Latest revision as of 10:35, 25 October 2025
A value type is a delegation of types within the FrooxEngine data model and ProtoFlux. In contrast to reference types, fields containing a value type store the value directly, rather than a reference to the value.
In FrooxEngine
What types are defined as value types in FrooxEngine are managed through a complicated autogenerated class called Coder<T>. As such, it is much better to refer to the list of all value types for determining what is a value type in FrooxEngine. Overall, though, all FrooxEngine value types share the property that they do not implement the Type:IWorldElement interface, unlike reference types.
In a Scene Inspector, fields holding a value type are easily identifiable by the ability to directly edit the value within them, rather than needing to drag in a reference to the type.
A ValueField component is only able to be created for types that are FrooxEngine value types, so one can enter the type name while attaching the component to test whether it is a value type or not.
In ProtoFlux
In ProtoFlux, in short, if a type can be used within the unmanaged type constraint in C#, it is recognized as a value type. Otherwise, it is an object type. This makes ProtoFlux's type categorization a direct interface to C#'s type categorization.
To expand on the definition: in ProtoFlux, a value type must either (criteria not useful to Resonite excluded):
- Be one of sbyte,byte,short,ushort,int,uint,long,ulong,char,float,double,decimal, orbool.
- Be an Enum type.
- Be defined as a non-nullable structinternally that only contains other value types.- This encompasses many different types, such as float3, DateTime, and TangentPointFloat.
- This excludes Nullable types from being a ProtoFlux value type, such as int?.
 
This discrepency between the definition of a value type in FrooxEngine and in ProtoFlux can cause some confusion. For example, a string is a value type in FrooxEngine, but an object type in ProtoFlux. This means you would use a ValueField<string> to store a string on a slot, but an ObjectWrite<string> to write to the value within ProtoFlux. This is also the case with nullable types.
All in all, every value type in ProtoFlux is also a value type in FrooxEngine, but not every value type in FrooxEngine is a value type in ProtoFlux.
See also
- Category:Value types for a list of all value types.
- Reference type, for the other type of types within the FrooxEngine data model.
- Type:Object, for the other type of types within ProtoFlux.
