X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=bundles%2Forg.simantics.scl.compiler%2Fsrc%2Forg%2Fsimantics%2Fscl%2Fcompiler%2Finternal%2Fparsing%2Fparser%2FSCLParserImpl.java;h=7cf1fb754a954a3b29f13415a036f99c364d8b1f;hb=caad4b50af37ff3731a3e9a557dc697e9116de56;hp=bda298bd661afd593eb59fc5766f9a6b72ba46da;hpb=fe1a2f532761669e67da4db4ae15096ced8a04db;p=simantics%2Fplatform.git diff --git a/bundles/org.simantics.scl.compiler/src/org/simantics/scl/compiler/internal/parsing/parser/SCLParserImpl.java b/bundles/org.simantics.scl.compiler/src/org/simantics/scl/compiler/internal/parsing/parser/SCLParserImpl.java index bda298bd6..7cf1fb754 100644 --- a/bundles/org.simantics.scl.compiler/src/org/simantics/scl/compiler/internal/parsing/parser/SCLParserImpl.java +++ b/bundles/org.simantics.scl.compiler/src/org/simantics/scl/compiler/internal/parsing/parser/SCLParserImpl.java @@ -57,6 +57,7 @@ import org.simantics.scl.compiler.elaboration.expressions.accessor.FieldAccessor import org.simantics.scl.compiler.elaboration.expressions.accessor.IdAccessor; import org.simantics.scl.compiler.elaboration.expressions.accessor.StringAccessor; import org.simantics.scl.compiler.elaboration.expressions.block.BindStatement; +import org.simantics.scl.compiler.elaboration.expressions.block.BlockType; import org.simantics.scl.compiler.elaboration.expressions.block.CHRStatement; import org.simantics.scl.compiler.elaboration.expressions.block.ConstraintStatement; import org.simantics.scl.compiler.elaboration.expressions.block.GuardStatement; @@ -761,7 +762,14 @@ public class SCLParserImpl extends SCLParser { protected Object reduceDo() { EBlock block = (EBlock)get(1); Token doToken = (Token)get(0); - block.setMonadic( doToken.text.equals("mdo") ); + switch(doToken.text) { + case "mdo": + block.setBlockType(BlockType.Monad); + break; + case "edo": + block.setBlockType(BlockType.MonadE); + break; + } block.location = Locations.location(Locations.beginOf(doToken.location), Locations.endOf(block.location)); return block; } @@ -1339,4 +1347,9 @@ public class SCLParserImpl extends SCLParser { return new CHRStatement((CHRAstQuery)get(0), (CHRAstQuery)get(2)); } + @Override + protected Object reduceWildcard() { + return new FieldAssignment(FieldAssignment.WILDCARD, null); + } + }