5 # Generate opcodes.h, opcodes.h
7 # Copyright (c) 2008 Matthias Kramm <kramm@quiss.org>
9 # This program is free software; you can redistribute it and/or modify
10 # it under the terms of the GNU General Public License as published by
11 # the Free Software Foundation; either version 2 of the License, or
12 # (at your option) any later version.
14 # This program is distributed in the hope that it will be useful,
15 # but WITHOUT ANY WARRANTY; without even the implied warranty of
16 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 # GNU General Public License for more details.
19 # You should have received a copy of the GNU General Public License
20 # along with this program; if not, write to the Free Software
21 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
25 fi = open("code.c", "rb")
26 foc = open("opcodes.c", "wb")
27 foh = open("opcodes.h", "wb")
29 foh.write("#ifndef __opcodes_h__\n")
30 foh.write("#define __opcodes_h__\n")
31 foh.write("#include \"abc.h\"\n")
32 foh.write("#include \"pool.h\"\n")
33 foh.write("#include \"code.h\"\n")
35 foc.write("#include \"opcodes.h\"\n")
37 R = re.compile('{(0x..),\s*"([^"]*)"\s*,\s*"([^"]*)"[^}]*}\s*')
39 for line in fi.readlines():
43 op,name,params = m.group(1),m.group(2),m.group(3)
49 for iteration in range(iterations):
52 params = params.strip()
61 type,pname="char*","name"
63 type,pname="multiname_t*","name"
65 type,pname="char*","s"
69 type,pname="abc_method_t*","m"
71 type,pname="abc_method_body_t*","m"
73 type,pname="abc_class_t*","m"
75 type,pname="code_t*","label"
77 type,pname="lookupswitch_t*","l"
79 type,pname="void*","debuginfo"
81 type,pname="int","reg"
83 type,pname="double","f"
87 type,pname="unsigned int","u"
89 raise "Unknown type "+c
94 pname += str(seen[pname])
100 foh.write("code_t* abc_%s(code_t*prev%s);\n" % (name, paramstr))
102 foc.write("code_t* abc_%s(code_t*prev%s)\n" % (name, paramstr))
104 foc.write(" code_t*self = add_opcode(prev, %s);\n" % op)
106 for pname,c in zip(names,params):
109 foc.write(" self->data[%d] = multiname_fromstring(%s);\n" % (i,pname));
111 foc.write(" self->data[%d] = multiname_clone(%s);\n" % (i,pname));
113 foc.write(" self->data[%d] = (void*)(ptroff_t)%s;\n" % (i,pname))
115 foc.write(" self->data[%d] = (void*)(ptroff_t)%s;\n" % (i,pname))
117 foc.write(" double*fp = malloc(sizeof(double));\n")
118 foc.write(" *fp = %s;\n" % (pname))
119 foc.write(" self->data[%d] = fp;\n" % (i))
121 foc.write(" self->data[%d] = (void*)(ptroff_t)%s;\n" % (i,pname))
123 foc.write(" self->data[%d] = strdup(%s);\n" % (i,pname))
125 foc.write(" self->data[%d] = %s;\n" % (i,pname))
127 foc.write(" self->data[%d] = %s;\n" % (i,pname))
129 foc.write(" self->data[%d] = %s;\n" % (i,pname))
131 foc.write(" self->data[%d] = 0; //placeholder\n" % i)
132 foc.write(" self->branch = %s;\n" % pname)
134 foc.write(" self->data[%d] = %s;\n" % (i,pname))
136 foc.write(" /* FIXME: write debuginfo %s */\n" % pname)
138 raise "Unknown type "+c
140 foc.write(" return self;\n")
143 foh.write("#define "+name+"(")
144 foh.write(",".join(["method"]+names))
145 foh.write(") (method->code = abc_"+name+"(")
146 foh.write(",".join(["method->code"]+names))
149 foh.write("#define OPCODE_"+name.upper()+" "+op+"\n")
151 foh.write("#endif\n")
156 #{0x75, "convert_d", ""},