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
58 | RULESET ID WHERE statements # RulesetDefinition
63 BEGIN_STRING END_STRING
69 = LPAREN (importItem (COMMA importItem)*)? RPAREN # ImportShowing
70 | HIDING LPAREN (importItem (COMMA importItem)*)? RPAREN # ImportHiding
74 = ID # ImportValueItem
75 // | (TYPE | DATA) ID # ImportTypeItem
76 // | CLASS ID # ImportClassItem
81 = (ANNOTATION_ID aexp)* ID atype* # Constructor
82 | (ANNOTATION_ID aexp)* ID LBRACE
83 fieldDeclaration (COMMA fieldDeclaration)* RBRACE # RecordConstructor
87 = ID HASTYPE type # FieldDescription
90 rhs = EQUALS exp (WHERE statements)? # SimpleRhs
91 | guardedExpEq+ (WHERE statements)? # GuardedRhs
95 = BAR exp (COMMA exp)* EQUALS exp # GuardedExpEq
99 = ID+ ARROW ID # Fundep
103 = fundep (COMMA fundep)* # Fundeps
106 /******************************************************************************
111 = LBRACE (ruleDeclaration (SEMICOLON ruleDeclaration)*)? RBRACE # RuleDeclarations
115 = query # QueryRuleDeclaration
116 | ANNOTATION_ID aexp* # Annotation
119 /******************************************************************************
123 exp = bexp (HASTYPE type)? # LocalTypeAnnotation, shift HASTYPE, shift COLON
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
204 | INCLUDE ID aexp # LocalInclude
208 = listQualifier (COMMA listQualifier)* # CHRQuery
212 = LBRACE listQualifier (SEMICOLON listQualifier)* RBRACE # VerboseCHRQuery
216 = exp # GuardQualifier
217 | exp EQUALS exp # LetQualifier
218 | exp BINDS exp # BindQualifier
219 | THEN exp (BY exp)? # ThenQualifier
227 = ARROW exp (WHERE statements)? # SimpleCaseRhs
228 | guardedExpArrow+ (WHERE statements)? # GuardedCaseRhs
232 = BAR exp (COMMA exp)* ARROW exp # GuardedExpArrow
236 = ID EQUALS exp # Field
237 | ID # FieldShorthand
240 /******************************************************************************
245 = LBRACE (query (SEMICOLON query)*)? RBRACE # QueryBlock
249 = exp # GuardQuery, shift BINDS, shift EQUALS
250 | exp EQUALS exp # EqualsQuery
251 | exp BINDS exp # BindQuery
252 | QUERY_OP queryBlock # CompositeQuery
255 /******************************************************************************
260 = (equation (SEMICOLON equation)*)? # EquationBlock
264 = exp # GuardEquation
265 | exp EQUALS exp # BasicEquation
268 /******************************************************************************
273 = LPAREN type (COMMA type)* RPAREN IMPLIES # Context
277 = etype ((ARROW | IMPLIES) etype)* # Arrow, shift ARROW, shift IMPLIES
281 = LESS ID (COMMA ID)* GREATER btype # Effect
283 | FORALL ID+ (SEPARATED_DOT | ATTACHED_DOT) type # ForAll
287 = atype+ # ApplyType, shift ID, shift LPAREN,
293 | LPAREN (type (COMMA type)*)? RPAREN # TupleType
294 | LBRACKET type RBRACKET # ListType
295 | LBRACKET RBRACKET # ListTypeConstructor
296 | LPAREN COMMA+ RPAREN # TupleTypeConstructor
299 /******************************************************************************
300 * Variables and symbols
304 | ESCAPED_SYMBOL # EscapedSymbol
305 | LPAREN COMMA+ RPAREN # TupleConstructor
310 | ESCAPED_ID # EscapedId
314 | SEPARATED_DOT # Dot
319 | ESCAPED_ID # EscapedId
322 | SEPARATED_DOT # Dot
325 /******************************************************************************
328 dummy = COMMENT EOL # Dummy