Each class type models a different type of object. ECEntityClass models business objects, which are individually instantiable and have an Id. ECStructClass models complex property types, often known as structs. ECCustomAttributeClass models objects which are applied to other schema elements to provide additional metadata. ECRelationshipClass models connections between ECEntityClasses.
All classes support inheritance within their own class type. Therefore, an ECEntityClass can have another ECEntityClass as its base class, but could not have an ECStructClass as the base class. ECRelationshipClass only supports single inheritance while ECEntityClass supports a limited form of multi-inheritance using 'mixins'.
typeName defines the name of this ECClass. Must be a valid ECName and be unique among all other items in a schema.
description User facing description of the class. Localized and may be shown in the UI.
displayLabel a localized display label that will be used instead of the name in the GUI. If not set the Type Name of the class will be used.
modifier identifies the class as abstract or sealed.
Valid options are:
- None (default) – normal, instantiable class. Not valid for ECRelationshipClass type.
- Abstract – abstract class, cannot be instantiated.
- Sealed – normal, instantiable class but cannot be used as a base class or have children
An ECClass may have Custom Attributes applied and inherit the custom attributes applied to their base class. Custom attributes applied to a base class may be overriden by applying the same custom attribute applied to a derived class.
- The multiplicity of base classes changes depending on the individual ECClass Type.
Base classes are traversed in a depth-first fashion for all purposes, including property inheritance (and the first occurrence of a given named ECProperty “wins”). For example, given this abbreviated set of ECClass definitions:
<ECEntityClass typeName="Root"/> //Defines a property "A" <ECEntityClass typeName="B1"> <BaseClass>Root</BaseClass> </ECEntityClass> <ECEntityClass typeName="B2"/> // Defines a property "A" <ECEntityClass typeName="Foo"> <BaseClass>B1</BaseClass> <BaseClass>B2</BaseClass> </ECEntityClass>
The traversal order will be: Foo, B1, Root, B2, and Root’s definition of property "A" will "win", but if Foo were defined with B2 first:
<ECEntityClass typeName="Foo"> <BaseClass>B2</BaseClass> <BaseClass>B1</BaseClass> </ECEntityClass>
The traversal order will be: Foo, B2, B1, Root and B2’s definition of property "A" will "win". If we introduce the "diamond pattern" via multiple inheritance by adding "Root" as a BaseClass of B2, the traversal order (using our second definition of Foo) would be: Foo, B2, Root, B1, Root. If a polymorphic algorithm were looking for subclasses of "Root", it would stop when it hit "Root" the first time.
Last Updated: 08 January, 2020