No edit summary |
No edit summary |
||
Line 3: | Line 3: | ||
[[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 your OCL as EAL – something that has side effects. In this case, our method does not have any side effects and | 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 ==== | ==== Parameters and Return Types ==== | ||
Give parameters and return types in this format: | |||
SomeMethod(myparam:String):String | SomeMethod(myparam:String):String | ||
Line 23: | Line 23: | ||
SomeMethodThatReturnsList(myparam:String,SomeOtherParam:Integer,aListOfValue:Collection(String)):Collection(String) | SomeMethodThatReturnsList(myparam:String,SomeOtherParam:Integer,aListOfValue:Collection(String)):Collection(String) | ||
SomeMethodThatReturnsList(myparam:String,SomeOtherParam:Integer,aListOfValue:Collection(SomeClass)):Collection(SomeClass) | SomeMethodThatReturnsList(myparam:String,SomeOtherParam:Integer,aListOfValue:Collection(SomeClass)):Collection(SomeClass) | ||
[[Category:OCL]] |
Revision as of 05:37, 6 July 2023
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)