aboutsummaryrefslogtreecommitdiff
path: root/gen
diff options
context:
space:
mode:
Diffstat (limited to 'gen')
-rwxr-xr-xgen/prop/slc53
-rwxr-xr-xgen/prop/stc45
-rwxr-xr-xgen/prop/suc53
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