|
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