003 File Manager
Current Path:
/usr/src/crypto/heimdal/lib/wind
usr
/
src
/
crypto
/
heimdal
/
lib
/
wind
/
π
..
π
ChangeLog
(3.32 KB)
π
CompositionExclusions-3.2.0.txt
(7.28 KB)
π
DerivedNormalizationProps.txt
(193.66 KB)
π
Makefile.am
(3.2 KB)
π
Makefile.in
(43.33 KB)
π
NTMakefile
(4.54 KB)
π
NormalizationCorrections.txt
(1.78 KB)
π
NormalizationTest.txt
(1.96 MB)
π
UnicodeData.py
(2.12 KB)
π
UnicodeData.txt
(876.37 KB)
π
bidi.c
(2.81 KB)
π
bidi_table.c
(6.65 KB)
π
bidi_table.h
(421 B)
π
combining.c
(2.27 KB)
π
combining_table.c
(8.13 KB)
π
combining_table.h
(374 B)
π
doxygen.c
(1.87 KB)
π
errorlist.c
(2.55 KB)
π
errorlist_table.c
(7.68 KB)
π
errorlist_table.h
(390 B)
π
gen-bidi.py
(3.18 KB)
π
gen-combining.py
(2.99 KB)
π
gen-errorlist.py
(3.53 KB)
π
gen-map.py
(4.24 KB)
π
gen-normalize.py
(5.62 KB)
π
gen-punycode-examples.py
(3.67 KB)
π
generate.py
(3.1 KB)
π
idn-lookup.c
(4.05 KB)
π
ldap.c
(2.68 KB)
π
libwind-exports.def
(491 B)
π
map.c
(2.68 KB)
π
map_table.c
(146.7 KB)
π
map_table.h
(437 B)
π
normalize.c
(7.31 KB)
π
normalize_table.c
(511.89 KB)
π
normalize_table.h
(713 B)
π
punycode.c
(4.44 KB)
π
punycode_examples.c
(4.5 KB)
π
punycode_examples.h
(457 B)
π
rfc3454.py
(2.24 KB)
π
rfc3454.txt
(135.43 KB)
π
rfc3490.txt
(50.73 KB)
π
rfc3491.txt
(10.07 KB)
π
rfc3492.txt
(65.86 KB)
π
rfc4013.txt
(12.75 KB)
π
rfc4518.py
(5.47 KB)
π
rfc4518.txt
(27.51 KB)
π
stringprep.c
(4.02 KB)
π
stringprep.py
(3.37 KB)
π
test-bidi.c
(2.57 KB)
π
test-ldap.c
(3.58 KB)
π
test-map.c
(2.83 KB)
π
test-normalize.c
(4.54 KB)
π
test-prohibited.c
(3.64 KB)
π
test-punycode.c
(2.74 KB)
π
test-rw.c
(3.97 KB)
π
test-utf8.c
(4.63 KB)
π
utf8.c
(12.46 KB)
π
util.py
(1.93 KB)
π
version-script.map
(547 B)
π
wind.h
(3.09 KB)
π
wind_err.et
(695 B)
π
windlocl.h
(2.34 KB)
Editing: gen-map.py
#!/usr/local/bin/python # -*- coding: iso-8859-1 -*- # $Id$ # Copyright (c) 2004 Kungliga Tekniska HΓΆgskolan # (Royal Institute of Technology, Stockholm, Sweden). # All rights reserved. # # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions # are met: # # 1. Redistributions of source code must retain the above copyright # notice, this list of conditions and the following disclaimer. # # 2. Redistributions in binary form must reproduce the above copyright # notice, this list of conditions and the following disclaimer in the # documentation and/or other materials provided with the distribution. # # 3. Neither the name of the Institute nor the names of its contributors # may be used to endorse or promote products derived from this software # without specific prior written permission. # # THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND # ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE # ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE # FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS # OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) # HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY # OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF # SUCH DAMAGE. import re import string import sys import generate import rfc3454 import rfc4518 import stringprep import util if len(sys.argv) != 3: print "usage: %s rfc3454.txt out-dir" % sys.argv[0] sys.exit(1) tables = rfc3454.read(sys.argv[1]) t2 = rfc4518.read() for x in t2.iterkeys(): tables[x] = t2[x] map_list = stringprep.get_maplist() map_h = generate.Header('%s/map_table.h' % sys.argv[2]) map_c = generate.Implementation('%s/map_table.c' % sys.argv[2]) map_h.file.write( ''' #include "windlocl.h" struct translation { uint32_t key; unsigned short val_len; unsigned short val_offset; wind_profile_flags flags; }; extern const struct translation _wind_map_table[]; extern const size_t _wind_map_table_size; extern const uint32_t _wind_map_table_val[]; ''') map_c.file.write( ''' #include "map_table.h" const struct translation _wind_map_table[] = { ''') trans=[] for t in map_list.iterkeys(): for l in tables[t]: m = re.search('^ *([0-9A-F]+)-([0-9A-F]+); *([^;]+); *(.*) *$', l) if m: start = int(m.group(1), 0x10) end = int(m.group(2), 0x10) value = m.group(3) desc = m.group(4) for key in xrange(start,end,1): trans.append((key, value, desc, [t])) continue m = re.search('^ *([^;]+); *([^;]+); *(.*) *$', l) if m: key = int(m.group(1), 0x10) value = m.group(2) desc = m.group(3) trans.append((key, value, desc, [t])) continue valTable = [] offsetTable = {} trans = stringprep.sort_merge_trans(trans) for x in trans: if x[0] == 0xad: print "fooresult %s" % ",".join(x[3]) for x in trans: (key, value, description, table) = x v = value.split() i = util.subList(valTable, v) if i: offsetTable[key] = i else: offsetTable[key] = len(valTable) valTable.extend(v) for x in trans: (key, value, description, tables) = x symbols = stringprep.symbols(map_list, tables) if len(symbols) == 0: print "no symbol for %s %s (%s)" % (key, description, tables) sys.exit(1) v = value.split() map_c.file.write(" {0x%x, %u, %u, %s}, /* %s: %s */\n" % (key, len(v), offsetTable[key], symbols, ",".join(tables), description)) map_c.file.write( ''' }; ''') map_c.file.write( "const size_t _wind_map_table_size = %u;\n\n" % len(trans)) map_c.file.write( "const uint32_t _wind_map_table_val[] = {\n") for x in valTable: map_c.file.write(" 0x%s,\n" % x) map_c.file.write( "};\n\n") map_h.close() map_c.close()
Upload File
Create Folder