jsmigemo 0.3.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +97 -0
- package/bin/jsmigemo-cli.js +122 -0
- package/bin/jsmigemo-dict.js +37 -0
- package/bin/jsmigemo-skk2migemo.js +61 -0
- package/demo-list.html +116 -0
- package/demo-text.html +65 -0
- package/esm/BitList.d.ts +8 -0
- package/esm/BitList.js +39 -0
- package/esm/BitList.js.map +1 -0
- package/esm/BitVector.d.ts +15 -0
- package/esm/BitVector.js +150 -0
- package/esm/BitVector.js.map +1 -0
- package/esm/CharacterConverter.d.ts +3 -0
- package/esm/CharacterConverter.js +382 -0
- package/esm/CharacterConverter.js.map +1 -0
- package/esm/CompactDictionary.d.ts +17 -0
- package/esm/CompactDictionary.js +124 -0
- package/esm/CompactDictionary.js.map +1 -0
- package/esm/CompactDictionaryBuilder.d.ts +3 -0
- package/esm/CompactDictionaryBuilder.js +118 -0
- package/esm/CompactDictionaryBuilder.js.map +1 -0
- package/esm/CompactHiraganaString.d.ts +6 -0
- package/esm/CompactHiraganaString.js +41 -0
- package/esm/CompactHiraganaString.js.map +1 -0
- package/esm/DoubleArray.d.ts +12 -0
- package/esm/DoubleArray.js +70 -0
- package/esm/DoubleArray.js.map +1 -0
- package/esm/LOUDSTrie.d.ts +13 -0
- package/esm/LOUDSTrie.js +67 -0
- package/esm/LOUDSTrie.js.map +1 -0
- package/esm/LOUDSTrieBuilder.d.ts +4 -0
- package/esm/LOUDSTrieBuilder.js +69 -0
- package/esm/LOUDSTrieBuilder.js.map +1 -0
- package/esm/Migemo.d.ts +13 -0
- package/esm/Migemo.js +71 -0
- package/esm/Migemo.js.map +1 -0
- package/esm/RomajiProcessor.d.ts +18 -0
- package/esm/RomajiProcessor.js +478 -0
- package/esm/RomajiProcessor.js.map +1 -0
- package/esm/RomajiProcessor2.d.ts +15 -0
- package/esm/RomajiProcessor2.js +91 -0
- package/esm/RomajiProcessor2.js.map +1 -0
- package/esm/SimpleDictionary.d.ts +1 -0
- package/esm/SimpleDictionary.js +54 -0
- package/esm/SimpleDictionary.js.map +1 -0
- package/esm/TernaryRegexGenerator.d.ts +27 -0
- package/esm/TernaryRegexGenerator.js +202 -0
- package/esm/TernaryRegexGenerator.js.map +1 -0
- package/esm/index.d.ts +3 -0
- package/esm/index.js +5 -0
- package/esm/index.js.map +1 -0
- package/esm/utils.d.ts +5 -0
- package/esm/utils.js +88 -0
- package/esm/utils.js.map +1 -0
- package/index.html +55 -0
- package/jest.config.js +12 -0
- package/lib/BitList.d.ts +8 -0
- package/lib/BitList.js +43 -0
- package/lib/BitList.js.map +1 -0
- package/lib/BitVector.d.ts +15 -0
- package/lib/BitVector.js +154 -0
- package/lib/BitVector.js.map +1 -0
- package/lib/CharacterConverter.d.ts +3 -0
- package/lib/CharacterConverter.js +388 -0
- package/lib/CharacterConverter.js.map +1 -0
- package/lib/CompactDictionary.d.ts +17 -0
- package/lib/CompactDictionary.js +128 -0
- package/lib/CompactDictionary.js.map +1 -0
- package/lib/CompactDictionaryBuilder.d.ts +3 -0
- package/lib/CompactDictionaryBuilder.js +122 -0
- package/lib/CompactDictionaryBuilder.js.map +1 -0
- package/lib/CompactHiraganaString.d.ts +6 -0
- package/lib/CompactHiraganaString.js +45 -0
- package/lib/CompactHiraganaString.js.map +1 -0
- package/lib/DoubleArray.d.ts +12 -0
- package/lib/DoubleArray.js +74 -0
- package/lib/DoubleArray.js.map +1 -0
- package/lib/LOUDSTrie.d.ts +13 -0
- package/lib/LOUDSTrie.js +71 -0
- package/lib/LOUDSTrie.js.map +1 -0
- package/lib/LOUDSTrieBuilder.d.ts +4 -0
- package/lib/LOUDSTrieBuilder.js +73 -0
- package/lib/LOUDSTrieBuilder.js.map +1 -0
- package/lib/Migemo.d.ts +13 -0
- package/lib/Migemo.js +75 -0
- package/lib/Migemo.js.map +1 -0
- package/lib/RegexGenerator.d.ts +21 -0
- package/lib/RegexGenerator.js +150 -0
- package/lib/RegexGenerator.js.map +1 -0
- package/lib/RomajiProcessor.d.ts +18 -0
- package/lib/RomajiProcessor.js +484 -0
- package/lib/RomajiProcessor.js.map +1 -0
- package/lib/RomajiProcessor2.d.ts +15 -0
- package/lib/RomajiProcessor2.js +96 -0
- package/lib/RomajiProcessor2.js.map +1 -0
- package/lib/RomanEntry.d.ts +1 -0
- package/lib/RomanEntry.js +481 -0
- package/lib/RomanEntry.js.map +1 -0
- package/lib/SimpleDictionary.d.ts +1 -0
- package/lib/SimpleDictionary.js +56 -0
- package/lib/SimpleDictionary.js.map +1 -0
- package/lib/TernaryRegexGenerator.d.ts +27 -0
- package/lib/TernaryRegexGenerator.js +206 -0
- package/lib/TernaryRegexGenerator.js.map +1 -0
- package/lib/index.d.ts +3 -0
- package/lib/index.js +17 -0
- package/lib/index.js.map +1 -0
- package/lib/utils.d.ts +5 -0
- package/lib/utils.js +96 -0
- package/lib/utils.js.map +1 -0
- package/migemo-compact-dict +0 -0
- package/package.json +37 -0
- package/tsconfig.esm.json +9 -0
- package/umd/jsmigemo.js +1 -0
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CompactDictionaryBuilder = void 0;
|
|
4
|
+
const LOUDSTrieBuilder_1 = require("./LOUDSTrieBuilder");
|
|
5
|
+
const CompactHiraganaString_1 = require("./CompactHiraganaString");
|
|
6
|
+
const BitList_1 = require("./BitList");
|
|
7
|
+
class CompactDictionaryBuilder {
|
|
8
|
+
static build(dict) {
|
|
9
|
+
// remove some keys
|
|
10
|
+
const keysToRemove = new Array();
|
|
11
|
+
for (const key of dict.keys()) {
|
|
12
|
+
try {
|
|
13
|
+
CompactHiraganaString_1.CompactHiraganaString.encodeString(key);
|
|
14
|
+
}
|
|
15
|
+
catch (e) {
|
|
16
|
+
keysToRemove.push(key);
|
|
17
|
+
console.log("skipped the world: " + key);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
for (const key of keysToRemove) {
|
|
21
|
+
dict.delete(key);
|
|
22
|
+
}
|
|
23
|
+
// build key trie
|
|
24
|
+
const keys = Array.from(dict.keys()).sort();
|
|
25
|
+
const keyTrie = LOUDSTrieBuilder_1.LOUDSTrieBuilder.build(keys)[0];
|
|
26
|
+
// build value trie
|
|
27
|
+
const valuesSet = new Set();
|
|
28
|
+
for (const value of dict.values()) {
|
|
29
|
+
for (const v of value) {
|
|
30
|
+
valuesSet.add(v);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
const values = Array.from(valuesSet.values()).sort();
|
|
34
|
+
const valueTrie = LOUDSTrieBuilder_1.LOUDSTrieBuilder.build(values)[0];
|
|
35
|
+
// build trie mapping
|
|
36
|
+
let mappingCount = 0;
|
|
37
|
+
for (const i of dict.values()) {
|
|
38
|
+
mappingCount += i.length;
|
|
39
|
+
}
|
|
40
|
+
const mapping = new Uint32Array(mappingCount);
|
|
41
|
+
let mappingIndex = 0;
|
|
42
|
+
const mappingBitList = new BitList_1.BitList();
|
|
43
|
+
for (let i = 1; i <= keyTrie.size(); i++) {
|
|
44
|
+
let key = keyTrie.reverseLookup(i);
|
|
45
|
+
mappingBitList.add(false);
|
|
46
|
+
let values = dict.get(key);
|
|
47
|
+
if (values != undefined) {
|
|
48
|
+
for (let j = 0; j < values.length; j++) {
|
|
49
|
+
mappingBitList.add(true);
|
|
50
|
+
mapping[mappingIndex] = valueTrie.lookup(values[j]);
|
|
51
|
+
mappingIndex++;
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
// calculate output size
|
|
56
|
+
const keyTrieDataSize = 8 + keyTrie.edges.length + ((keyTrie.bitVector.size() + 63) >>> 6) * 8;
|
|
57
|
+
const valueTrieDataSize = 8 + valueTrie.edges.length * 2 + ((valueTrie.bitVector.size() + 63) >>> 6) * 8;
|
|
58
|
+
const mappingDataSize = 8 + ((mappingBitList.size + 63) >>> 6) * 8 + mapping.length * 4;
|
|
59
|
+
const outputDataSize = keyTrieDataSize + valueTrieDataSize + mappingDataSize;
|
|
60
|
+
// ready output
|
|
61
|
+
const arrayBuffer = new ArrayBuffer(outputDataSize);
|
|
62
|
+
const dataView = new DataView(arrayBuffer);
|
|
63
|
+
let dataViewIndex = 0;
|
|
64
|
+
// output key trie
|
|
65
|
+
dataView.setInt32(dataViewIndex, keyTrie.edges.length);
|
|
66
|
+
dataViewIndex += 4;
|
|
67
|
+
for (let i = 0; i < keyTrie.edges.length; i++) {
|
|
68
|
+
const compactChar = CompactHiraganaString_1.CompactHiraganaString.encodeChar(keyTrie.edges[i]);
|
|
69
|
+
dataView.setUint8(dataViewIndex, compactChar);
|
|
70
|
+
dataViewIndex += 1;
|
|
71
|
+
}
|
|
72
|
+
dataView.setInt32(dataViewIndex, keyTrie.bitVector.size());
|
|
73
|
+
dataViewIndex += 4;
|
|
74
|
+
const keyTrieBitVectorWords = keyTrie.bitVector.words;
|
|
75
|
+
for (let i = 0; i < keyTrieBitVectorWords.length >>> 1; i++) {
|
|
76
|
+
dataView.setUint32(dataViewIndex, keyTrieBitVectorWords[i * 2 + 1]);
|
|
77
|
+
dataViewIndex += 4;
|
|
78
|
+
dataView.setUint32(dataViewIndex, keyTrieBitVectorWords[i * 2]);
|
|
79
|
+
dataViewIndex += 4;
|
|
80
|
+
}
|
|
81
|
+
// output value trie
|
|
82
|
+
dataView.setInt32(dataViewIndex, valueTrie.edges.length);
|
|
83
|
+
dataViewIndex += 4;
|
|
84
|
+
for (let i = 0; i < valueTrie.edges.length; i++) {
|
|
85
|
+
dataView.setUint16(dataViewIndex, valueTrie.edges[i]);
|
|
86
|
+
dataViewIndex += 2;
|
|
87
|
+
}
|
|
88
|
+
dataView.setInt32(dataViewIndex, valueTrie.bitVector.size());
|
|
89
|
+
dataViewIndex += 4;
|
|
90
|
+
const valueTrieBitVectorWords = valueTrie.bitVector.words;
|
|
91
|
+
for (let i = 0; i < valueTrieBitVectorWords.length >>> 1; i++) {
|
|
92
|
+
dataView.setUint32(dataViewIndex, valueTrieBitVectorWords[i * 2 + 1]);
|
|
93
|
+
dataViewIndex += 4;
|
|
94
|
+
dataView.setUint32(dataViewIndex, valueTrieBitVectorWords[i * 2]);
|
|
95
|
+
dataViewIndex += 4;
|
|
96
|
+
}
|
|
97
|
+
// output mapping
|
|
98
|
+
dataView.setInt32(dataViewIndex, mappingBitList.size);
|
|
99
|
+
dataViewIndex += 4;
|
|
100
|
+
const mappingWordsLen = (mappingBitList.size + 63) >> 6;
|
|
101
|
+
for (let i = 0; i < mappingWordsLen; i++) {
|
|
102
|
+
dataView.setUint32(dataViewIndex, mappingBitList.words[i * 2 + 1]);
|
|
103
|
+
dataViewIndex += 4;
|
|
104
|
+
dataView.setUint32(dataViewIndex, mappingBitList.words[i * 2]);
|
|
105
|
+
dataViewIndex += 4;
|
|
106
|
+
}
|
|
107
|
+
// TODO: padding to 64bit words
|
|
108
|
+
dataView.setInt32(dataViewIndex, mapping.length);
|
|
109
|
+
dataViewIndex += 4;
|
|
110
|
+
for (let i = 0; i < mapping.length; i++) {
|
|
111
|
+
dataView.setUint32(dataViewIndex, mapping[i]);
|
|
112
|
+
dataViewIndex += 4;
|
|
113
|
+
}
|
|
114
|
+
// check data size
|
|
115
|
+
if (dataViewIndex !== outputDataSize) {
|
|
116
|
+
throw new Error(`file size is not valid: expected=${outputDataSize} actual=${dataViewIndex}`);
|
|
117
|
+
}
|
|
118
|
+
return arrayBuffer;
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
exports.CompactDictionaryBuilder = CompactDictionaryBuilder;
|
|
122
|
+
//# sourceMappingURL=CompactDictionaryBuilder.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CompactDictionaryBuilder.js","sourceRoot":"","sources":["../src/CompactDictionaryBuilder.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CompactHiraganaString = void 0;
|
|
4
|
+
class CompactHiraganaString {
|
|
5
|
+
static decodeBytes(bytes) {
|
|
6
|
+
let result = "";
|
|
7
|
+
for (let i = 0; i < bytes.length; i++) {
|
|
8
|
+
result += CompactHiraganaString.decodeByte(bytes[i]);
|
|
9
|
+
}
|
|
10
|
+
return result;
|
|
11
|
+
}
|
|
12
|
+
static decodeByte(c) {
|
|
13
|
+
if (0x20 <= c && c <= 0x7e) {
|
|
14
|
+
return String.fromCharCode(c);
|
|
15
|
+
}
|
|
16
|
+
if (0xa1 <= c && c <= 0xf6) {
|
|
17
|
+
return String.fromCharCode(c + 0x3040 - 0xa0);
|
|
18
|
+
}
|
|
19
|
+
throw new RangeError();
|
|
20
|
+
}
|
|
21
|
+
static encodeString(str) {
|
|
22
|
+
const result = new Uint8Array(str.length);
|
|
23
|
+
for (let i = 0; i < str.length; i++) {
|
|
24
|
+
result[i] = CompactHiraganaString.encodeChar(str.charCodeAt(i));
|
|
25
|
+
}
|
|
26
|
+
return result;
|
|
27
|
+
}
|
|
28
|
+
static encodeChar(b) {
|
|
29
|
+
if (b == 0) {
|
|
30
|
+
return 0;
|
|
31
|
+
}
|
|
32
|
+
if (0x20 <= b && b <= 0x7e) {
|
|
33
|
+
return b;
|
|
34
|
+
}
|
|
35
|
+
if (0x3041 <= b && b <= 0x3096) {
|
|
36
|
+
return b - 0x3040 + 0xa0;
|
|
37
|
+
}
|
|
38
|
+
if (0x30fc === b) {
|
|
39
|
+
return b - 0x3040 + 0xa0;
|
|
40
|
+
}
|
|
41
|
+
throw new RangeError('unknown character to encode: ' + b);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
exports.CompactHiraganaString = CompactHiraganaString;
|
|
45
|
+
//# sourceMappingURL=CompactHiraganaString.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CompactHiraganaString.js","sourceRoot":"","sources":["../src/CompactHiraganaString.ts"],"names":[],"mappings":";;;AACA,MAAa,qBAAqB;IACvB,MAAM,CAAC,WAAW,CAAC,KAAiB;QACvC,IAAI,MAAM,GAAG,EAAE,CAAC;QAChB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACnC,MAAM,IAAI,qBAAqB,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;SACxD;QACD,OAAO,MAAM,CAAC;IAClB,CAAC;IAEM,MAAM,CAAC,UAAU,CAAC,CAAS;QAC9B,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,EAAE;YACxB,OAAO,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;SACjC;QACD,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,EAAE;YACxB,OAAO,MAAM,CAAC,YAAY,CAAC,CAAC,GAAG,MAAM,GAAG,IAAI,CAAC,CAAC;SACjD;QACD,MAAM,IAAI,UAAU,EAAE,CAAC;IAC3B,CAAC;IAEM,MAAM,CAAC,YAAY,CAAC,GAAW;QAClC,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QAC1C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACjC,MAAM,CAAC,CAAC,CAAC,GAAG,qBAAqB,CAAC,UAAU,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;SACnE;QACD,OAAO,MAAM,CAAC;IAClB,CAAC;IAEM,MAAM,CAAC,UAAU,CAAC,CAAS;QAC9B,IAAI,CAAC,IAAI,CAAC,EAAE;YACR,OAAO,CAAC,CAAC;SACZ;QACD,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,EAAE;YACxB,OAAO,CAAC,CAAC;SACZ;QACD,IAAI,MAAM,IAAI,CAAC,IAAI,CAAC,IAAI,MAAM,EAAE;YAC5B,OAAO,CAAC,GAAG,MAAM,GAAG,IAAI,CAAC;SAC5B;QACD,IAAI,MAAM,KAAK,CAAC,EAAE;YACd,OAAO,CAAC,GAAG,MAAM,GAAG,IAAI,CAAC;SAC5B;QACD,MAAM,IAAI,UAAU,CAAC,+BAA+B,GAAG,CAAC,CAAC,CAAC;IAC9D,CAAC;CACJ;AA1CD,sDA0CC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export declare class DoubleArray {
|
|
2
|
+
base: Int16Array;
|
|
3
|
+
check: Int16Array;
|
|
4
|
+
charConverter: (arg: number) => number;
|
|
5
|
+
charSize: number;
|
|
6
|
+
constructor(base: Int16Array, check: Int16Array, charConverter: (arg: number) => number, charSize: number);
|
|
7
|
+
traverse(n: number, k: number): number;
|
|
8
|
+
lookup(str: string): number;
|
|
9
|
+
commonPrefixSearch(key: string): IterableIterator<number>;
|
|
10
|
+
predictiveSearch(key: string): IterableIterator<number>;
|
|
11
|
+
visitRecursive(n: number): IterableIterator<number>;
|
|
12
|
+
}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DoubleArray = void 0;
|
|
4
|
+
class DoubleArray {
|
|
5
|
+
constructor(base, check, charConverter, charSize) {
|
|
6
|
+
this.base = base;
|
|
7
|
+
this.check = check;
|
|
8
|
+
this.charConverter = charConverter;
|
|
9
|
+
this.charSize = charSize;
|
|
10
|
+
}
|
|
11
|
+
traverse(n, k) {
|
|
12
|
+
const m = this.base[n] + k;
|
|
13
|
+
if (this.check[m] == n) {
|
|
14
|
+
return m;
|
|
15
|
+
}
|
|
16
|
+
else {
|
|
17
|
+
return -1;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
lookup(str) {
|
|
21
|
+
if (str.length == 0) {
|
|
22
|
+
return 0;
|
|
23
|
+
}
|
|
24
|
+
let n = 0;
|
|
25
|
+
for (let i = 0; i < str.length; i++) {
|
|
26
|
+
const c = this.charConverter(str.charCodeAt(i));
|
|
27
|
+
if (c < 1) {
|
|
28
|
+
throw new Error();
|
|
29
|
+
}
|
|
30
|
+
n = this.traverse(n, c);
|
|
31
|
+
if (n == -1) {
|
|
32
|
+
return -1;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
return n;
|
|
36
|
+
}
|
|
37
|
+
*commonPrefixSearch(key) {
|
|
38
|
+
let index = 0;
|
|
39
|
+
let offset = 0;
|
|
40
|
+
while (index != -1) {
|
|
41
|
+
const lastIndex = index;
|
|
42
|
+
if (offset == key.length) {
|
|
43
|
+
index = -1;
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
const c = this.charConverter(key.charCodeAt(offset));
|
|
47
|
+
index = this.traverse(index, c);
|
|
48
|
+
offset++;
|
|
49
|
+
}
|
|
50
|
+
yield lastIndex;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
*predictiveSearch(key) {
|
|
54
|
+
const n = this.lookup(key);
|
|
55
|
+
if (n == -1) {
|
|
56
|
+
return;
|
|
57
|
+
}
|
|
58
|
+
yield* this.visitRecursive(n);
|
|
59
|
+
}
|
|
60
|
+
*visitRecursive(n) {
|
|
61
|
+
yield n;
|
|
62
|
+
for (let i = 0; i < this.charSize; i++) {
|
|
63
|
+
const m = this.base[n] + i + 1;
|
|
64
|
+
if (m >= this.check.length) {
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
67
|
+
if (this.check[m] == n) {
|
|
68
|
+
yield* this.visitRecursive(m);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
exports.DoubleArray = DoubleArray;
|
|
74
|
+
//# sourceMappingURL=DoubleArray.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DoubleArray.js","sourceRoot":"","sources":["../src/DoubleArray.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { BitVector } from "./BitVector";
|
|
2
|
+
export declare class LOUDSTrie {
|
|
3
|
+
bitVector: BitVector;
|
|
4
|
+
edges: Uint16Array;
|
|
5
|
+
constructor(bitVector: BitVector, edges: Uint16Array);
|
|
6
|
+
reverseLookup(index: number): string;
|
|
7
|
+
parent(x: number): number;
|
|
8
|
+
firstChild(x: number): number;
|
|
9
|
+
traverse(index: number, c: number): number;
|
|
10
|
+
lookup(key: string): number;
|
|
11
|
+
predictiveSearch(index: number): IterableIterator<number>;
|
|
12
|
+
size(): number;
|
|
13
|
+
}
|
package/lib/LOUDSTrie.js
ADDED
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.LOUDSTrie = void 0;
|
|
4
|
+
const utils_1 = require("./utils");
|
|
5
|
+
class LOUDSTrie {
|
|
6
|
+
constructor(bitVector, edges) {
|
|
7
|
+
this.bitVector = bitVector;
|
|
8
|
+
this.edges = edges;
|
|
9
|
+
}
|
|
10
|
+
reverseLookup(index) {
|
|
11
|
+
if (index <= 0 || this.edges.length <= index) {
|
|
12
|
+
throw new RangeError();
|
|
13
|
+
}
|
|
14
|
+
let sb = new Array();
|
|
15
|
+
while (index > 1) {
|
|
16
|
+
sb.push(this.edges[index]);
|
|
17
|
+
index = this.parent(index);
|
|
18
|
+
}
|
|
19
|
+
return sb.reverse().map(v => String.fromCharCode(v)).join('');
|
|
20
|
+
}
|
|
21
|
+
parent(x) {
|
|
22
|
+
return this.bitVector.rank(this.bitVector.select(x, true), false);
|
|
23
|
+
}
|
|
24
|
+
firstChild(x) {
|
|
25
|
+
let y = this.bitVector.select(x, false) + 1;
|
|
26
|
+
if (this.bitVector.get(y)) {
|
|
27
|
+
return this.bitVector.rank(y, true) + 1;
|
|
28
|
+
}
|
|
29
|
+
else {
|
|
30
|
+
return -1;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
traverse(index, c) {
|
|
34
|
+
let firstChild = this.firstChild(index);
|
|
35
|
+
if (firstChild == -1) {
|
|
36
|
+
return -1;
|
|
37
|
+
}
|
|
38
|
+
let childStartBit = this.bitVector.select(firstChild, true);
|
|
39
|
+
let childEndBit = this.bitVector.nextClearBit(childStartBit);
|
|
40
|
+
let childSize = childEndBit - childStartBit;
|
|
41
|
+
let result = (0, utils_1.binarySearchUint16)(this.edges, firstChild, firstChild + childSize, c);
|
|
42
|
+
return result >= 0 ? result : -1;
|
|
43
|
+
}
|
|
44
|
+
lookup(key) {
|
|
45
|
+
let nodeIndex = 1;
|
|
46
|
+
for (let i = 0; i < key.length; i++) {
|
|
47
|
+
let c = key.charCodeAt(i);
|
|
48
|
+
nodeIndex = this.traverse(nodeIndex, c);
|
|
49
|
+
if (nodeIndex == -1) {
|
|
50
|
+
break;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
return (nodeIndex >= 0) ? nodeIndex : -1;
|
|
54
|
+
}
|
|
55
|
+
*predictiveSearch(index) {
|
|
56
|
+
let lower = index;
|
|
57
|
+
let upper = index + 1;
|
|
58
|
+
while (upper - lower > 0) {
|
|
59
|
+
for (let i = lower; i < upper; i++) {
|
|
60
|
+
yield i;
|
|
61
|
+
}
|
|
62
|
+
lower = this.bitVector.rank(this.bitVector.select(lower, false) + 1, true) + 1;
|
|
63
|
+
upper = this.bitVector.rank(this.bitVector.select(upper, false) + 1, true) + 1;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
size() {
|
|
67
|
+
return this.edges.length - 2;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
exports.LOUDSTrie = LOUDSTrie;
|
|
71
|
+
//# sourceMappingURL=LOUDSTrie.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LOUDSTrie.js","sourceRoot":"","sources":["../src/LOUDSTrie.ts"],"names":[],"mappings":";;;AAAA,mCAA6C;AAG7C,MAAa,SAAS;IAIlB,YAAY,SAAoB,EAAE,KAAkB;QAChD,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACvB,CAAC;IAED,aAAa,CAAC,KAAa;QACvB,IAAI,KAAK,IAAI,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,IAAI,KAAK,EAAE;YAC1C,MAAM,IAAI,UAAU,EAAE,CAAC;SAC1B;QACD,IAAI,EAAE,GAAG,IAAI,KAAK,EAAU,CAAC;QAC7B,OAAO,KAAK,GAAG,CAAC,EAAE;YACd,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;YAC3B,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;SAC9B;QACD,OAAO,EAAE,CAAC,OAAO,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAClE,CAAC;IAED,MAAM,CAAC,CAAS;QACZ,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,EAAE,IAAI,CAAC,EAAE,KAAK,CAAC,CAAC;IACtE,CAAC;IAED,UAAU,CAAC,CAAS;QAChB,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC;QAC5C,IAAI,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;YACvB,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;SAC3C;aAAM;YACH,OAAO,CAAC,CAAC,CAAC;SACb;IACL,CAAC;IAED,QAAQ,CAAC,KAAa,EAAE,CAAS;QAC7B,IAAI,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QACxC,IAAI,UAAU,IAAI,CAAC,CAAC,EAAE;YAClB,OAAO,CAAC,CAAC,CAAC;SACb;QACD,IAAI,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;QAC5D,IAAI,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;QAC7D,IAAI,SAAS,GAAG,WAAW,GAAG,aAAa,CAAC;QAC5C,IAAI,MAAM,GAAG,IAAA,0BAAkB,EAAC,IAAI,CAAC,KAAK,EAAE,UAAU,EAAE,UAAU,GAAG,SAAS,EAAE,CAAC,CAAC,CAAC;QACnF,OAAO,MAAM,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACrC,CAAC;IAED,MAAM,CAAC,GAAW;QACd,IAAI,SAAS,GAAG,CAAC,CAAC;QAClB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACjC,IAAI,CAAC,GAAG,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YAC1B,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;YACxC,IAAI,SAAS,IAAI,CAAC,CAAC,EAAE;gBACjB,MAAM;aACT;SACJ;QACD,OAAO,CAAC,SAAS,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC7C,CAAC;IAED,CAAC,gBAAgB,CAAC,KAAa;QAC3B,IAAI,KAAK,GAAG,KAAK,CAAC;QAClB,IAAI,KAAK,GAAG,KAAK,GAAG,CAAC,CAAC;QACtB,OAAO,KAAK,GAAG,KAAK,GAAG,CAAC,EAAE;YACtB,KAAK,IAAI,CAAC,GAAG,KAAK,EAAE,CAAC,GAAG,KAAK,EAAE,CAAC,EAAE,EAAE;gBAChC,MAAM,CAAC,CAAC;aACX;YACD,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;YAC/E,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;SAClF;IACL,CAAC;IAED,IAAI;QACA,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;IACjC,CAAC;CACJ;AAzED,8BAyEC"}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.LOUDSTrieBuilder = void 0;
|
|
4
|
+
const LOUDSTrie_1 = require("./LOUDSTrie");
|
|
5
|
+
const BitVector_1 = require("./BitVector");
|
|
6
|
+
const BitList_1 = require("./BitList");
|
|
7
|
+
class LOUDSTrieBuilder {
|
|
8
|
+
static build(keys) {
|
|
9
|
+
for (let i = 0; i < keys.length; i++) {
|
|
10
|
+
if (keys[i] == null) {
|
|
11
|
+
throw new Error();
|
|
12
|
+
}
|
|
13
|
+
if (i > 0 && keys[i - 1] > keys[i]) {
|
|
14
|
+
throw new Error();
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
const nodes = new Uint32Array(keys.length);
|
|
18
|
+
for (let i = 0; i < nodes.length; i++) {
|
|
19
|
+
nodes[i] = 1;
|
|
20
|
+
}
|
|
21
|
+
let cursor = 0;
|
|
22
|
+
let currentNode = 1;
|
|
23
|
+
let edges = " ";
|
|
24
|
+
const louds = new BitList_1.BitList();
|
|
25
|
+
louds.add(true);
|
|
26
|
+
while (true) {
|
|
27
|
+
let lastChar = 0;
|
|
28
|
+
let lastParent = 0;
|
|
29
|
+
let restKeys = 0;
|
|
30
|
+
for (let i = 0; i < keys.length; i++) {
|
|
31
|
+
if (keys[i].length < cursor) {
|
|
32
|
+
continue;
|
|
33
|
+
}
|
|
34
|
+
if (keys[i].length == cursor) {
|
|
35
|
+
louds.add(false);
|
|
36
|
+
lastParent = nodes[i];
|
|
37
|
+
lastChar = 0;
|
|
38
|
+
continue;
|
|
39
|
+
}
|
|
40
|
+
const currentChar = keys[i].charCodeAt(cursor);
|
|
41
|
+
const currentParent = nodes[i];
|
|
42
|
+
if (lastParent != currentParent) {
|
|
43
|
+
louds.add(false);
|
|
44
|
+
louds.add(true);
|
|
45
|
+
edges += String.fromCharCode(currentChar);
|
|
46
|
+
currentNode = currentNode + 1;
|
|
47
|
+
}
|
|
48
|
+
else if (lastChar != currentChar) {
|
|
49
|
+
louds.add(true);
|
|
50
|
+
edges += String.fromCharCode(currentChar);
|
|
51
|
+
currentNode = currentNode + 1;
|
|
52
|
+
}
|
|
53
|
+
nodes[i] = currentNode;
|
|
54
|
+
lastChar = currentChar;
|
|
55
|
+
lastParent = currentParent;
|
|
56
|
+
restKeys++;
|
|
57
|
+
}
|
|
58
|
+
if (restKeys == 0) {
|
|
59
|
+
break;
|
|
60
|
+
}
|
|
61
|
+
cursor++;
|
|
62
|
+
}
|
|
63
|
+
const bitVectorWords = new Uint32Array(louds.words.buffer, 0, ((louds.size + 63) >> 6) * 2);
|
|
64
|
+
const bitVector = new BitVector_1.BitVector(bitVectorWords, louds.size);
|
|
65
|
+
const uint16Edges = new Uint16Array(edges.length);
|
|
66
|
+
for (let i = 0; i < edges.length; i++) {
|
|
67
|
+
uint16Edges[i] = edges.charCodeAt(i);
|
|
68
|
+
}
|
|
69
|
+
return [new LOUDSTrie_1.LOUDSTrie(bitVector, uint16Edges), nodes];
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
exports.LOUDSTrieBuilder = LOUDSTrieBuilder;
|
|
73
|
+
//# sourceMappingURL=LOUDSTrieBuilder.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LOUDSTrieBuilder.js","sourceRoot":"","sources":["../src/LOUDSTrieBuilder.ts"],"names":[],"mappings":"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"}
|
package/lib/Migemo.d.ts
ADDED
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { CompactDictionary } from "./CompactDictionary";
|
|
2
|
+
import { RomajiProcessor2 } from "./RomajiProcessor2";
|
|
3
|
+
export declare class Migemo {
|
|
4
|
+
dict: CompactDictionary | null;
|
|
5
|
+
rxop: Array<string> | null;
|
|
6
|
+
processor: RomajiProcessor2;
|
|
7
|
+
constructor();
|
|
8
|
+
queryAWord(word: string): string;
|
|
9
|
+
query(word: string): string;
|
|
10
|
+
setDict(dict: CompactDictionary | null): void;
|
|
11
|
+
setRxop(rxop: [string] | null): void;
|
|
12
|
+
parseQuery(query: string): IterableIterator<string>;
|
|
13
|
+
}
|
package/lib/Migemo.js
ADDED
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Migemo = void 0;
|
|
4
|
+
const CharacterConverter_1 = require("./CharacterConverter");
|
|
5
|
+
const TernaryRegexGenerator_1 = require("./TernaryRegexGenerator");
|
|
6
|
+
const RomajiProcessor2_1 = require("./RomajiProcessor2");
|
|
7
|
+
class Migemo {
|
|
8
|
+
constructor() {
|
|
9
|
+
this.dict = null;
|
|
10
|
+
this.rxop = null;
|
|
11
|
+
this.processor = RomajiProcessor2_1.RomajiProcessor2.buildProcessor();
|
|
12
|
+
}
|
|
13
|
+
queryAWord(word) {
|
|
14
|
+
const generator = this.rxop == null ? TernaryRegexGenerator_1.TernaryRegexGenerator.getDEFAULT() : new TernaryRegexGenerator_1.TernaryRegexGenerator(this.rxop[0], this.rxop[1], this.rxop[2], this.rxop[3], this.rxop[4], this.rxop[5]);
|
|
15
|
+
// query自信はもちろん候補に加える
|
|
16
|
+
generator.add(word);
|
|
17
|
+
// queryそのものでの辞書引き
|
|
18
|
+
const lower = word.toLowerCase();
|
|
19
|
+
if (this.dict != null) {
|
|
20
|
+
for (const word of this.dict.predictiveSearch(lower)) {
|
|
21
|
+
generator.add(word);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
// queryを全角にして候補に加える
|
|
25
|
+
const zen = (0, CharacterConverter_1.han2zen_conv)(word);
|
|
26
|
+
generator.add(zen);
|
|
27
|
+
// queryを半角にして候補に加える
|
|
28
|
+
const han = (0, CharacterConverter_1.zen2han_conv)(word);
|
|
29
|
+
generator.add(han);
|
|
30
|
+
// 平仮名、カタカナ、及びそれによる辞書引き追加
|
|
31
|
+
const hiraganaResult = this.processor.romajiToHiraganaPredictively(lower);
|
|
32
|
+
for (const a of hiraganaResult.suffixes) {
|
|
33
|
+
const hira = hiraganaResult.prefix + a;
|
|
34
|
+
generator.add(hira);
|
|
35
|
+
// 平仮名による辞書引き
|
|
36
|
+
if (this.dict != null) {
|
|
37
|
+
for (const b of this.dict.predictiveSearch(hira)) {
|
|
38
|
+
generator.add(b);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
// 片仮名文字列を生成し候補に加える
|
|
42
|
+
const kata = (0, CharacterConverter_1.hira2kata_conv)(hira);
|
|
43
|
+
generator.add(kata);
|
|
44
|
+
// 半角カナを生成し候補に加える
|
|
45
|
+
generator.add((0, CharacterConverter_1.zen2han_conv)(kata));
|
|
46
|
+
}
|
|
47
|
+
return generator.generate();
|
|
48
|
+
}
|
|
49
|
+
query(word) {
|
|
50
|
+
if (word == "") {
|
|
51
|
+
return "";
|
|
52
|
+
}
|
|
53
|
+
const words = this.parseQuery(word);
|
|
54
|
+
let result = "";
|
|
55
|
+
for (const w of words) {
|
|
56
|
+
result += this.queryAWord(w);
|
|
57
|
+
}
|
|
58
|
+
return result;
|
|
59
|
+
}
|
|
60
|
+
setDict(dict) {
|
|
61
|
+
this.dict = dict;
|
|
62
|
+
}
|
|
63
|
+
setRxop(rxop) {
|
|
64
|
+
this.rxop = rxop;
|
|
65
|
+
}
|
|
66
|
+
*parseQuery(query) {
|
|
67
|
+
const re = /[^A-Z\s]+|[A-Z]{2,}|([A-Z][^A-Z\s]+)|([A-Z]\s*$)/g;
|
|
68
|
+
let myArray;
|
|
69
|
+
while ((myArray = re.exec(query)) !== null) {
|
|
70
|
+
yield myArray[0];
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
exports.Migemo = Migemo;
|
|
75
|
+
//# sourceMappingURL=Migemo.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Migemo.js","sourceRoot":"","sources":["../src/Migemo.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export declare class RegexNode {
|
|
2
|
+
code: string;
|
|
3
|
+
child: RegexNode | null;
|
|
4
|
+
next: RegexNode | null;
|
|
5
|
+
constructor(code: string);
|
|
6
|
+
}
|
|
7
|
+
export declare class RegexGenerator {
|
|
8
|
+
or: string;
|
|
9
|
+
beginGroup: string;
|
|
10
|
+
endGroup: string;
|
|
11
|
+
beginClass: string;
|
|
12
|
+
endClass: string;
|
|
13
|
+
newline: string;
|
|
14
|
+
root: RegexNode | null;
|
|
15
|
+
constructor(or: string, beginGroup: string, endGroup: string, beginClass: string, endClass: string, newline: string);
|
|
16
|
+
static getDEFAULT(): RegexGenerator;
|
|
17
|
+
static _add(node: RegexNode | null, word: string, offset: number): RegexNode | null;
|
|
18
|
+
add(word: string): void;
|
|
19
|
+
_generateStub(node: RegexNode | null): string;
|
|
20
|
+
generate(): string;
|
|
21
|
+
}
|