File: ident.py

package info (click to toggle)
antlr 2.7.6-7
  • links: PTS
  • area: main
  • in suites: etch, etch-m68k
  • size: 9,816 kB
  • ctags: 10,149
  • sloc: java: 54,608; cs: 12,515; makefile: 8,978; cpp: 7,362; pascal: 5,273; python: 4,301; sh: 4,221; lisp: 1,969; xml: 198; lex: 192; ansic: 127
file content (51 lines) | stat: -rwxr-xr-x 1,158 bytes parent folder | download | duplicates (11)
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
39
40
41
42
43
44
45
46
47
48
49
50
51
import sys
import antlr
import codecs

import ident_l,ident_p

def warn(msg):
   print >>sys.stderr,"warning:",msg
   sys.stderr.flush()

def error(msg):
   print >>sys.stderr,"error:",msg
   sys.stderr.flush()
   sys.exit(1)

### Unicode  handling  depends very much on  whether
### your  terminal can  handle (print) unicode chars.

### To  be  sure  about  it, just create a non ASCII
### letter and try to print it. If that is not going
### to work, we create an  alternative  method which
### maps non printable chars to '?'.

c = u"\N{LATIN SMALL LETTER O WITH ACUTE}"

try:
   print c
except:
   warn("terminal can't display unicode chars.")
   sys.stderr.flush()

   ## I'm just going to redefine 'unicode' to return
   ## a ASCII string.
   def unicode(x):
      return x.__str__().encode("ascii","replace")


### Now for the input. This should ideally  be  done
### in the lexer ..

### replace  stdin  with  a  wrapper that spits out
### unicode chars.
try:
   sys.stdin = codecs.lookup('Shift-JIS')[-2](sys.stdin)
except:
   warn("Japanese codecs required - please install.")
   sys.exit(0)

L = ident_l.Lexer()
P = ident_p.Parser(L)
P.program()