import sys
import re
import optparse
+from urllib2 import urlopen
def stderr(x):
class TxtParser(LineParser):
+ section_re = re.compile(r'^([A-Z]\w+)( \w+)*$')
+
property_re = re.compile(r'^\w+:')
prototype_re = re.compile(r'^(\w+)\((.*)\)$')
self.prefix = prefix
def parse(self):
- line = self.consume()
- while not line.startswith("New Procedures and Functions"):
+ while not self.eof():
+ while not self.eof():
+ line = self.lookahead()
+ if self.eof():
+ return
+ mo = self.section_re.match(line)
+ if mo:
+ break
+ self.consume()
line = self.consume()
- self.parse_procs()
+ self.parse_section(line)
+ print
+
+ def parse_section(self, name):
+ if name == 'Name Strings':
+ self.parse_strings()
+ if name == 'New Procedures and Functions':
+ self.parse_procs()
+
+ def parse_strings(self):
+ while not self.eof():
+ line = self.lookahead()
+ if not line.strip():
+ self.consume()
+ continue
+ if not line.startswith(' '):
+ break
+ self.consume()
+ name = line.strip()
+ print ' # %s' % name
def parse_procs(self):
lines = []
- while True:
- line = self.consume()
+ while not self.eof():
+ line = self.lookahead()
if not line.strip():
+ self.consume()
continue
if not line.startswith(' '):
break
+ self.consume()
lines.append(line.strip())
- if line.endswith(';'):
- self.parse_proc(' '.join(lines))
+ if line[-1] in (';', ')'):
+ prototype = ' '.join(lines)
+ self.parse_proc(prototype)
lines = []
token_re = re.compile(r'(\w+|\s+|.)')
def main():
- for arg in sys.argv[1:]:
- parser = TxtParser(open(arg, 'rt'), prefix='gl')
+ optparser = optparse.OptionParser(
+ usage="\n\t%prog [options] [SPEC] ")
+ optparser.add_option(
+ '-p', '--prefix', metavar='STRING',
+ type="string", dest="prefix", default='gl',
+ help="function prefix [default: %default]")
+
+ (options, args) = optparser.parse_args(sys.argv[1:])
+
+ for arg in args:
+ if arg.startswith('http://'):
+ stream = urlopen(arg, 'rt')
+ else:
+ stream = open(arg, 'rt')
+ parser = TxtParser(stream, prefix = options.prefix)
parser.parse()