| #! /ufs/guido/bin/sgi/python | 
 | #! /usr/local/python | 
 |  | 
 | # Read #define's from stdin and translate to Python code on stdout. | 
 | # Very primitive: non-#define's are ignored, no check for valid Python | 
 | # syntax is made -- you will have to edit the output in most cases. | 
 |  | 
 | # XXX To do: | 
 | # - accept filename arguments | 
 | # - turn trailing C comments into Python comments | 
 | # - turn C string quotes into Python comments | 
 | # - turn C Boolean operators "&& || !" into Python "and or not" | 
 | # - what to do about #if(def)? | 
 | # - what to do about macros with parameters? | 
 | # - reject definitions with semicolons in them | 
 |  | 
 | import sys, regex, string | 
 |  | 
 | p_define = regex.compile('^#[\t ]*define[\t ]+\([a-zA-Z0-9_]+\)[\t ]+') | 
 |  | 
 | p_comment = regex.compile('/\*\([^*]+\|\*+[^/]\)*\*+/') | 
 |  | 
 | def main(): | 
 | 	process(sys.stdin) | 
 |  | 
 | def process(fp): | 
 | 	lineno = 0 | 
 | 	while 1: | 
 | 		line = fp.readline() | 
 | 		if not line: break | 
 | 		lineno = lineno + 1 | 
 | 		if p_define.match(line) >= 0: | 
 | 			# gobble up continuation lines | 
 | 			while line[-2:] == '\\\n': | 
 | 				nextline = fp.readline() | 
 | 				if not nextline: break | 
 | 				lineno = lineno + 1 | 
 | 				line = line + nextline | 
 | 			regs = p_define.regs | 
 | 			a, b = regs[1] # where the macro name is | 
 | 			name = line[a:b] | 
 | 			a, b = regs[0] # the whole match | 
 | 			body = line[b:] | 
 | 			# replace comments by spaces | 
 | 			while p_comment.search(body) >= 0: | 
 | 				a, b = p_comment.regs[0] | 
 | 				body = body[:a] + ' ' + body[b:] | 
 | 			print name, '=', string.strip(body) | 
 |  | 
 | main() |