OCLOperators
No edit summary
Line 1: Line 1:
== General operators ==
== General Operators ==
To find all available you can open the OCL-Editor and type in a class:
To find all available operators, you can open the OCL-Editor and type in a class:


[[File:Ocl-editor 1.png|frameless|433x433px|link=https://wiki.mdriven.net/index.php/File:Ocl-editor_1.png]]
[[File:Ocl-editor 1.png|frameless|433x433px|link=https://wiki.mdriven.net/index.php/File:Ocl-editor_1.png]]
Line 14: Line 14:
|-
|-
|[[OCLOperators allLoadedObjects|allLoadedObjects]]
|[[OCLOperators allLoadedObjects|allLoadedObjects]]
|All objects currently in memory, exckluding deleted objects
|All objects currently in memory, excluding deleted objects
|-
|-
|'''[[OCLOperators allStates|allStates]]'''
|'''[[OCLOperators allStates|allStates]]'''
Line 20: Line 20:
|-
|-
|'''[[OCLOperators allSubClasses|allSubClasses]]'''
|'''[[OCLOperators allSubClasses|allSubClasses]]'''
|Meta information on all the sub classes this class has
|Meta information on all the sub-classes this class has
|-
|-
|'''[[OCLOperators allSuperTypes|allSuperTypes]]'''
|'''[[OCLOperators allSuperTypes|allSuperTypes]]'''
|Meta information on all the super classes – in inheritance order the class has
|Meta information on all the super-classes – in inheritance order the class has
|-
|-
|[[OCLOperators ASCII|ASCII]]
|[[OCLOperators ASCII|ASCII]]
Line 53: Line 53:
|-
|-
|[[OCLOperators canAccess|canAccess]]
|[[OCLOperators canAccess|canAccess]]
|Check viewmodels Access expression for root
|Check ViewModels Access expression for root
|-
|-
|'''[[OCLOperators constraints|Contraints]]'''
|'''[[OCLOperators constraints|Constraints]]'''
|Meta information on what constraints the class has
|Meta information on what constraints the class has
|-
|-
|[[OCLOperators count|count]]
|[[OCLOperators count|count]]
|Returns how many times ''object'' is in the collection ''self''.
|Returns how many times the ''object'' is in the collection ''self''.
|-
|-
|[[OCLOperators Default|Default]]
|[[OCLOperators Default|Default]]
Line 113: Line 113:
|-
|-
|'''[[OCLOperators oclIsKindOf|oclIsKindOf]]'''
|'''[[OCLOperators oclIsKindOf|oclIsKindOf]]'''
|This is to if a class is a subclass or a the class itself and not unrelated
|This is to if a class is a subclass or as the class itself and not unrelated
|-
|-
|'''[[OCLOperators oclIsTypeOf|oclIsTypeOf]]'''
|'''[[OCLOperators oclIsTypeOf|oclIsTypeOf]]'''
Line 158: Line 158:
|}
|}


== Collection operators ==
== Collection Operators ==
Once you have a collection of objects there are certain operators that are applicable to it.  
Once you have a collection of objects, there are certain operators applicable to them.  


See this page for [[examples on collection operators]]
See this page for [[examples on collection operators|examples on collection operators.]]


Again you can use the OCL-Editor to see what they are:
Again, you can use the OCL-Editor to see what they are:


[[File:Collection of objects operators.png|frameless|453x453px|link=https://wiki.mdriven.net/index.php/File:Collection_of_objects_operators.png]]
[[File:Collection of objects operators.png|frameless|453x453px|link=https://wiki.mdriven.net/index.php/File:Collection_of_objects_operators.png]]
Line 201: Line 201:
|-
|-
|'''[[OCLOperators excluding|->excluding]]'''
|'''[[OCLOperators excluding|->excluding]]'''
|The collection except this single object
|The collection except for this single object
|-
|-
|'''[[OCLOperators exists|->exists]]'''
|'''[[OCLOperators exists|->exists]]'''
Line 213: Line 213:
|-
|-
|'''[[OCLOperators forAll|->forAll]]'''
|'''[[OCLOperators forAll|->forAll]]'''
|Returns true if the all the elements contained in ''self'' validate the condition ''expr'', false otherwise.
|Returns true if all the elements contained in ''self'' validate the condition ''expr'', false otherwise.
|-
|-
|'''[[OCLOperators groupBy|->groupBy]]'''
|'''[[OCLOperators groupBy|->groupBy]]'''
|Build collection of tuples grouped by some aspect
|Build a collection of tuples grouped by some aspect
|-
|-
|'''[[OCLOperators includes|->includes]]'''
|'''[[OCLOperators includes|->includes]]'''
Line 258: Line 258:
|-
|-
|'''[[OCLOperators notEmpty|->notEmpty]]'''
|'''[[OCLOperators notEmpty|->notEmpty]]'''
|Returns true of the collection is not empty
|Returns true if the collection is not empty
|-
|-
|'''[[OCLOperators orderBy|->orderBy]]'''
|'''[[OCLOperators orderBy|->orderBy]]'''
Line 291: Line 291:
|}
|}


== String operators ==
== String Operators ==
{| class="wikitable"
{| class="wikitable"
!Operators
!Operators
Line 303: Line 303:
|-
|-
|[[OCLOperators StringToEncodedBase64|StringToEncodedBase64]]
|[[OCLOperators StringToEncodedBase64|StringToEncodedBase64]]
|Convert a string to a specific encoding and as a base64 string. For example Western Eauropean (ISO) Codepage 28591
|Convert a string to a specific encoding and as a base64 string. For example Western European (ISO) Codepage 28591
|-
|-
|[[OCLOperators Size () : Integer|size () : Integer]]
|[[OCLOperators Size () : Integer|size () : Integer]]
Line 324: Line 324:
|}
|}


== Number operators ==
== Number Operators ==
In addition to the basic math functions (+, -, /, \*) are a number of advanced functions. Take note that *Number* denotes both *Integer* and *Real*, and they're substitutive unless otherwise specified.
In addition to the basic math functions (+, -, /, \*) are a number of advanced functions. Take note that *Number* denotes both *Integer* and *Real*, and they're substitutive unless otherwise specified.
{| class="wikitable"
{| class="wikitable"
Line 354: Line 354:
|Returns the integer remainder of the division of ''self'' by *i*.
|Returns the integer remainder of the division of ''self'' by *i*.
|}
|}
== Boolean operators ==
== Boolean Operators ==
{| class="wikitable"
{| class="wikitable"
!Operators
!Operators
Line 374: Line 374:
|
|
|}
|}
== Viewmodel operators (on selfVM variable) ==
== Viewmodel Operators (on selfVM variable) ==
See page [[SelfVM]]
See page [[SelfVM]]



Revision as of 06:38, 1 March 2023

General Operators

To find all available operators, you can open the OCL-Editor and type in a class:

Ocl-editor 1.png

Operators Description
allInstances All the objects of the class
allinstancesAtTime All the currently loaded instances
allLoadedObjects All objects currently in memory, excluding deleted objects
allStates Meta information about available states in state machines the class may contain
allSubClasses Meta information on all the sub-classes this class has
allSuperTypes Meta information on all the super-classes – in inheritance order the class has
ASCII
associationEnds Returns a collection of strings with association names for the class
associationEndsWithType Returns a collection of strings with association names and type information for the class
asString The string representation of the class – the asString operation is available on everything
asTaJson Returns a json string defined by the ViewModel
atTime
Attributes Meta information about what attributes the class has
BigEndianUnicode
brokenConstraints Returns a collection of the names of broken constraints for the class and object.
canAccess Check ViewModels Access expression for root
Constraints Meta information on what constraints the class has
count Returns how many times the object is in the collection self.
Default
Empty
emptylist Returns an empty list typed to hold objects of the class
existing
externalId Returns the external ID for the object operated on.
format
IsDirty
IsNew IsNew operator returns true if the object has never been saved to the database.
isDirtyMember
isNull
maxValue Gets the maximum value in a collection of values
minValue Gets the minimum value in a collection of values
nullValue A typed null value
objectFromExternalId An external identity will be resolved to the object
oclAsType The type of the class
oclGetStates
oclIsInvalid Returns true if self is equal to *invalid*.
oclIsKindOf This is to if a class is a subclass or as the class itself and not unrelated
oclIsTypeOf Returns true if
OnCreate
OnUpdate
oclIsUndefined Returns true if self is equal to invalid or null.
OclType
random
safeCast
sqlpassthrough Calls a stored procedure
sqlpassthroughobjects Return a primary key of SomeClass. This can be combined with other Ocl-PS via ->intersection or union.
superTypes Returns the set of all direct supertypes of the type.
TaggedValue Meta information on tagged values set in the class
TaggedValueOnFeature Meta information on Tagged values set on a named feature in the class
Typename The type name as a string
ViewModels A tuple with the ViewModels for this class a members

Collection Operators

Once you have a collection of objects, there are certain operators applicable to them.

See this page for examples on collection operators.

Again, you can use the OCL-Editor to see what they are:

Collection of objects operators.png

Operators Description
->append Add another object last
->asBag Returns a Bag containing all elements of self.
->asSequence Returns a Sequence containing all elements of self. Element ordering is preserved when possible.
->asSet Returns a Set containing all elements of self.
->at Get the objects at X where the first index is 1
->at0 Get the objects at X where the first index is 0
->collect Returns a collection containing the result of applying expr on all elements contained in self.
->count Count how many meet a certain criteria
->dictionary Efficiently looks up values
->difference The difference between 2 collections
->excluding The collection except for this single object
->exists Returns true if at least one element in self validates the condition expr, false otherwise.
->filterOnType Only keep the ones of a certain type
->first Return the first object
->forAll Returns true if all the elements contained in self validate the condition expr, false otherwise.
->groupBy Build a collection of tuples grouped by some aspect
->includes Does the collection include the object
->includesAll Does the collection include the whole other collection
->including Returns the list with the element in the parameter included.
->IndexOf The 1 based index of an object in the collection possibly -1 if not existing
->indexOf0 The 0 based index of an object in the collection possibly -1 if not existing
->intersection The intersection of two collections
->isEmpty Returns true if the collection is empty
->notEmpty Returns true if self contains at least one element, false otherwise.
->reject Returns a collection with all elements of self except for those who validate the OclExpression expr.
->select Returns a collection with all elements of self that validate the OclExpression expr.
->size Returns the number of elements contained in self.
->sum Returns the sum of all elements contained in self if they support the '+' operation.
->last Returns the last object in the collection
->notEmpty Returns true if the collection is not empty
->orderBy Sorts the collection on one or more properties
->orderDescending Sort the from biggest to smallest
->orderGeneric Sorts the list of properties with interchangeable sort order: (expr1, OclSortDirection::ascending, expr2, OclSortDirection::descending...)
->prepend Returns an OrderedSet containing object followed by all elements of self.
->reject Returns the objects not matching the criteria
->select Returns the objects matching the criteria
->size Returns the number of elements in the collection
->subsequence Returns a smaller collection from a start to stop
->symmetricDifference The symmetric difference between the collections; ie all the objects in collection1 or collection2 but not in both
->union The set of objects in collection1 and objects in collection2

String Operators

Operators Description
Escape codes Escape (special) characters used in OCL
StringToAnsiBase64 Convert a string to an ANSI (1252) and as a base64 string
StringToEncodedBase64 Convert a string to a specific encoding and as a base64 string. For example Western European (ISO) Codepage 28591
size () : Integer Returns the number of characters composing self.
subString Returns the substring of the string operated on. The substring starts at parameter 1 and ends at parameter 2. The counting is 1-based.
toInteger () : Integer Returns self with all characters converted to lowercase.
toLower () : String Returns self with all characters converted to lowercase.
toReal () : Real Returns a Real of value equal to self, or |invalid| if self does not represent a real.
toUpper () : String Returns self with all characters converted to uppercase.

Number Operators

In addition to the basic math functions (+, -, /, \*) are a number of advanced functions. Take note that *Number* denotes both *Integer* and *Real*, and they're substitutive unless otherwise specified.

Operators Description
Number::abs () : Number Returns the absolute value of selfself if it is already a positive number.
Number::floor () : Integer Returns the integer part of self if it is a Real, self if it is an Integer.
Number::max ( r : Number ) : Number Returns the greatest number between self and *r*.
Number::min ( r : Number ) : Number Returns the lowest number between self and *r*.
Number::round () : Integer Returns the nearest integer to self if it is a Real, self if it is an Integer.
Number::ieeereminder(r:Number):Integer Reminder of division with r, ie modulus or mod or %
Integer::div ( i : Integer ) : Integer Returns the integer quotient of the division of self by *i*.
Integer::mod ( i : Integer ) : Integer Returns the integer remainder of the division of self by *i*.

Boolean Operators

Operators Description
And
Implies
Or
Not
Xor

Viewmodel Operators (on selfVM variable)

See page SelfVM

This page was edited 108 days ago on 01/11/2024. What links here