GetClassPropertyByIteratorEx

Returns a handle to a property. If input property is zero, the handle will point to the first property having cardinality restriction to the class. else it will point to next property with known restriction If all properties are past (or no relevant properties are found), the function will return 0. minCard and maxCard will contain restrictions for returned property

Note: this function does not return inherited restrictions.

This call has the same behavior as GetClassPropertyByIterator, however needs to be used in case classes and / or properties are exchanged as a successive series of integers.

Syntax

public const string enginedll = @"engine.dll";

[DllImport(enginedll, EntryPoint = "GetClassPropertyByIteratorEx")]
public static extern Int64 GetClassPropertyByIteratorEx(Int64 model, Int64 owlClass, Int64 rdfProperty, out Int64 minCard, out Int64 maxCard);

public static Int64 GetClassPropertyByIteratorEx(Int64 model, Int64 owlClass, Int64 rdfProperty)
        {
            return GetClassPropertyByIteratorEx(model, owlClass, rdfProperty, IntPtr.Zero, IntPtr.Zero);
        }    

Property model

Size: 64 bit / 8 byte (value)
The handle to the model. The model handle is static during its existance. Several models can be opened simultaniously within one session. Different models are always independent, threads are allowed to be running on different models simultaniously.

Property owlClass

Size: 64 bit / 8 byte (value)
This attribute represents a handle to the class. The term owl is comming from W3C, the classes follow the expression power of Semantic Web concepts, therefore classes support multiple inheritance. Technically classes can also be distributed over different resources, however for this the parametric library is required as an extension on the basic Geometry Kernel API.

Property rdfProperty

Size: 64 bit / 8 byte (value)
This attribute represents a handle to the property, this can be either a datatype property (attribute), an object property (relation) or non-defined property. The handle will be static during the life-time of the model, when the model (or part of it) is saved and opened again, the handle will most probably be different.

Property minCard

Size: 32 bit / 4 byte (reference)
The minimum cardinality (i.e. number of elements) of this property.

Property maxCard

Size: 32 bit / 4 byte (reference)
The maximum cardinality (i.e. number of elements) of this property.