1 #!/usr/local/bin/python
2 # -*- coding: iso-8859-1 -*-
6 # Copyright (c) 2004 Kungliga Tekniska Högskolan
7 # (Royal Institute of Technology, Stockholm, Sweden).
10 # Redistribution and use in source and binary forms, with or without
11 # modification, are permitted provided that the following conditions
14 # 1. Redistributions of source code must retain the above copyright
15 # notice, this list of conditions and the following disclaimer.
17 # 2. Redistributions in binary form must reproduce the above copyright
18 # notice, this list of conditions and the following disclaimer in the
19 # documentation and/or other materials provided with the distribution.
21 # 3. Neither the name of the Institute nor the names of its contributors
22 # may be used to endorse or promote products derived from this software
23 # without specific prior written permission.
25 # THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
26 # ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
27 # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
28 # ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
29 # FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
30 # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
31 # OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
32 # HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
33 # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
34 # OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
47 if len(sys.argv) != 3:
48 print "usage: %s rfc3454.txt out-dir" % sys.argv[0]
51 tables = rfc3454.read(sys.argv[1])
54 for x in t2.iterkeys():
57 map_list = stringprep.get_maplist()
59 map_h = generate.Header('%s/map_table.h' % sys.argv[2])
61 map_c = generate.Implementation('%s/map_table.c' % sys.argv[2])
69 unsigned short val_len;
70 unsigned short val_offset;
71 wind_profile_flags flags;
74 extern const struct translation _wind_map_table[];
76 extern const size_t _wind_map_table_size;
78 extern const uint32_t _wind_map_table_val[];
84 #include "map_table.h"
86 const struct translation _wind_map_table[] = {
91 for t in map_list.iterkeys():
93 m = re.search('^ *([0-9A-F]+)-([0-9A-F]+); *([^;]+); *(.*) *$', l)
95 start = int(m.group(1), 0x10)
96 end = int(m.group(2), 0x10)
99 for key in xrange(start,end,1):
100 trans.append((key, value, desc, [t]))
102 m = re.search('^ *([^;]+); *([^;]+); *(.*) *$', l)
104 key = int(m.group(1), 0x10)
107 trans.append((key, value, desc, [t]))
113 trans = stringprep.sort_merge_trans(trans)
117 print "fooresult %s" % ",".join(x[3])
120 (key, value, description, table) = x
122 i = util.subList(valTable, v)
126 offsetTable[key] = len(valTable)
130 (key, value, description, tables) = x
131 symbols = stringprep.symbols(map_list, tables)
132 if len(symbols) == 0:
133 print "no symbol for %s %s (%s)" % (key, description, tables)
136 map_c.file.write(" {0x%x, %u, %u, %s}, /* %s: %s */\n"
137 % (key, len(v), offsetTable[key], symbols, ",".join(tables), description))
146 "const size_t _wind_map_table_size = %u;\n\n" % len(trans))
149 "const uint32_t _wind_map_table_val[] = {\n")
152 map_c.file.write(" 0x%s,\n" % x)