]> gerrit.simantics Code Review - simantics/platform.git/blobdiff - bundles/org.simantics.scl.compiler/src/org/simantics/scl/compiler/elaboration/expressions/block/ConstraintStatement.java
New type class MonadE and corresponding monad syntax with edo keyword
[simantics/platform.git] / bundles / org.simantics.scl.compiler / src / org / simantics / scl / compiler / elaboration / expressions / block / ConstraintStatement.java
index 54437c9bac77f83fe7ae3c1b334ed0e59a72969a..6ff4c487791176278b66171213756073460e6f27 100644 (file)
@@ -1,54 +1,59 @@
-package org.simantics.scl.compiler.elaboration.expressions.block;\r
-\r
-import org.simantics.scl.compiler.elaboration.contexts.EnvironmentalContext;\r
-import org.simantics.scl.compiler.elaboration.contexts.TranslationContext;\r
-import org.simantics.scl.compiler.elaboration.expressions.Expression;\r
-import org.simantics.scl.compiler.errors.Locations;\r
-import org.simantics.scl.compiler.internal.parsing.Token;\r
-import org.simantics.scl.compiler.internal.parsing.types.TypeAst;\r
-\r
-public class ConstraintStatement extends Statement {\r
-\r
-    public Token name;\r
-    public TypeAst[] parameterTypes;\r
-    \r
-    public ConstraintStatement(Token name, TypeAst[] parameterTypes) {\r
-        this.name = name;\r
-        this.parameterTypes = parameterTypes;\r
-    }\r
-    \r
-    @Override\r
-    public void setLocationDeep(long loc) {\r
-        if(location == Locations.NO_LOCATION) {\r
-            location = loc;\r
-            for(TypeAst parameterType : parameterTypes)\r
-                if(parameterType.location == Locations.NO_LOCATION)\r
-                    parameterType.location = location;\r
-        }\r
-    }\r
-\r
-    @Override\r
-    public Expression toExpression(EnvironmentalContext context, boolean monadic, Expression in) {\r
-        throw new UnsupportedOperationException();\r
-    }\r
-\r
-    @Override\r
-    public void resolvePattern(TranslationContext context) {\r
-        throw new UnsupportedOperationException();\r
-    }\r
-\r
-    @Override\r
-    public boolean mayBeRecursive() {\r
-        throw new UnsupportedOperationException();\r
-    }\r
-\r
-    @Override\r
-    public void accept(StatementVisitor visitor) {\r
-        throw new UnsupportedOperationException();\r
-    }\r
-\r
-    @Override\r
-    public StatementGroup getStatementGroup() {\r
-        return StatementGroup.CHR;\r
-    }\r
-}\r
+package org.simantics.scl.compiler.elaboration.expressions.block;
+
+import org.simantics.scl.compiler.elaboration.contexts.EnvironmentalContext;
+import org.simantics.scl.compiler.elaboration.contexts.TranslationContext;
+import org.simantics.scl.compiler.elaboration.expressions.Expression;
+import org.simantics.scl.compiler.errors.Locations;
+import org.simantics.scl.compiler.internal.parsing.Token;
+import org.simantics.scl.compiler.internal.parsing.declarations.DAnnotationAst;
+import org.simantics.scl.compiler.internal.parsing.types.TypeAst;
+
+public class ConstraintStatement extends Statement {
+
+    public Token name;
+    public TypeAst[] parameterTypes;
+    public String[] fieldNames;
+    public DAnnotationAst[] annotations;
+    
+    public ConstraintStatement(Token name, TypeAst[] parameterTypes, String[] fieldNames, DAnnotationAst[] annotations) {
+        this.name = name;
+        this.parameterTypes = parameterTypes;
+        this.fieldNames = fieldNames;
+        this.annotations = annotations;
+    }
+    
+    @Override
+    public void setLocationDeep(long loc) {
+        if(location == Locations.NO_LOCATION) {
+            location = loc;
+            for(TypeAst parameterType : parameterTypes)
+                if(parameterType.location == Locations.NO_LOCATION)
+                    parameterType.location = location;
+        }
+    }
+
+    @Override
+    public Expression toExpression(EnvironmentalContext context, BlockType blockType, Expression in) {
+        throw new UnsupportedOperationException();
+    }
+
+    @Override
+    public void resolvePattern(TranslationContext context) {
+        throw new UnsupportedOperationException();
+    }
+
+    @Override
+    public boolean mayBeRecursive() {
+        throw new UnsupportedOperationException();
+    }
+
+    @Override
+    public void accept(StatementVisitor visitor) {
+        throw new UnsupportedOperationException();
+    }
+
+    @Override
+    public StatementGroup getStatementGroup() {
+        return StatementGroup.CHR;
+    }
+}