VerbalizePatterns
No edit summary
(Automatically adding template at the end of the page.)
 
(18 intermediate revisions by 3 users not shown)
Line 1: Line 1:
This page can be downloaded from the MDrivenDesigner and act as patterns for verbalization of OCL expressions. Divider between pattern and translation is 3 stars padded by a space.
This page can be downloaded from MDrivenDesigner to act as a pattern for the verbalization of OCL expressions. The Divider between pattern and translation is '''3 stars padded by a space'''. The initial part must be unique - the first occurrence will be used.


STARTMARKER
To handle an unknown number of parameters, but more than 2, use this pattern: <code><ARG_N0>,<ARG_NMINUS1>,<ARG_N></code>. We will use <code>ARG_N0</code> for the first and <code>ARG_N</code> for the last and <code>ARG_NMINUS1</code> for the one before the last. Separators in your pattern will be kept and repeated between <code>ARG_N0</code> and followers to the one before the last.


[SELF:<NAME>:<T>] *** From the current context (of type <T> )
'''STARTMARKER'''
 
[MULTI:<NAME>:<COLLECTION(T)>] *** take the multilink named <NAME> that holds objects of type <T>
[SELF:<NAME>:<T>] *** From the current context (of type <T> )
 
[SINGLE:<NAME>:<T>] *** take the singlelink named <NAME> that has an object of type <T>
[MULTI:<NAME>:<COLLECTION(T)>] *** take the multilink named <NAME> that holds objects of type <T>
 
[OPERATION:allinstances:<COLLECTION(T)>] *** Take all exsisting objects
[SINGLE:<NAME>:<T>] *** take the singlelink named <NAME> that has an object of type <T>
 
[ITERATION:select:<LOOPVARNAME>:<LOOPVARTYPE>:(<ARG_1>):<COLLECTION(T)>] *** filter the list by going over all objects, in each iteration we call the current object <LOOPVARNAME> and check <ARG_1> - keep the objects that evaluate to true - the result is a reduced list of objects of <T>
[OPERATION:allinstances:<COLLECTION(T)>] *** Take all exsisting objects
 
[ITERATION:foreach:<LOOPVARNAME>:<LOOPVARTYPE>:(<ARG_1>):<COLLECTION(T)>] *** for each item in the call the current object <LOOPVARNAME> and do the following: <ARG_1> - the incoming list of objects of <T> is returned
[ITERATION:select:<LOOPVARNAME>:<LOOPVARTYPE>:(<ARG_1>):<COLLECTION(T)>] *** filter the list by going over all objects, in each iteration we call the  
 
current object <LOOPVARNAME> and check <ARG_1> - keep the objects that evaluate to true - the result is a reduced list of objects of <T>
[ITERATION:<NAME>:<LOOPVARNAME>:<LOOPVARTYPE>:(<ARG_1>):<COLLECTION(T)>]
 
[ITERATION:foreach:<LOOPVARNAME>:<LOOPVARTYPE>:(<ARG_1>):<COLLECTION(T)>] *** for each item in the call the current object <LOOPVARNAME> and do the  
[LOOPVAR:<NAME>:<LOOPVARNAME>:<T>] *** current object of iteration <LOOPVARNAME> of type <T>
following: <ARG_1> - the incoming list of objects of <T> is returned
 
[ATTRIBUTE:<NAME>:<T>] *** take the attribut <NAME> that has the type <T>
[ITERATION:exists:<LOOPVARNAME>:<LOOPVARTYPE>:(<ARG_1>):System.Boolean] *** return true if the criteria <ARG_1> is met at least once for items in the
 
list called <LOOPVARNAME>
[LISTCOERCION:<NAME>:(<ARG_1>):<T>] ***  
 
[ITERATION:collect:<LOOPVARNAME>:<LOOPVARTYPE>:(<ARG_1>,<ARG_2>):<COLLECTION(T)>] *** collect <ARG_1> and <ARG_2> and build a list of a new resulting
[LISTCOERCION:<NAME>:(<ARG_1>):<COLLECTION(T)>] ***
tuple type <T>
 
[OPERATION:>:(<ARG_1>):<T>] *** if it is larger (>) than <ARG_1>
[ITERATION:collect:<LOOPVARNAME>:<LOOPVARTYPE>:(<ARG_N0>,<ARG_NMINUS1>,<ARG_N>):<COLLECTION(T)>] *** collect the following arguments <ARG_N0>,
 
<ARG_NMINUS1> and <ARG_N> and build a list of a new resulting tuple type <T>
[OPERATION:<:(<ARG_1>):<T>] *** check if it is smaller (<) than <ARG_1>
 
[ITERATION:<NAME>:<LOOPVARNAME>:<LOOPVARTYPE>:(<ARG_1>):<COLLECTION(T)>]
[OPERATION:or:(<ARG_1>):<T>] *** or (or) the following is true: <ARG_1>
 
[LOOPVAR:<NAME>:<LOOPVARNAME>:<T>] *** current object of iteration <LOOPVARNAME> of type <T>
[OPERATION:and:(<ARG_1>):<T>] *** and (and) also the following is true: <ARG_1>
 
[ATTRIBUTE:<NAME>:<T>] *** take the attribut <NAME> that has the type <T>
[OPERATION:first:<T>] *** take the first object
 
[LISTCOERCION:<NAME>:(<ARG_1>):<T>] ***
[CONST:<NAME>:<CONSTVALUE>:<T>] *** <CONSTVALUE> (of type <T>)
 
[LISTCOERCION:<NAME>:(<ARG_1>):<COLLECTION(T)>] *** _
[TYPE:<NAME>:<T>] *** From type <NAME>
 
[OPERATION:>:(<ARG_1>):<T>] *** if it is larger (>) than <ARG_1>
[OPERATION:<NAME>:(<ARG_1>):<T>] *** apply operation <NAME> with argument <ARG_1>, it will return a value of type <T>
 
[OPERATION:<:(<ARG_1>):<T>] *** check if it is smaller (<) than <ARG_1>
[VAR:<NAME>:System.Boolean] *** value of <NAME>
 
[OPERATION:or:(<ARG_1>):<T>] *** or (or) the following is true: <ARG_1>
[VAR:<NAME>:<T>] *** value of <NAME>
 
[OPERATION:and:(<ARG_1>):<T>] *** and (and) also the following is true: <ARG_1>
[VAR:<NAME>:<COLLECTION(T)>] *** <NAME> is a list of <T> objects
 
[OPERATION:first:<T>] *** take the first object
[OPERATION:if:(<ARG_1>,<ARG_2>):<T>] *** if true then <ARG_1> else <ARG_2>
 
[CONST:<NAME>:<CONSTVALUE>:<T>] *** <CONSTVALUE> (of type <T>)
[OPERATION:if:(<ARG_1>,<ARG_2>):<COLLECTION(T)>] *** if true then <ARG_1> else <ARG_2>
 
[TYPE:<NAME>:<T>] *** From type <NAME>
[OPERATION::=:(<ARG_1>):<T>] *** and assign it to the result of <ARG_1>
 
[OPERATION:<NAME>:(<ARG_1>):<T>] *** apply operation <NAME> with argument <ARG_1>, it will return a value of type <T>
[OPERATION:=:(<ARG_1>):<T>] *** and check if it is equal to <ARG_1>
 
[OPERATION:<NAME>:<T>] *** run the operation <NAME>, it will return a value of type <T>
[OPERATION:;:(<ARG_1>):<T>] *** . <ARG_1>
 
[VAR:<NAME>:System.Boolean] *** value of <NAME>
[OPERATION:not:System.Boolean] *** avoid all that match
 
[VAR:<NAME>:<T>] *** <NAME>
[OPERATION:oclsingleton:<T>] *** Get the singleton object of type <T>
 
[VAR:selfVM:<T>] *** selfVMXXX
[OPERATION:isnull:System.Boolean] *** is not assigned a value (null)
 
[VAR:<NAME>:<COLLECTION(T)>] *** <NAME> is a list of <T> objects
[OPERATION:notnull:System.Boolean] *** is assigned a value (not null)
 
[OPERATION:if:(<ARG_1>,<ARG_2>):<T>] *** if true then <ARG_1> else <ARG_2>
[OPERATION:+:(<ARG_1>):System.String] *** append <ARG_1> to the string
 
[OPERATION:if:(<ARG_1>,<ARG_2>):<COLLECTION(T)>] *** if true then <ARG_1> else <ARG_2>
[OPERATION:oclisinstate:(<ARG_1>):System.Boolean] *** and object is in state: <ARG_1>
 
[OPERATION::=:(<ARG_1>):<T>] *** and assign it to the result of <ARG_1>  
[CONST:<NAME>:<CONSTVALUE>:<Enum Literal>] *** <CONSTVALUE>
 
[OPERATION:=:(<ARG_1>):<T>] *** and check if it is equal to <ARG_1>
[OPERATION:oclisinstate:(<ARG_1>):System.Boolean].[CONST:<NAME>:<CONSTVALUE>:<Enum Literal>] *** test1<CONSTVALUE>
 
[OPERATION:;:(<ARG_1>):<T>] *** . <ARG_1>
[CONST:<NAME>:<CONSTVALUE>:<Enum Literal>].[OPERATION:oclisinstate:(<ARG_1>):System.Boolean] *** test2<CONSTVALUE>
 
[OPERATION:not:System.Boolean] *** avoid all that match
[OPERATION:oclisinstate:(<[CONST:<NAME>:<CONSTVALUE>:<Enum Literal>]>):System.Boolean] *** test3<CONSTVALUE>
 
[OPERATION:oclsingleton:<T>] *** Get the singleton object of type <T>
[OPERATION:oclisinstate:([CONST:<NAME>:<CONSTVALUE>:<Enum Literal>]):System.Boolean] *** test4<CONSTVALUE>
 
[OPERATION:isnull:System.Boolean] *** is not assigned a value (null)
[LET:<NAME>:<LOOPVARTYPE>:<LETASSIGNEXP>:<LETACTEXP>:<T>] *** let <NAME> represent the result of <LETASSIGNEXP> in this expression: <LETACTEXP>
[OPERATION:notnull:System.Boolean] *** is assigned a value (not null)
[OPERATION:+:(<ARG_1>):System.String] *** append <ARG_1> to the string
[OPERATION:oclisinstate:(<ARG_1>):System.Boolean] *** and object is in state: <ARG_1>
[CONST:<NAME>:<CONSTVALUE>:<Enum Literal>] *** <CONSTVALUE>
[OPERATION:oclisinstate:(<ARG_1>):System.Boolean].[CONST:<NAME>:<CONSTVALUE>:<Enum Literal>] *** test1<CONSTVALUE>
[CONST:<NAME>:<CONSTVALUE>:<Enum Literal>].[OPERATION:oclisinstate:(<ARG_1>):System.Boolean] *** test2<CONSTVALUE>
[OPERATION:oclisinstate:(<[CONST:<NAME>:<CONSTVALUE>:<Enum Literal>]>):System.Boolean] *** test3<CONSTVALUE>
[OPERATION:oclisinstate:([CONST:<NAME>:<CONSTVALUE>:<Enum Literal>]):System.Boolean] *** test4<CONSTVALUE>
[LET:<NAME>:<LOOPVARTYPE>:<LETASSIGNEXP>:<LETACTEXP>:<T>] *** let <NAME> represent the result of <LETASSIGNEXP> in this expression: <LETACTEXP>
[LET:<NAME>:<LOOPVARTYPE>:<LETASSIGNEXP>:<LETACTEXP>:<COLLECTION(T)>] *** let <NAME> represent the result of <LETASSIGNEXP> in this expression:
<LETACTEXP>
[OPERATION:<>:(<ARG_1>):System.Boolean] *** is NOT Equal from <ARG_1>
[OPERATION:<NAME>:(<ARG_1>,<ARG_2>):<T>] *** Execute the method <NAME> with argument <ARG_1> and <ARG_2>, and get a result of type <T>
[OPERATION:<NAME>:(<ARG_N0>,<ARG_NMINUS1>,<ARG_N>):<T>] *** Execute the method <NAME> with argument <ARG_N0>,<ARG_NMINUS1> and <ARG_N> get a result
of type <T>
[[Category:OCL]]
{{Edited|July|12|2024}}

Latest revision as of 15:49, 10 February 2024

This page can be downloaded from MDrivenDesigner to act as a pattern for the verbalization of OCL expressions. The Divider between pattern and translation is 3 stars padded by a space. The initial part must be unique - the first occurrence will be used.

To handle an unknown number of parameters, but more than 2, use this pattern: <ARG_N0>,<ARG_NMINUS1>,<ARG_N>. We will use ARG_N0 for the first and ARG_N for the last and ARG_NMINUS1 for the one before the last. Separators in your pattern will be kept and repeated between ARG_N0 and followers to the one before the last.

STARTMARKER

[SELF:<NAME>:<T>] *** From the current context (of type <T> )

[MULTI:<NAME>:<COLLECTION(T)>] *** take the multilink named <NAME> that holds objects of type <T>

[SINGLE:<NAME>:<T>] *** take the singlelink named <NAME> that has an object of type <T>

[OPERATION:allinstances:<COLLECTION(T)>] *** Take all exsisting objects

[ITERATION:select:<LOOPVARNAME>:<LOOPVARTYPE>:(<ARG_1>):<COLLECTION(T)>] *** filter the list by going over all objects, in each iteration we call the 
current object <LOOPVARNAME> and check <ARG_1> - keep the objects that evaluate to true - the result is a reduced list of objects of <T>

[ITERATION:foreach:<LOOPVARNAME>:<LOOPVARTYPE>:(<ARG_1>):<COLLECTION(T)>] *** for each item in the call the current object <LOOPVARNAME> and do the 
following: <ARG_1> - the incoming list of objects of <T> is returned

[ITERATION:exists:<LOOPVARNAME>:<LOOPVARTYPE>:(<ARG_1>):System.Boolean] *** return true if the criteria <ARG_1> is met at least once for items in the 
list called <LOOPVARNAME>

[ITERATION:collect:<LOOPVARNAME>:<LOOPVARTYPE>:(<ARG_1>,<ARG_2>):<COLLECTION(T)>] *** collect <ARG_1> and <ARG_2> and build a list of a new resulting 
tuple type <T> 

[ITERATION:collect:<LOOPVARNAME>:<LOOPVARTYPE>:(<ARG_N0>,<ARG_NMINUS1>,<ARG_N>):<COLLECTION(T)>] *** collect the following arguments <ARG_N0>, 
<ARG_NMINUS1> and <ARG_N> and build a list of a new resulting tuple type <T> 

[ITERATION:<NAME>:<LOOPVARNAME>:<LOOPVARTYPE>:(<ARG_1>):<COLLECTION(T)>]

[LOOPVAR:<NAME>:<LOOPVARNAME>:<T>] *** current object of iteration <LOOPVARNAME> of type <T>

[ATTRIBUTE:<NAME>:<T>] *** take the attribut <NAME> that has the type <T>

[LISTCOERCION:<NAME>:(<ARG_1>):<T>] *** _  

[LISTCOERCION:<NAME>:(<ARG_1>):<COLLECTION(T)>] *** _ 

[OPERATION:>:(<ARG_1>):<T>] *** if it is larger (>) than <ARG_1>

[OPERATION:<:(<ARG_1>):<T>] *** check if it is smaller (<) than <ARG_1>

[OPERATION:or:(<ARG_1>):<T>] *** or (or) the following is true: <ARG_1>

[OPERATION:and:(<ARG_1>):<T>] *** and (and) also the following is true: <ARG_1>

[OPERATION:first:<T>] *** take the first object

[CONST:<NAME>:<CONSTVALUE>:<T>] *** <CONSTVALUE> (of type <T>)

[TYPE:<NAME>:<T>] *** From type <NAME>

[OPERATION:<NAME>:(<ARG_1>):<T>] *** apply operation <NAME> with argument <ARG_1>, it will return a value of type <T>

[OPERATION:<NAME>:<T>] *** run the operation <NAME>, it will return a value of type <T>

[VAR:<NAME>:System.Boolean] *** value of <NAME>

[VAR:<NAME>:<T>] *** <NAME>

[VAR:selfVM:<T>] *** selfVMXXX

[VAR:<NAME>:<COLLECTION(T)>] *** <NAME> is a list of <T> objects

[OPERATION:if:(<ARG_1>,<ARG_2>):<T>] *** if true then <ARG_1> else <ARG_2>

[OPERATION:if:(<ARG_1>,<ARG_2>):<COLLECTION(T)>] *** if true then <ARG_1> else <ARG_2>

[OPERATION::=:(<ARG_1>):<T>] *** and assign it to the result of <ARG_1> 

[OPERATION:=:(<ARG_1>):<T>] *** and check if it is equal to <ARG_1>

[OPERATION:;:(<ARG_1>):<T>] *** . <ARG_1>

[OPERATION:not:System.Boolean] *** avoid all that match

[OPERATION:oclsingleton:<T>] *** Get the singleton object of type <T>

[OPERATION:isnull:System.Boolean] *** is not assigned a value (null)

[OPERATION:notnull:System.Boolean] *** is assigned a value (not null)

[OPERATION:+:(<ARG_1>):System.String] *** append <ARG_1> to the string

[OPERATION:oclisinstate:(<ARG_1>):System.Boolean] *** and object is in state: <ARG_1>

[CONST:<NAME>:<CONSTVALUE>:<Enum Literal>] *** <CONSTVALUE>

[OPERATION:oclisinstate:(<ARG_1>):System.Boolean].[CONST:<NAME>:<CONSTVALUE>:<Enum Literal>] *** test1<CONSTVALUE>

[CONST:<NAME>:<CONSTVALUE>:<Enum Literal>].[OPERATION:oclisinstate:(<ARG_1>):System.Boolean] *** test2<CONSTVALUE>

[OPERATION:oclisinstate:(<[CONST:<NAME>:<CONSTVALUE>:<Enum Literal>]>):System.Boolean] *** test3<CONSTVALUE>

[OPERATION:oclisinstate:([CONST:<NAME>:<CONSTVALUE>:<Enum Literal>]):System.Boolean] *** test4<CONSTVALUE>

[LET:<NAME>:<LOOPVARTYPE>:<LETASSIGNEXP>:<LETACTEXP>:<T>] *** let <NAME> represent the result of <LETASSIGNEXP> in this expression: <LETACTEXP>

[LET:<NAME>:<LOOPVARTYPE>:<LETASSIGNEXP>:<LETACTEXP>:<COLLECTION(T)>] *** let <NAME> represent the result of <LETASSIGNEXP> in this expression: 
<LETACTEXP>

[OPERATION:<>:(<ARG_1>):System.Boolean] *** is NOT Equal from <ARG_1>

[OPERATION:<NAME>:(<ARG_1>,<ARG_2>):<T>] *** Execute the method <NAME> with argument <ARG_1> and <ARG_2>, and get a result of type <T> 

[OPERATION:<NAME>:(<ARG_N0>,<ARG_NMINUS1>,<ARG_N>):<T>] *** Execute the method <NAME> with argument <ARG_N0>,<ARG_NMINUS1> and <ARG_N> get a result 
of type <T>
This page was edited more than 11 months ago on 02/10/2024. What links here