annotate pyrect/pyrect/regexp/fa.py @ 9:493c96d030c0

add pyrect
author nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
date Tue, 14 Jun 2011 17:24:03 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
9
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
1 #!/usr/bin/env python
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
2
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
3 from pyrect.regexp.ast import AnyChar, Range
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
4
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
5 class FA(object):
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
6 def __init__(self, transition, start, accepts, states=None):
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
7 self.transition = transition
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
8 self.start = start
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
9 self.accepts = accepts
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
10 self.states = states
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
11
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
12 def accept(self, laungage):
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
13 return False
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
14
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
15 class Transition(dict):
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
16 def __setitem__(self, key, value):
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
17 if type(key) == tuple:
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
18 (state, input) = key
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
19 if self.has_key(state):
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
20 self[state][input] = value
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
21 else:
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
22 self[state] = {input: value}
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
23 else:
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
24 if not isinstance(value, dict):
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
25 raise "Transition.__setitem__: invalid item!"
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
26 dict.__setitem__(self, key, value)
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
27
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
28 def __getitem__(self, key):
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
29 if type(key) == tuple:
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
30 (state, input) = key
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
31 if self.has_key(state) and self[state].has_key(input):
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
32 return self[state][input]
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
33 else:
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
34 return None
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
35 else:
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
36 if self.has_key(key):
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
37 return dict.__getitem__(self, key)
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
38 else:
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
39 return None
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
40
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
41 def __str__(self):
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
42 string = "Transition:"
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
43 for (s, i), ns in self.itertrans():
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
44 string += " %s x %s -> %s," % (s, i, ns)
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
45 return string
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
46
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
47 def iterstates(self):
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
48 for s, t in self.iteritems():
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
49 yield s, t
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
50
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
51 def itertrans(self):
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
52 for s, v in self.iteritems():
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
53 for i, n in v.iteritems():
493c96d030c0 add pyrect
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
54 yield (s, i), n