diff options
author | toasted-nutbread <toasted-nutbread@users.noreply.github.com> | 2019-12-09 21:18:23 -0500 |
---|---|---|
committer | toasted-nutbread <toasted-nutbread@users.noreply.github.com> | 2019-12-13 23:11:56 -0500 |
commit | ddad034aa6b8d3b67871af9bc2409412da29ec84 (patch) | |
tree | ebadae03a0c6e033def712da374594cfda296c15 /ext/bg/js/backend.js | |
parent | 73ce2fe3d3572faa194735052b1448f6a46fa969 (diff) |
Move apiTextParse implementation into Backend
Diffstat (limited to 'ext/bg/js/backend.js')
-rw-r--r-- | ext/bg/js/backend.js | 30 |
1 files changed, 28 insertions, 2 deletions
diff --git a/ext/bg/js/backend.js b/ext/bg/js/backend.js index 4c3b3dfa..56bd4fca 100644 --- a/ext/bg/js/backend.js +++ b/ext/bg/js/backend.js @@ -254,8 +254,34 @@ class Backend { return {length, definitions}; } - _onApiTextParse({text, optionsContext}) { - return apiTextParse(text, optionsContext); + async _onApiTextParse({text, optionsContext}) { + const options = await this.getOptions(optionsContext); + const results = []; + while (text.length > 0) { + const term = []; + const [definitions, sourceLength] = await this.translator.findTermsInternal( + text.substring(0, options.scanning.length), + dictEnabledSet(options), + options.scanning.alphanumeric, + {} + ); + if (definitions.length > 0) { + dictTermsSort(definitions); + const {expression, reading} = definitions[0]; + const source = text.substring(0, sourceLength); + for (const {text, furigana} of jpDistributeFuriganaInflected(expression, reading, source)) { + const reading = jpConvertReading(text, furigana, options.parsing.readingMode); + term.push({text, reading}); + } + text = text.substring(source.length); + } else { + const reading = jpConvertReading(text[0], null, options.parsing.readingMode); + term.push({text: text[0], reading}); + text = text.substring(1); + } + results.push(term); + } + return results; } _onApiTextParseMecab({text, optionsContext}) { |