diff options
author | Tom Smeding <tom@tomsmeding.com> | 2024-04-21 21:16:12 +0200 |
---|---|---|
committer | Tom Smeding <tom@tomsmeding.com> | 2024-04-21 21:16:12 +0200 |
commit | 43f26e5b23c6bf2d0e7d72ceeb9c02b2ceb7b608 (patch) | |
tree | b92baea5f8f3181a8ac657fa6d0a98f097aef24c /modules/unicode | |
parent | 2d4eb2561fa65d5e7bd83caa9b975791f0f6664e (diff) |
unicode: More results; aliases
Diffstat (limited to 'modules/unicode')
-rw-r--r-- | modules/unicode/aliases.txt | 3 | ||||
-rw-r--r-- | modules/unicode/unicode.js | 24 |
2 files changed, 26 insertions, 1 deletions
diff --git a/modules/unicode/aliases.txt b/modules/unicode/aliases.txt new file mode 100644 index 0000000..ea23cab --- /dev/null +++ b/modules/unicode/aliases.txt @@ -0,0 +1,3 @@ +0x039B lambda +0x03BB lambda +0x2218 composition diff --git a/modules/unicode/unicode.js b/modules/unicode/unicode.js index ab8ad53..4b313fc 100644 --- a/modules/unicode/unicode.js +++ b/modules/unicode/unicode.js @@ -24,6 +24,8 @@ const fTITLECASE = 14; let db = new Map(); // ranges: [{name: String, first: int, last: int}] let ranges = []; +// aliases: [{name: String, code: int}] +let aliases = []; function importDatabase(csv) { // clear the database if necessary @@ -56,6 +58,17 @@ function importDatabase(csv) { } } +function importAliases(lines) { + aliases = []; + for (const line of lines.split("\n")) { + const idx = line.indexOf(" "); + if (idx == -1) continue; + const num = parseInt(line.slice(0, idx)); + const descr = line.slice(idx + 1).toUpperCase(); + aliases.push({name: descr, code: num}); + } +} + function lookupCode(codepoint) { for (const range of ranges) { if (range.first <= codepoint && codepoint <= range.last) { @@ -75,7 +88,14 @@ function searchDescription(text) { for (const row of db.values()) { if (row[fNAME].includes(text)) { result.push(row); - if (result.length >= 200) break; + if (result.length >= 500) return result; + } + } + + for (const row of aliases) { + if (row.name.includes(text)) { + result.push(db.get(row.code)); + if (result.length >= 500) return result; } } @@ -123,6 +143,8 @@ module.exports = function (app, io, moddir) { throw new Error("UnicodeData.txt doesn't exist! Be sure to run ./install_prepare.sh"); } + importAliases(fs.readFileSync(path.join(moddir, "aliases.txt")).toString()); + app.get("/unicode", (req, res) => { res.sendFile(path.join(moddir, "index.html")); }); |