diff options
Diffstat (limited to 'gen/prop')
-rwxr-xr-x | gen/prop/slc | 53 | ||||
-rwxr-xr-x | gen/prop/stc | 45 | ||||
-rwxr-xr-x | gen/prop/suc | 53 |
3 files changed, 151 insertions, 0 deletions
diff --git a/gen/prop/slc b/gen/prop/slc new file mode 100755 index 0000000..57ee4c0 --- /dev/null +++ b/gen/prop/slc @@ -0,0 +1,53 @@ +#!/bin/sh + +set -e +cd "${0%/*}/../.." +exec >lib/unicode/prop/uprop_get_slc.c + +gawk ' +BEGIN { + FS = ";" + + print "/* This file is autogenerated by gen/prop/slc; DO NOT EDIT. */" + print "" + print "#include \"__bsearch.h\"" + print "#include \"macros.h\"" + print "#include \"rune.h\"" + print "#include \"unicode/prop.h\"" + print "" +} + +length($14) > 0 { + map[strtonum("0X" $1)] = strtonum("0X" $14) +} + +END { + print "static constexpr rune lookup_lat1[] = {" + for (i = 0; i < 0x100; i++) { + if (i % 8 == 0) + printf "\t" + printf "0x%03X,%s", map[i] ? map[i] : i, i % 8 == 7 ? "\n" : " " + } + print "};" + print "" + print "static const struct {" + print "\trune k, v;" + print "} lookup[] = {" + + for (i = 0x100; i <= 0x10FFFF; i++) { + if (!map[i]) + continue + printf "\t{RUNE_C(0x%06X), RUNE_C(0x%06X)},\n", i, map[i] + } + + print "};" + print "" + print "__MLIB_DEFINE_BSEARCH_KV(rune, lookup, ch)" + print "" + print "rune" + print "uprop_get_slc(rune ch)" + print "{" + print "\treturn ch < lengthof(lookup_lat1) ? lookup_lat1[ch] : mlib_lookup_kv(ch);" + print "}" +} +' data/UnicodeData.txt diff --git a/gen/prop/stc b/gen/prop/stc new file mode 100755 index 0000000..42dca19 --- /dev/null +++ b/gen/prop/stc @@ -0,0 +1,45 @@ +#!/bin/sh + +set -e +cd "${0%/*}/../.." +exec >lib/unicode/prop/uprop_get_stc.c + +gawk ' +BEGIN { + FS = ";" + + print "/* This file is autogenerated by gen/prop/stc; DO NOT EDIT. */" + print "" + print "#include \"__bsearch.h\"" + print "#include \"macros.h\"" + print "#include \"rune.h\"" + print "#include \"unicode/prop.h\"" + print "" +} + +length($15) > 0 && $13 != $15 && $1 != $15 { + map[strtonum("0X" $1)] = strtonum("0X" $15) +} + +END { + print "static const struct {" + print "\trune k, v;" + print "} lookup[] = {" + + for (i = 0x100; i <= 0x10FFFF; i++) { + if (!map[i]) + continue + printf "\t{RUNE_C(0x%06X), RUNE_C(0x%06X)},\n", i, map[i] + } + + print "};" + print "" + print "__MLIB_DEFINE_BSEARCH_KV(rune, lookup, uprop_get_suc(ch))" + print "" + print "rune" + print "uprop_get_stc(rune ch)" + print "{" + print "\treturn mlib_lookup_kv(ch);" + print "}" +} +' data/UnicodeData.txt diff --git a/gen/prop/suc b/gen/prop/suc new file mode 100755 index 0000000..8a53060 --- /dev/null +++ b/gen/prop/suc @@ -0,0 +1,53 @@ +#!/bin/sh + +set -e +cd "${0%/*}/../.." +exec >lib/unicode/prop/uprop_get_suc.c + +gawk ' +BEGIN { + FS = ";" + + print "/* This file is autogenerated by gen/prop/suc; DO NOT EDIT. */" + print "" + print "#include \"__bsearch.h\"" + print "#include \"macros.h\"" + print "#include \"rune.h\"" + print "#include \"unicode/prop.h\"" + print "" +} + +length($13) > 0 { + map[strtonum("0X" $1)] = strtonum("0X" $13) +} + +END { + print "static constexpr rune lookup_lat1[] = {" + for (i = 0; i < 0x100; i++) { + if (i % 8 == 0) + printf "\t" + printf "0x%03X,%s", map[i] ? map[i] : i, i % 8 == 7 ? "\n" : " " + } + print "};" + print "" + print "static const struct {" + print "\trune k, v;" + print "} lookup[] = {" + + for (i = 0x100; i <= 0x10FFFF; i++) { + if (!map[i]) + continue + printf "\t{RUNE_C(0x%06X), RUNE_C(0x%06X)},\n", i, map[i] + } + + print "};" + print "" + print "__MLIB_DEFINE_BSEARCH_KV(rune, lookup, ch)" + print "" + print "rune" + print "uprop_get_suc(rune ch)" + print "{" + print "\treturn ch < lengthof(lookup_lat1) ? lookup_lat1[ch] : mlib_lookup_kv(ch);" + print "}" +} +' data/UnicodeData.txt |