No edit summary |
(Automatically adding template at the end of the page.) |
||
(6 intermediate revisions by 3 users not shown) | |||
Line 1: | Line 1: | ||
You may define methods in classes | You may define methods in classes and implement these with OCL: | ||
[[File:My method.png|frameless|419x419px]] | [[File:My method.png|frameless|419x419px]] | ||
Do this in the OCL implementation in the Body-property: | |||
[[File:Method ocl.png|frameless|411x411px]] | [[File:Method ocl.png|frameless|411x411px]] | ||
Notice that since this was a method MDriven will treat | Notice that since this was a method, MDriven will treat your OCL as EAL – something that has side effects. In this case, our method does not have any side effects and you may want to be able to use this method in OCL, but trying to use it in OCL will not succeed. Methods with side effects are not recognized by OCL. There is a flag on the Method definition called IsQuery and if this is set, we “promise” that it does not have intentional side effects. Now it is seen by OCL: | ||
[[File:Method ocl2.png|frameless|415x415px]] | [[File:Method ocl2.png|frameless|415x415px]] | ||
We can then use our IsQuery method in any expression in OCL. Thing.allinstances- >select(x|x.MyMethod(x.SomeInt)) | We can then use our IsQuery method in any expression in OCL. '''Thing.allinstances- >select(x|x.MyMethod(x.SomeInt))''' | ||
==== Parameters and Return Types ==== | |||
Give parameters and return types in this format: | |||
SomeMethod(myparam:String):String | |||
SomeMethod(myparam:String,SomeOtherParam:Integer):String | |||
SomeMethod(myparam:String,SomeOtherParam:Integer,aListOfValue:Collection(String)):String | |||
SomeMethodThatReturnsList(myparam:String,SomeOtherParam:Integer,aListOfValue:Collection(String)):Collection(String) | |||
SomeMethodThatReturnsList(myparam:String,SomeOtherParam:Integer,aListOfValue:Collection(SomeClass)):Collection(SomeClass) | |||
[[Category:OCL]] | |||
{{Edited|July|12|2024}} |
Latest revision as of 15:37, 10 February 2024
You may define methods in classes and implement these with OCL:
Do this in the OCL implementation in the Body-property:
Notice that since this was a method, MDriven will treat your OCL as EAL – something that has side effects. In this case, our method does not have any side effects and you may want to be able to use this method in OCL, but trying to use it in OCL will not succeed. Methods with side effects are not recognized by OCL. There is a flag on the Method definition called IsQuery and if this is set, we “promise” that it does not have intentional side effects. Now it is seen by OCL:
We can then use our IsQuery method in any expression in OCL. Thing.allinstances- >select(x|x.MyMethod(x.SomeInt))
Parameters and Return Types
Give parameters and return types in this format:
SomeMethod(myparam:String):String SomeMethod(myparam:String,SomeOtherParam:Integer):String SomeMethod(myparam:String,SomeOtherParam:Integer,aListOfValue:Collection(String)):String SomeMethodThatReturnsList(myparam:String,SomeOtherParam:Integer,aListOfValue:Collection(String)):Collection(String) SomeMethodThatReturnsList(myparam:String,SomeOtherParam:Integer,aListOfValue:Collection(SomeClass)):Collection(SomeClass)