|
12 | 12 | import pt.uminho.haslab.echo.EchoError; |
13 | 13 | import pt.uminho.haslab.echo.EchoOptionsSetup; |
14 | 14 | import pt.uminho.haslab.echo.EchoReporter; |
| 15 | +import pt.uminho.haslab.echo.EchoTypeError; |
15 | 16 | import pt.uminho.haslab.echo.ErrorTransform; |
16 | 17 | import pt.uminho.haslab.echo.ErrorUnsupported; |
17 | 18 | import pt.uminho.haslab.echo.engine.EchoHelper; |
@@ -53,13 +54,31 @@ public INode translateAtlOcl(EObject expr) throws EchoError { |
53 | 54 | return translateAtlOclBooleanLit(expr); |
54 | 55 | } else if (expr.eClass().getName().equals("Binding")) { |
55 | 56 | return translateAtlOclBinding(expr); |
| 57 | + } else if (expr.eClass().getName().equals("IfExp")) { |
| 58 | + return translateAtlOclIf(expr); |
56 | 59 | } else if (expr.eClass().getName().equals("IteratorExp")) { |
57 | 60 | return translateAtlOclIterator(expr); |
58 | 61 | } else |
59 | 62 | throw new ErrorUnsupported("OCL expression not supported: " + expr |
60 | 63 | + "."); |
61 | 64 | } |
62 | 65 |
|
| 66 | + private INode translateAtlOclIf(EObject expr) throws EchoError { |
| 67 | + EStructuralFeature x = expr.eClass().getEStructuralFeature("condition"); |
| 68 | + IFormula eif = (IFormula) translateAtlOcl((EObject) expr.eGet(x)); |
| 69 | + x = expr.eClass().getEStructuralFeature("thenExpression"); |
| 70 | + INode thenExpr = translateAtlOcl((EObject) expr.eGet(x)); |
| 71 | + x = expr.eClass().getEStructuralFeature("elseExpression"); |
| 72 | + INode elseExpr = translateAtlOcl((EObject) expr.eGet(x)); |
| 73 | + |
| 74 | + if (thenExpr instanceof IExpression && elseExpr instanceof IExpression) |
| 75 | + return eif.thenElse((IExpression) thenExpr,(IExpression) elseExpr); |
| 76 | + else if (thenExpr instanceof IFormula && elseExpr instanceof IFormula) |
| 77 | + return (IFormula) eif.thenElse((IFormula) thenExpr,(IFormula) elseExpr); |
| 78 | + |
| 79 | + throw new EchoTypeError("Expression: "+expr.getClass()); |
| 80 | + } |
| 81 | + |
63 | 82 | IExpression translateAtlOclVariable(EObject expr) { |
64 | 83 | EStructuralFeature x = expr.eClass().getEStructuralFeature( |
65 | 84 | "referredVariable"); |
@@ -184,6 +203,8 @@ INode translateAtlOclOperationCall(EObject expr) throws EchoError { |
184 | 203 | res = ((IFormula) src).not(); |
185 | 204 | else if (operatorname.equals("isEmpty")) |
186 | 205 | res = ((IExpression) src).no(); |
| 206 | + else if (operatorname.equals("notEmpty")) |
| 207 | + res = ((IExpression) src).some(); |
187 | 208 | else if (operatorname.equals("size")) |
188 | 209 | res = ((IExpression) src).cardinality(); |
189 | 210 | else if (operatorname.equals("=")) { |
@@ -232,22 +253,45 @@ else if (operatorname.equals(">=")) |
232 | 253 | else if (operatorname.equals("union")) |
233 | 254 | res = ((IExpression) src) |
234 | 255 | .union((IExpression) translateAtlOcl(argumentso.get(0))); |
| 256 | + else if (operatorname.equals("including")) |
| 257 | + res = ((IExpression) src) |
| 258 | + .union((IExpression) translateAtlOcl(argumentso.get(0))); |
| 259 | + else if (operatorname.equals("excluding")) |
| 260 | + res = ((IExpression) src) |
| 261 | + .difference((IExpression) translateAtlOcl(argumentso.get(0))); |
235 | 262 | else if (operatorname.equals("intersection")) |
236 | 263 | res = ((IExpression) src) |
237 | 264 | .intersection((IExpression) translateAtlOcl(argumentso |
238 | 265 | .get(0))); |
239 | 266 | else if (operatorname.equals("includes")) |
240 | 267 | res = ((IExpression) translateAtlOcl(argumentso.get(0))) |
241 | 268 | .in((IExpression) src); |
| 269 | + else if (operatorname.equals("includesAll")) |
| 270 | + res = ((IExpression) translateAtlOcl(argumentso.get(0))) |
| 271 | + .in((IExpression) src); |
| 272 | + else if (operatorname.equals("excludes")) |
| 273 | + res = ((IExpression) translateAtlOcl(argumentso.get(0))) |
| 274 | + .in((IExpression) src).not(); |
| 275 | + else if (operatorname.equals("excludesAll")) |
| 276 | + res = ((IExpression) translateAtlOcl(argumentso.get(0))) |
| 277 | + .in((IExpression) src).not(); |
242 | 278 | else if (operatorname.equals("oclAsSet") |
243 | 279 | || operatorname.equals("asSet")) |
244 | 280 | res = src; |
| 281 | + else if (operatorname.equals("oclIsKindOf")) |
| 282 | + res = ((IExpression) src).in((IExpression) translateAtlOcl(argumentso.get(0))); |
| 283 | + else if (operatorname.equals("oclAsType")) |
| 284 | + res = ((IExpression) src); |
245 | 285 | else if (operatorname.equals("+")) |
246 | 286 | res = ((IIntExpression) src) |
247 | 287 | .plus((IIntExpression) translateAtlOcl(argumentso.get(0))); |
248 | | - else if (operatorname.equals("-")) |
249 | | - res = ((IIntExpression) src) |
250 | | - .minus((IIntExpression) translateAtlOcl(argumentso.get(0))); |
| 288 | + else if (operatorname.equals("-")) { |
| 289 | + INode x = translateAtlOcl(argumentso.get(0)); |
| 290 | + if (src instanceof IIntExpression && x instanceof IIntExpression) |
| 291 | + res = ((IIntExpression) src).minus((IIntExpression) x); |
| 292 | + else |
| 293 | + res = ((IIntExpression) src).difference((IIntExpression) x); |
| 294 | + } |
251 | 295 | else if (operatorname.equals("allInstances")) |
252 | 296 | res = src; |
253 | 297 | else if (((EATLTransformation) context.getCallerRel().transformation.transformation).getRelation(operatorname) != null) { |
|
0 commit comments