diff options
author | Marius <mariausol@gmail.com> | 2011-05-13 12:40:12 +0300 |
---|---|---|
committer | Marius <mariausol@gmail.com> | 2011-05-13 12:40:12 +0300 |
commit | 4a00862b42dd8347bd782022a819fa9c3a32f9a2 (patch) | |
tree | 1360a3144185079a59795bd6503910988b6c9755 /tex/context/base/char-ini.lua | |
parent | 749d7be28ed620f9017cb6a65735ac937d1b8a86 (diff) | |
download | context-4a00862b42dd8347bd782022a819fa9c3a32f9a2.tar.gz |
beta 2011.05.13 11:37
Diffstat (limited to 'tex/context/base/char-ini.lua')
-rw-r--r-- | tex/context/base/char-ini.lua | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/tex/context/base/char-ini.lua b/tex/context/base/char-ini.lua index 059332d51..2244048c3 100644 --- a/tex/context/base/char-ini.lua +++ b/tex/context/base/char-ini.lua @@ -12,6 +12,7 @@ local tex = tex local utf = unicode.utf8 local utfchar, utfbyte, utfvalues = utf.char, utf.byte, string.utfvalues +local ustring = unicode.ustring local concat, unpack = table.concat, table.unpack local next, tonumber, type, rawget, rawset = next, tonumber, type, rawget, rawset local texsprint, texprint = tex.sprint, tex.print @@ -939,3 +940,38 @@ end --~ direction="l", --~ unicodeslot=0x10FFFD, --~ }, + +if not characters.superscripts then + + local superscripts = allocate() characters.superscripts = superscripts + local subscripts = allocate() characters.subscripts = subscripts + + -- skipping U+02120 (service mark) U+02122 (trademark) + + for k, v in next, data do + local specials = v.specials + if specials then + local what = specials[1] + if what == "super" then + if #specials == 2 then + superscripts[k] = specials[2] + else + report_defining("ignoring superscript %s %s: %s",ustring(k),utfchar(k),v.description) + end + elseif what == "sub" then + if #specials == 2 then + subscripts[k] = specials[2] + else + report_defining("ignoring subscript %s %s: %s",ustring(k),utfchar(k),v.description) + end + end + end + end + + -- print(table.serialize(superscripts, "superscripts", { hexify = true })) + -- print(table.serialize(subscripts, "subscripts", { hexify = true })) + + storage.register("characters/superscripts", superscripts, "characters.superscripts") + storage.register("characters/subscripts", subscripts, "characters.subscripts") + +end |