2 /******************************************************************************
11 initial equationBlock ;
14 = (declaration (SEMICOLON declaration)*)? # Module
18 = command? # OneCommand
19 | commands SEMICOLON command # ManyCommands
23 = statement # StatementCommand
24 | import # ImportCommand
27 /******************************************************************************
32 = LBRACE (declaration (SEMICOLON declaration)*)? RBRACE # Declarations
36 = MODULE LBRACE (field (COMMA field)*)? RBRACE # ModuleHeader
37 | var (COMMA var)* HASTYPE type # TypeAnnotation
38 | bexp rhs # ValueDefinition
39 | DATA ID+ (EQUALS constructor (BAR constructor)*)? # DataDefinition
40 | TYPE ID+ EQUALS type # TypeDefinition
43 (WHERE declarations)? # ClassDefinition
44 | INSTANCE context? ID atype+ (WHERE declarations)? # InstanceDefinition
45 | DERIVING INSTANCE context? ID atype+ # DerivingInstanceDefinition
46 | BEGIN_STRING END_STRING # DocumentationString
47 | ANNOTATION_ID aexp* # Annotation
48 | (INFIX | INFIXL | INFIXR) INTEGER var (COMMA var)* # PrecedenceDefinition
50 | IMPORTJAVA BEGIN_STRING END_STRING WHERE declarations # ImportJava
51 | EFFECT ID BEGIN_STRING END_STRING
52 BEGIN_STRING END_STRING # EffectDefinition
53 | (RULE | ABSTRACT_RULE) ID
54 (EXTENDS ID (COMMA ID)*)?
55 WHERE ruleDeclarations # RuleDefinition
56 | MAPPING_RELATION ID atype* # MappingRelationDefinition
57 | bexp FOLLOWS ruleDeclarations # RelationDefinition
62 BEGIN_STRING END_STRING
68 = LPAREN (importItem (COMMA importItem)*)? RPAREN # ImportShowing
69 | HIDING LPAREN (importItem (COMMA importItem)*)? RPAREN # ImportHiding
73 = ID # ImportValueItem
74 // | (TYPE | DATA) ID # ImportTypeItem
75 // | CLASS ID # ImportClassItem
80 = (ANNOTATION_ID aexp)* ID atype* # Constructor
81 | (ANNOTATION_ID aexp)* ID LBRACE
82 fieldDeclaration (COMMA fieldDeclaration)* RBRACE # RecordConstructor
86 = ID HASTYPE type # FieldDescription
89 rhs = EQUALS exp (WHERE statements)? # SimpleRhs
90 | guardedExpEq+ (WHERE statements)? # GuardedRhs
94 = BAR exp (COMMA exp)* EQUALS exp # GuardedExpEq
98 = ID+ ARROW ID # Fundep
102 = fundep (COMMA fundep)* # Fundeps
105 /******************************************************************************
110 = LBRACE (ruleDeclaration (SEMICOLON ruleDeclaration)*)? RBRACE # RuleDeclarations
114 = query # QueryRuleDeclaration
115 | ANNOTATION_ID aexp* # Annotation
118 /******************************************************************************
122 exp = bexp (HASTYPE type)? # LocalTypeAnnotation, shift HASTYPE, shift COLON
123 | bexp COLON ID WITH? queryBlock? # EntityTypeAnnotation, shift LBRACE, shift WITH
127 = MINUS? lexp (symbol lexp)* # Binary, shift MINUS, shift SYMBOL,
128 shift LESS, shift GREATER, shift SEPARATED_DOT,
133 = faexp+ # Apply, shift ID, shift LAMBDA, shift LAMBDA_MATCH,
134 shift LET, shift INTEGER, shift BEGIN_STRING,
135 shift IF, shift MATCH, shift DO,
136 shift MDO, shift ENFORCE, shift BLANK,
137 shift FLOAT, shift LPAREN, shift LBRACKET,
138 shift ESCAPED_SYMBOL, shift CHAR, shift LBRACE,
139 shift WHEN, shift ATTACHED_HASH,
140 shift SELECT, shift SELECT_FIRST, shift SELECT_DISTINCT,
141 shift TRANSFORMATION, shift EQ
145 = aexp ((ATTACHED_DOT | ATTACHED_HASH) accessor)* # FieldAccess, shift ATTACHED_DOT, shift ATTACHED_HASH
150 | BEGIN_STRING END_STRING # StringAccessor
151 | LPAREN exp RPAREN # ExpAccessor
155 = LAMBDA aexp+ ARROW exp # Lambda, shift HASTYPE
156 | LAMBDA_MATCH LBRACE case (SEMICOLON case)* RBRACE # LambdaMatch, shift HASTYPE
157 | LET statements IN exp # Let, shift HASTYPE
158 | IF exp THEN exp (ELSE exp)? # If, shift HASTYPE, shift ELSE
160 LBRACE case (SEMICOLON case)* RBRACE # Match
161 | (DO | MDO) statements # Do
162 | (SELECT | SELECT_FIRST | SELECT_DISTINCT)
163 exp WHERE queryBlock # Select
164 | ENFORCE queryBlock # Enforce
165 //| WHEN queryBlock SEMICOLON exp # When
167 | ATTACHED_HASH ID # HashedId
171 | stringLiteral # String
173 | LPAREN (exp (COMMA exp)*)? RPAREN # Tuple
174 | LPAREN exp ARROW exp RPAREN # ViewPattern
175 | LPAREN symbolWithoutMinus lexp RPAREN # RightSection
176 | LPAREN lexp symbol RPAREN # LeftSection
177 | LBRACKET (exp (COMMA exp)*)? RBRACKET # ListLiteral
178 | LBRACKET exp DOTDOT exp RBRACKET # Range
180 listQualifier (COMMA listQualifier)* RBRACKET # ListComprehension
182 | ID LBRACE (field (COMMA field)*)? RBRACE # Record
183 | TRANSFORMATION ID WHERE queryBlock # Transformation
184 | EQ LBRACE equationBlock RBRACE # Eq
188 = BEGIN_STRING (SUSPEND_STRING exp CONTINUE_STRING)*
189 END_STRING # StringLiteral
193 = LBRACE (statement (SEMICOLON statement)*)? RBRACE # Statements
197 = exp # GuardStatement
198 | exp rhs # LetStatement
199 | exp BINDS exp # BindStatement
200 | exp FOLLOWS queryBlock # RuleStatement
201 | chrQuery IMPLIES chrQuery # CHRStatement
202 | WHEN verboseChrQuery THEN_AFTER_WHEN verboseChrQuery # VerboseCHRStatement
203 | CONSTRAINT ID atype* # ConstraintStatement
207 = listQualifier (COMMA listQualifier)* # CHRQuery
211 = LBRACE listQualifier (SEMICOLON listQualifier)* RBRACE # VerboseCHRQuery
215 = exp # GuardQualifier
216 | exp EQUALS exp # LetQualifier
217 | exp BINDS exp # BindQualifier
218 | THEN exp (BY exp)? # ThenQualifier
226 = ARROW exp (WHERE statements)? # SimpleCaseRhs
227 | guardedExpArrow+ (WHERE statements)? # GuardedCaseRhs
231 = BAR exp (COMMA exp)* ARROW exp # GuardedExpArrow
235 = ID EQUALS exp # Field
236 | ID # FieldShorthand
239 /******************************************************************************
244 = LBRACE (query (SEMICOLON query)*)? RBRACE # QueryBlock
248 = exp # GuardQuery, shift BINDS, shift EQUALS
249 | exp EQUALS exp # EqualsQuery
250 | exp BINDS exp # BindQuery
251 | QUERY_OP queryBlock # CompositeQuery
254 /******************************************************************************
259 = (equation (SEMICOLON equation)*)? # EquationBlock
263 = exp # GuardEquation
264 | exp EQUALS exp # BasicEquation
267 /******************************************************************************
272 = LPAREN type (COMMA type)* RPAREN IMPLIES # Context
276 = etype ((ARROW | IMPLIES) etype)* # Arrow, shift ARROW, shift IMPLIES
280 = LESS ID (COMMA ID)* GREATER btype # Effect
282 | FORALL ID+ (SEPARATED_DOT | ATTACHED_DOT) type # ForAll
286 = atype+ # ApplyType, shift ID, shift LPAREN,
292 | LPAREN (type (COMMA type)*)? RPAREN # TupleType
293 | LBRACKET type RBRACKET # ListType
294 | LBRACKET RBRACKET # ListTypeConstructor
295 | LPAREN COMMA+ RPAREN # TupleTypeConstructor
298 /******************************************************************************
299 * Variables and symbols
303 | ESCAPED_SYMBOL # EscapedSymbol
304 | LPAREN COMMA+ RPAREN # TupleConstructor
309 | ESCAPED_ID # EscapedId
313 | SEPARATED_DOT # Dot
318 | ESCAPED_ID # EscapedId
321 | SEPARATED_DOT # Dot
324 /******************************************************************************
327 dummy = COMMENT EOL # Dummy