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
)