File: LR.g

package info (click to toggle)
frown 0.6.1-13
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 9,956 kB
  • sloc: haskell: 35,132; makefile: 228; csh: 35; yacc: 23
file content (38 lines) | stat: -rw-r--r-- 719 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
{-

This grammar is LR(1) but not LALR(1). However, thanks to the stack
information there is no reduce/reduce conflict. In the traditional
setting only the look-ahead information and the current state is used
to determine the reducing production. Here, we can use also the past,
ie the path to the current state.

Exercise 4.40, dragon book.

	frown --debug LR.g

-}

module LR
where

type Terminal                   =  Char

type Result                     =  []

%{

Terminal                        =  'a' | 'b' | 'c' | 'd';
Nonterminal                     =   s  |  x  |  y;

s :  x, 'a';
  | 'b', x, 'c';
  |  y, 'c';
  | 'b', y, 'a';

x : 'd';

y : 'd';

}%

frown ts                        =  fail "syntax error"