From be1c7e50e1e8809ea56f2c9d472eccd8ffd73a97 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Fri, 19 Apr 2024 04:57:58 +0200 Subject: Adding upstream version 1.44.3. Signed-off-by: Daniel Baumann --- .../libh2o/doc/search/oktavia-english-search.js | 9039 ++++++++++++++++++++ 1 file changed, 9039 insertions(+) create mode 100644 web/server/h2o/libh2o/doc/search/oktavia-english-search.js (limited to 'web/server/h2o/libh2o/doc/search/oktavia-english-search.js') diff --git a/web/server/h2o/libh2o/doc/search/oktavia-english-search.js b/web/server/h2o/libh2o/doc/search/oktavia-english-search.js new file mode 100644 index 00000000..5911991f --- /dev/null +++ b/web/server/h2o/libh2o/doc/search/oktavia-english-search.js @@ -0,0 +1,9039 @@ +// generatedy by JSX compiler 0.9.10 (2013-02-22 10:18:33 +0900; e3a1f2a04656dbfd626086b3c68606d0c9697212) +var JSX = {}; +(function (JSX) { +/** + * copies the implementations from source interface to target + */ +function $__jsx_merge_interface(target, source) { + for (var k in source.prototype) + if (source.prototype.hasOwnProperty(k)) + target.prototype[k] = source.prototype[k]; +} + +/** + * defers the initialization of the property + */ +function $__jsx_lazy_init(obj, prop, func) { + function reset(obj, prop, value) { + delete obj[prop]; + obj[prop] = value; + return value; + } + + Object.defineProperty(obj, prop, { + get: function () { + return reset(obj, prop, func()); + }, + set: function (v) { + reset(obj, prop, v); + }, + enumerable: true, + configurable: true + }); +} + +/** + * sideeffect().a /= b + */ +function $__jsx_div_assign(obj, prop, divisor) { + return obj[prop] = (obj[prop] / divisor) | 0; +} + +/* + * global functions, renamed to avoid conflict with local variable names + */ +var $__jsx_parseInt = parseInt; +var $__jsx_parseFloat = parseFloat; +var $__jsx_isNaN = isNaN; +var $__jsx_isFinite = isFinite; + +var $__jsx_encodeURIComponent = encodeURIComponent; +var $__jsx_decodeURIComponent = decodeURIComponent; +var $__jsx_encodeURI = encodeURI; +var $__jsx_decodeURI = decodeURI; + +var $__jsx_ObjectToString = Object.prototype.toString; +var $__jsx_ObjectHasOwnProperty = Object.prototype.hasOwnProperty; + +/* + * profiler object, initialized afterwards + */ +function $__jsx_profiler() { +} + +/* + * public interface to JSX code + */ +JSX.require = function (path) { + var m = $__jsx_classMap[path]; + return m !== undefined ? m : null; +}; + +JSX.profilerIsRunning = function () { + return $__jsx_profiler.getResults != null; +}; + +JSX.getProfileResults = function () { + return ($__jsx_profiler.getResults || function () { return {}; })(); +}; + +JSX.postProfileResults = function (url) { + if ($__jsx_profiler.postResults == null) + throw new Error("profiler has not been turned on"); + return $__jsx_profiler.postResults(url); +}; + +JSX.resetProfileResults = function () { + if ($__jsx_profiler.resetResults == null) + throw new Error("profiler has not been turned on"); + return $__jsx_profiler.resetResults(); +}; +JSX.DEBUG = true; +/** + * class _Main extends Object + * @constructor + */ +function _Main() { +} + +/** + * @constructor + */ +function _Main$() { +}; + +_Main$.prototype = new _Main; + +/** + * @param {Array.} args + */ +_Main.main$AS = function (args) { + OktaviaSearch$setStemmer$LStemmer$(new EnglishStemmer$()); +}; + +var _Main$main$AS = _Main.main$AS; + +/** + * class _Result extends Object + * @constructor + */ +function _Result() { +} + +/** + * @constructor + * @param {!string} title + * @param {!string} url + * @param {!string} content + * @param {!number} score + */ +function _Result$SSSI(title, url, content, score) { + this.title = title; + this.url = url; + this.content = content; + this.score = score; +}; + +_Result$SSSI.prototype = new _Result; + +/** + * class _Proposal extends Object + * @constructor + */ +function _Proposal() { +} + +/** + * @constructor + * @param {!string} options + * @param {!string} label + * @param {!number} count + */ +function _Proposal$SSI(options, label, count) { + this.options = options; + this.label = label; + this.count = count; +}; + +_Proposal$SSI.prototype = new _Proposal; + +/** + * class OktaviaSearch extends Object + * @constructor + */ +function OktaviaSearch() { +} + +/** + * @constructor + * @param {!number} entriesPerPage + */ +function OktaviaSearch$I(entriesPerPage) { + this._queries = null; + this._result = null; + this._proposals = null; + this._currentFolderDepth = 0; + this._oktavia = new Oktavia$(); + this._entriesPerPage = entriesPerPage; + this._currentPage = 1; + this._queryString = null; + this._callback = null; + OktaviaSearch._instance = this; +}; + +OktaviaSearch$I.prototype = new OktaviaSearch; + +/** + * @param {Stemmer} stemmer + */ +OktaviaSearch.setStemmer$LStemmer$ = function (stemmer) { + if (OktaviaSearch._instance) { + OktaviaSearch._instance._oktavia.setStemmer$LStemmer$(stemmer); + } else { + OktaviaSearch._stemmer = stemmer; + } +}; + +var OktaviaSearch$setStemmer$LStemmer$ = OktaviaSearch.setStemmer$LStemmer$; + +/** + * @param {!string} index + */ +OktaviaSearch.prototype.loadIndex$S = function (index) { + if (OktaviaSearch._stemmer) { + this._oktavia.setStemmer$LStemmer$(OktaviaSearch._stemmer); + } + this._oktavia.load$S(Binary$base64decode$S(index)); + if (this._queryString) { + this.search$SF$IIV$((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[tool/web/oktavia-search.jsx:84:28] null access\n this.search(this._queryString, this._callback);\n ^\n"); + } + return v; + }(this._queryString)), this._callback); + this._queryString = null; + this._callback = null; + } +}; + +/** + * @param {!string} queryString + * @param {*} callback + */ +OktaviaSearch.prototype.search$SF$IIV$ = function (queryString, callback) { + /** @type {QueryStringParser} */ + var queryParser; + /** @type {SearchSummary} */ + var summary; + if (this._oktavia) { + queryParser = new QueryStringParser$(); + queryParser.parse$S(queryString); + this._queries = queryParser.queries; + summary = this._oktavia.search$ALQuery$(queryParser.queries); + console.log(summary); + if (summary.size$() > 0) { + this._result = this._sortResult$LSearchSummary$(summary); + this._proposals = [ ]; + this._currentPage = 1; + } else { + this._result = [ ]; + if (this._queries.length > 1) { + this._proposals = summary.getProposal$(); + } else { + this._proposals = [ ]; + } + this._currentPage = 1; + } + callback(this.resultSize$(), this.totalPages$()); + } else { + this._queryString = queryString; + this._callback = callback; + } +}; + +/** + * @return {!number} + */ +OktaviaSearch.prototype.resultSize$ = function () { + return (this._result.length | 0); +}; + +/** + * @return {!number} + */ +OktaviaSearch.prototype.totalPages$ = function () { + console.log(this._result.length); + console.log(this._entriesPerPage); + console.log(Math.ceil(this._result.length / this._entriesPerPage)); + return (Math.ceil(this._result.length / this._entriesPerPage) | 0); +}; + +/** + * @return {!number} + */ +OktaviaSearch.prototype.currentPage$ = function () { + return this._currentPage; +}; + +/** + * @param {!number} page + */ +OktaviaSearch.prototype.setCurrentPage$I = function (page) { + this._currentPage = page; +}; + +/** + * @return {!boolean} + */ +OktaviaSearch.prototype.hasPrevPage$ = function () { + return this._currentPage !== 1; +}; + +/** + * @return {!boolean} + */ +OktaviaSearch.prototype.hasNextPage$ = function () { + return this._currentPage !== this.totalPages$(); +}; + +/** + * @return {Array.} + */ +OktaviaSearch.prototype.getResult$ = function () { + /** @type {Style} */ + var style; + /** @type {!number} */ + var start; + /** @type {!number} */ + var last; + /** @type {Metadata} */ + var metadata; + /** @type {!number} */ + var num; + /** @type {Array.} */ + var results; + /** @type {!number} */ + var i; + /** @type {SearchUnit} */ + var unit; + /** @type {Array.} */ + var info; + /** @type {!number} */ + var offset; + /** @type {!string} */ + var content; + /** @type {Array.} */ + var positions; + /** @type {!number} */ + var end; + /** @type {!boolean} */ + var split; + /** @type {!number} */ + var j; + /** @type {Position} */ + var pos; + /** @type {!string} */ + var text; + style = new Style$S('html'); + start = (this._currentPage - 1) * this._entriesPerPage; + last = Math.min(this._currentPage * this._entriesPerPage, this._result.length); + metadata = this._oktavia.getPrimaryMetadata$(); + num = 250; + results = [ ]; + for (i = start; i < last; i++) { + unit = this._result[i]; + info = metadata.getInformation$I(unit.id).split(Oktavia.eob); + offset = info[0].length + 1; + content = metadata.getContent$I(unit.id); + start = 0; + positions = unit.getPositions$(); + if (content.indexOf((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[tool/web/oktavia-search.jsx:179:36] null access\n if (content.indexOf(info[0]) == 1)\n ^\n"); + } + return v; + }(info[0]))) === 1) { + content = content.slice(info[0].length + 2, content.length); + start += info[0].length + 2; + } + end = start + num; + split = false; + if (positions[0].position > end - positions[0].word.length) { + end = positions[0].position + Math.floor(num / 2); + split = true; + } + for (j = positions.length - 1; j > - 1; j--) { + pos = positions[j]; + if (pos.position + pos.word.length < end) { + content = [ content.slice(0, pos.position - start), style.convert$S('*').replace('*', content.slice(pos.position - start, pos.position + pos.word.length - start)), content.slice(pos.position + pos.word.length - start, content.length) ].join(''); + } + } + if (split) { + text = [ content.slice(0, Math.floor(num / 2)) + ' ...', content.slice(- Math.floor(num / 2), end - start) ].join('
'); + } else { + text = content.slice(0, end - start) + ' ...
'; + } + text = text.replace(Oktavia.eob, ' ').replace(/()()+/, '

'); + results.push(new _Result$SSSI((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[tool/web/oktavia-search.jsx:215:41] null access\n results.push(new _Result(info[0], info[1], text, unit.score));\n ^\n"); + } + return v; + }(info[0])), (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[tool/web/oktavia-search.jsx:215:50] null access\n results.push(new _Result(info[0], info[1], text, unit.score));\n ^\n"); + } + return v; + }(info[1])), text, unit.score)); + } + return results; +}; + +/** + * @return {Array.} + */ +OktaviaSearch.prototype.getProposals$ = function () { + /** @type {Style} */ + var style; + /** @type {Array.} */ + var results; + /** @type {!number} */ + var i; + /** @type {Proposal} */ + var proposal; + /** @type {Array.} */ + var label; + /** @type {Array.} */ + var option; + /** @type {!number} */ + var j; + style = new Style$S('html'); + results = [ ]; + if (this._queries.length > 1) { + for (i = 0; i < this._proposals.length; i++) { + proposal = this._proposals[i]; + label = [ ]; + option = [ ]; + for (j = 0; j < this._queries.length; j++) { + if (j !== proposal.omit) { + label.push(style.convert$S('' + this._queries[j].toString() + '')); + option.push(this._queries[j].toString()); + } else { + label.push(style.convert$S('' + this._queries[j].toString() + '')); + } + } + results.push(new _Proposal$SSI(option.join(' '), label.join(' '), proposal.expect)); + } + } + return results; +}; + +/** + * @param {SearchSummary} summary + * @return {Array.} + */ +OktaviaSearch.prototype._sortResult$LSearchSummary$ = function (summary) { + /** @type {!number} */ + var i; + /** @type {!number} */ + var score; + /** @type {SearchUnit} */ + var unit; + /** @type {!string} */ + var pos; + /** @type {Position} */ + var position; + for (i = 0; i < summary.result.units.length; i++) { + score = 0; + unit = summary.result.units[i]; + for (pos in unit.positions) { + position = unit.positions[pos]; + if (this._oktavia.wordPositionType$I(position.position)) { + score += 10; + } else { + score += 1; + } + if (! position.stemmed) { + score += 2; + } + } + unit.score = (score | 0); + } + return summary.getSortedResult$(); +}; + +/** + * class _Main$0 extends Object + * @constructor + */ +function _Main$0() { +} + +/** + * @constructor + */ +function _Main$0$() { +}; + +_Main$0$.prototype = new _Main$0; + +/** + * @param {Array.} args + */ +_Main$0.main$AS = function (args) { +}; + +var _Main$0$main$AS = _Main$0.main$AS; + +/** + * class Oktavia extends Object + * @constructor + */ +function Oktavia() { +} + +/** + * @constructor + */ +function Oktavia$() { + this._compressCode2utf16 = null; + this._fmindex = new FMIndex$(); + this._metadatas = ({ }); + this._metadataLabels = [ ]; + this._stemmer = null; + this._stemmingResult = ({ }); + this._utf162compressCode = [ Oktavia.eof, Oktavia.eob, Oktavia.unknown ]; + this._utf162compressCode.length = 65536; + this._compressCode2utf16 = [ Oktavia.eof, Oktavia.eob, Oktavia.unknown ]; +}; + +Oktavia$.prototype = new Oktavia; + +/** + * @param {Stemmer} stemmer + */ +Oktavia.prototype.setStemmer$LStemmer$ = function (stemmer) { + this._stemmer = stemmer; +}; + +/** + * @return {Metadata} + */ +Oktavia.prototype.getPrimaryMetadata$ = function () { + return this._metadatas[this._metadataLabels[0]]; +}; + +/** + * @param {!string} key + * @return {Section} + */ +Oktavia.prototype.addSection$S = function (key) { + /** @type {Section} */ + var section; + if (this._metadataLabels.indexOf(key) !== - 1) { + throw new Error('Metadata name ' + key + ' is already exists'); + } + this._metadataLabels.push(key); + section = new Section$LOktavia$(this); + this._metadatas[key] = section; + return section; +}; + +/** + * @param {!string} key + * @return {Section} + */ +Oktavia.prototype.getSection$S = function (key) { + if (this._metadataLabels.indexOf(key) === - 1) { + throw new Error('Metadata name ' + key + " does't exists"); + } + return (function (v) { + if (! (v == null || v instanceof Section)) { + debugger; + throw new Error("[src/oktavia.jsx:67:36] detected invalid cast, value is not an instance of the designated type or null\n return this._metadatas[key] as Section;\n ^^\n"); + } + return v; + }(this._metadatas[key])); +}; + +/** + * @param {!string} key + * @return {Splitter} + */ +Oktavia.prototype.addSplitter$S = function (key) { + /** @type {Splitter} */ + var splitter; + if (this._metadataLabels.indexOf(key) !== - 1) { + throw new Error('Metadata name ' + key + ' is already exists'); + } + this._metadataLabels.push(key); + splitter = new Splitter$LOktavia$(this); + this._metadatas[key] = splitter; + return splitter; +}; + +/** + * @param {!string} key + * @return {Splitter} + */ +Oktavia.prototype.getSplitter$S = function (key) { + if (this._metadataLabels.indexOf(key) === - 1) { + throw new Error('Metadata name ' + key + " does't exists"); + } + return (function (v) { + if (! (v == null || v instanceof Splitter)) { + debugger; + throw new Error("[src/oktavia.jsx:88:36] detected invalid cast, value is not an instance of the designated type or null\n return this._metadatas[key] as Splitter;\n ^^\n"); + } + return v; + }(this._metadatas[key])); +}; + +/** + * @param {!string} key + * @param {Array.} headers + * @return {Table} + */ +Oktavia.prototype.addTable$SAS = function (key, headers) { + /** @type {Table} */ + var table; + if (this._metadataLabels.indexOf(key) !== - 1) { + throw new Error('Metadata name ' + key + ' is already exists'); + } + this._metadataLabels.push(key); + table = new Table$LOktavia$AS(this, headers); + this._metadatas[key] = table; + return table; +}; + +/** + * @param {!string} key + * @return {Table} + */ +Oktavia.prototype.getTable$S = function (key) { + if (this._metadataLabels.indexOf(key) === - 1) { + throw new Error('Metadata name ' + key + " does't exists"); + } + return (function (v) { + if (! (v == null || v instanceof Table)) { + debugger; + throw new Error("[src/oktavia.jsx:109:36] detected invalid cast, value is not an instance of the designated type or null\n return this._metadatas[key] as Table;\n ^^\n"); + } + return v; + }(this._metadatas[key])); +}; + +/** + * @param {!string} key + * @return {Block} + */ +Oktavia.prototype.addBlock$S = function (key) { + /** @type {Block} */ + var block; + if (this._metadataLabels.indexOf(key) !== - 1) { + throw new Error('Metadata name ' + key + ' is already exists'); + } + this._metadataLabels.push(key); + block = new Block$LOktavia$(this); + this._metadatas[key] = block; + return block; +}; + +/** + * @param {!string} key + * @return {Block} + */ +Oktavia.prototype.getBlock$S = function (key) { + if (this._metadataLabels.indexOf(key) === - 1) { + throw new Error('Metadata name ' + key + " does't exists"); + } + return (function (v) { + if (! (v == null || v instanceof Block)) { + debugger; + throw new Error("[src/oktavia.jsx:130:36] detected invalid cast, value is not an instance of the designated type or null\n return this._metadatas[key] as Block;\n ^^\n"); + } + return v; + }(this._metadatas[key])); +}; + +/** + */ +Oktavia.prototype.addEndOfBlock$ = function () { + this._fmindex.push$S(Oktavia.eob); +}; + +/** + * @param {!string} words + */ +Oktavia.prototype.addWord$S = function (words) { + /** @type {Array.} */ + var str; + /** @type {!number} */ + var i; + /** @type {!number} */ + var charCode; + /** @type {undefined|!string} */ + var newCharCode; + str = [ ]; + str.length = words.length; + for (i = 0; i < words.length; i++) { + charCode = words.charCodeAt(i); + newCharCode = this._utf162compressCode[charCode]; + if (newCharCode == null) { + newCharCode = String.fromCharCode(this._compressCode2utf16.length); + this._utf162compressCode[charCode] = newCharCode; + this._compressCode2utf16.push(String.fromCharCode(charCode)); + } + str.push((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/oktavia.jsx:152:21] null access\n str.push(newCharCode);\n ^^^^^^^^^^^\n"); + } + return v; + }(newCharCode))); + } + this._fmindex.push$S(str.join('')); +}; + +/** + * @param {!string} words + * @param {!boolean} stemming + */ +Oktavia.prototype.addWord$SB = function (words, stemming) { + /** @type {Array.} */ + var wordList; + /** @type {!number} */ + var i; + /** @type {undefined|!string} */ + var originalWord; + /** @type {!string} */ + var headSmall; + /** @type {!string} */ + var baseWord; + /** @type {!string} */ + var compressedCodeWord; + /** @type {Array.} */ + var stemmedList; + this.addWord$S(words); + if (stemming && this._stemmer) { + wordList = words.split(/\s+/); + for (i = 0; i < wordList.length; i++) { + originalWord = wordList[i]; + headSmall = originalWord.slice(0, 1).toLowerCase() + originalWord.slice(1); + baseWord = this._stemmer.stemWord$S(originalWord.toLowerCase()); + if (originalWord.indexOf(baseWord) === - 1 && headSmall.indexOf(baseWord) === - 1) { + compressedCodeWord = this._convertToCompressionCode$S((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/oktavia.jsx:170:76] null access\n var compressedCodeWord = this._convertToCompressionCode(originalWord);\n ^^^^^^^^^^^^\n"); + } + return v; + }(originalWord))); + stemmedList = this._stemmingResult[baseWord]; + if (! stemmedList) { + stemmedList = [ compressedCodeWord ]; + this._stemmingResult[baseWord] = stemmedList; + } else { + if (stemmedList.indexOf(compressedCodeWord) === - 1) { + stemmedList.push(compressedCodeWord); + } + } + } + } + } +}; + +/** + * @param {!string} keyword + * @return {!string} + */ +Oktavia.prototype._convertToCompressionCode$S = function (keyword) { + /** @type {Array.} */ + var resultChars; + /** @type {!number} */ + var i; + /** @type {undefined|!string} */ + var chr; + resultChars = [ ]; + for (i = 0; i < keyword.length; i++) { + chr = this._utf162compressCode[keyword.charCodeAt(i)]; + if (chr == null) { + resultChars.push(Oktavia.unknown); + } else { + resultChars.push((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/oktavia.jsx:198:33] null access\n resultChars.push(chr);\n ^^^\n"); + } + return v; + }(chr))); + } + } + return resultChars.join(''); +}; + +/** + * @param {!string} keyword + * @param {!boolean} stemming + * @return {Array.} + */ +Oktavia.prototype.rawSearch$SB = function (keyword, stemming) { + /** @type {Array.} */ + var result; + /** @type {!string} */ + var baseWord; + /** @type {Array.} */ + var stemmedList; + /** @type {!number} */ + var i; + /** @type {undefined|!string} */ + var word; + if (stemming) { + result = [ ]; + if (this._stemmer) { + baseWord = this._stemmer.stemWord$S(keyword.toLowerCase()); + stemmedList = this._stemmingResult[baseWord]; + if (stemmedList) { + for (i = 0; i < stemmedList.length; i++) { + word = stemmedList[i]; + result = result.concat(this._fmindex.search$S((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/oktavia.jsx:219:68] null access\n result = result.concat(this._fmindex.search(word));\n ^^^^\n"); + } + return v; + }(word)))); + } + } + } + } else { + result = this._fmindex.search$S(this._convertToCompressionCode$S(keyword)); + } + return result; +}; + +/** + * @param {Array.} queries + * @return {SearchSummary} + */ +Oktavia.prototype.search$ALQuery$ = function (queries) { + /** @type {SearchSummary} */ + var summary; + /** @type {!number} */ + var i; + summary = new SearchSummary$LOktavia$(this); + for (i = 0; i < queries.length; i++) { + summary.addQuery$LSingleResult$(this._searchQuery$LQuery$(queries[i])); + } + summary.mergeResult$(); + return summary; +}; + +/** + * @param {Query} query + * @return {SingleResult} + */ +Oktavia.prototype._searchQuery$LQuery$ = function (query) { + /** @type {SingleResult} */ + var result; + /** @type {Array.} */ + var positions; + result = new SingleResult$SBB(query.word, query.or, query.not); + if (query.raw) { + positions = this.rawSearch$SB(query.word, false); + } else { + positions = this.rawSearch$SB(query.word, false).concat(this.rawSearch$SB(query.word, true)); + } + this.getPrimaryMetadata$().grouping$LSingleResult$AISB(result, positions, query.word, ! query.raw); + return result; +}; + +/** + */ +Oktavia.prototype.build$ = function () { + this.build$IB(5, false); +}; + +/** + * @param {!number} cacheDensity + * @param {!boolean} verbose + */ +Oktavia.prototype.build$IB = function (cacheDensity, verbose) { + /** @type {!string} */ + var key; + /** @type {!number} */ + var cacheRange; + /** @type {!number} */ + var maxChar; + for (key in this._metadatas) { + this._metadatas[key]._build$(); + } + cacheRange = Math.round(Math.max(1, 100 / Math.min(100, Math.max(0.01, cacheDensity)))); + maxChar = this._compressCode2utf16.length; + this._fmindex.build$SIIB(Oktavia.eof, maxChar, cacheRange, verbose); +}; + +/** + * @return {!string} + */ +Oktavia.prototype.dump$ = function () { + return this.dump$B(false); +}; + +/** + * @param {!boolean} verbose + * @return {!string} + */ +Oktavia.prototype.dump$B = function (verbose) { + /** @type {!string} */ + var headerSource; + /** @type {!string} */ + var header; + /** @type {!string} */ + var fmdata; + /** @type {Array.} */ + var result; + /** @type {!number} */ + var i; + /** @type {CompressionReport} */ + var report; + /** @type {undefined|!string} */ + var name; + /** @type {!string} */ + var data; + headerSource = "oktavia-01"; + header = Binary$dumpString$S(headerSource).slice(1); + if (verbose) { + console.log("Source text size: " + (this._fmindex.size$() * 2 + "") + ' bytes'); + } + fmdata = this._fmindex.dump$B(verbose); + result = [ header, fmdata ]; + result.push(Binary$dump16bitNumber$I(this._compressCode2utf16.length)); + for (i = 3; i < this._compressCode2utf16.length; i++) { + result.push((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/oktavia.jsx:296:48] null access\n result.push(this._compressCode2utf16[i]);\n ^\n"); + } + return v; + }(this._compressCode2utf16[i]))); + } + if (verbose) { + console.log('Char Code Map: ' + (this._compressCode2utf16.length * 2 - 2 + "") + ' bytes'); + } + report = new CompressionReport$(); + result.push(Binary$dumpStringListMap$HASLCompressionReport$(this._stemmingResult, report)); + if (verbose) { + console.log('Stemmed Word Table: ' + (result[result.length - 1].length + "") + ' bytes (' + (report.rate$() + "") + '%)'); + console.log(this._stemmingResult); + } + result.push(Binary$dump16bitNumber$I(this._metadataLabels.length)); + for (i = 0; i < this._metadataLabels.length; i++) { + report = new CompressionReport$(); + name = this._metadataLabels[i]; + data = this._metadatas[name]._dump$LCompressionReport$(report); + result.push(Binary$dumpString$SLCompressionReport$((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/oktavia.jsx:317:42] null access\n result.push(Binary.dumpString(name, report), data);\n ^^^^\n"); + } + return v; + }(name)), report), data); + if (verbose) { + console.log('Meta Data ' + (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/oktavia.jsx:320:43] null access\n console.log(\'Meta Data \' + name + \': \' + (data.length * 2) as string + \' bytes (\' + report.rate() as string + \'%)\');\n ^^^^\n"); + } + return v; + }(name)) + ': ' + (data.length * 2 + "") + ' bytes (' + (report.rate$() + "") + '%)'); + } + } + return result.join(''); +}; + +/** + * @param {!string} data + */ +Oktavia.prototype.load$S = function (data) { + /** @type {!string} */ + var headerSource; + /** @type {!string} */ + var header; + /** @type {!number} */ + var offset; + /** @type {!number} */ + var charCodeCount; + /** @type {!number} */ + var i; + /** @type {!number} */ + var charCode; + /** @type {LoadedStringListMapResult} */ + var stemmedWords; + /** @type {!number} */ + var metadataCount; + /** @type {LoadedStringResult} */ + var nameResult; + /** @type {!string} */ + var name; + /** @type {!number} */ + var type; + headerSource = "oktavia-01"; + header = Binary$dumpString$S(headerSource).slice(1); + if (data.slice(0, 5) !== header) { + throw new Error('Invalid data file'); + } + this._metadatas = ({ }); + this._metadataLabels = [ ]; + offset = 5; + offset = this._fmindex.load$SI(data, offset); + charCodeCount = Binary$load16bitNumber$SI(data, offset++); + this._compressCode2utf16 = [ Oktavia.eof, Oktavia.eob, Oktavia.unknown ]; + this._utf162compressCode = [ Oktavia.eof, Oktavia.eob, Oktavia.unknown ]; + for (i = 3; i < charCodeCount; i++) { + charCode = Binary$load16bitNumber$SI(data, offset++); + this._compressCode2utf16.push(String.fromCharCode(charCode)); + this._utf162compressCode[charCode] = String.fromCharCode(i); + } + stemmedWords = Binary$loadStringListMap$SI(data, offset); + this._stemmingResult = stemmedWords.result; + offset = stemmedWords.offset; + metadataCount = Binary$load16bitNumber$SI(data, offset++); + for (i = 0; i < metadataCount; i++) { + nameResult = Binary$loadString$SI(data, offset); + name = nameResult.result; + offset = nameResult.offset; + type = Binary$load16bitNumber$SI(data, offset++); + switch (type) { + case 0: + offset = Section$_load$LOktavia$SSI(this, name, data, offset); + break; + case 1: + offset = Splitter$_load$LOktavia$SSI(this, name, data, offset); + break; + case 2: + offset = Table$_load$LOktavia$SSI(this, name, data, offset); + break; + case 3: + offset = Block$_load$LOktavia$SSI(this, name, data, offset); + break; + } + } +}; + +/** + * @return {!number} + */ +Oktavia.prototype.contentSize$ = function () { + return this._fmindex.contentSize$(); +}; + +/** + * @param {!number} position + * @return {!number} + */ +Oktavia.prototype.wordPositionType$I = function (position) { + /** @type {!number} */ + var result; + /** @type {!string} */ + var ahead; + result = 0; + if (position === 0) { + result = 4; + } else { + ahead = this._fmindex.getSubstring$II(position - 1, 1); + if (/\s/.test(ahead)) { + result = 2; + } else { + if (/\W/.test(ahead)) { + result = 1; + } else { + if (Oktavia.eob === ahead) { + result = 3; + } + } + } + } + return (result | 0); +}; + +/** + * @param {!number} position + * @param {!number} length + * @return {!string} + */ +Oktavia.prototype._getSubstring$II = function (position, length) { + /** @type {!string} */ + var result; + /** @type {Array.} */ + var str; + /** @type {!number} */ + var i; + result = this._fmindex.getSubstring$II(position, length); + str = [ ]; + for (i = 0; i < result.length; i++) { + str.push((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/oktavia.jsx:415:45] null access\n str.push(this._compressCode2utf16[result.charCodeAt(i)]);\n ^\n"); + } + return v; + }(this._compressCode2utf16[result.charCodeAt(i)]))); + } + return str.join(''); +}; + +/** + * class Binary extends Object + * @constructor + */ +function Binary() { +} + +/** + * @constructor + */ +function Binary$() { +}; + +Binary$.prototype = new Binary; + +/** + * @param {!number} num + * @return {!string} + */ +Binary.dump32bitNumber$N = function (num) { + /** @type {Array.} */ + var result; + result = [ String.fromCharCode(Math.floor(num / 65536)) ]; + result.push(String.fromCharCode(num % 65536)); + return result.join(""); +}; + +var Binary$dump32bitNumber$N = Binary.dump32bitNumber$N; + +/** + * @param {!string} buffer + * @param {!number} offset + * @return {!number} + */ +Binary.load32bitNumber$SI = function (buffer, offset) { + /** @type {!number} */ + var result; + result = buffer.charCodeAt(offset) * 65536 + buffer.charCodeAt(offset + 1); + return result; +}; + +var Binary$load32bitNumber$SI = Binary.load32bitNumber$SI; + +/** + * @param {!number} num + * @return {!string} + */ +Binary.dump16bitNumber$I = function (num) { + return String.fromCharCode(num % 65536); +}; + +var Binary$dump16bitNumber$I = Binary.dump16bitNumber$I; + +/** + * @param {!string} buffer + * @param {!number} offset + * @return {!number} + */ +Binary.load16bitNumber$SI = function (buffer, offset) { + return (buffer.charCodeAt(offset) | 0); +}; + +var Binary$load16bitNumber$SI = Binary.load16bitNumber$SI; + +/** + * @param {!string} str + * @return {!string} + */ +Binary.dumpString$S = function (str) { + return Binary$dumpString$SLCompressionReport$(str, null); +}; + +var Binary$dumpString$S = Binary.dumpString$S; + +/** + * @param {!string} str + * @param {CompressionReport} report + * @return {!string} + */ +Binary.dumpString$SLCompressionReport$ = function (str, report) { + /** @type {!number} */ + var length; + /** @type {!boolean} */ + var compress; + /** @type {Array.} */ + var charCodes; + /** @type {!number} */ + var i; + /** @type {!number} */ + var charCode; + /** @type {Array.} */ + var result; + /** @type {undefined|!number} */ + var bytes; + if (str.length > 32768) { + str = str.slice(0, 32768); + } + length = str.length; + compress = true; + charCodes = [ ]; + for (i = 0; i < length; i++) { + charCode = str.charCodeAt(i); + if (charCode > 255) { + compress = false; + break; + } + charCodes.push(charCode); + } + if (compress) { + result = [ Binary$dump16bitNumber$I(length + 32768) ]; + for (i = 0; i < length; i += 2) { + bytes = charCodes[i]; + if (i !== length - 1) { + bytes += (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/binary-util.jsx:58:38] null access\n bytes += charCodes[i + 1] << 8;\n ^\n"); + } + return v; + }(charCodes[i + 1])) << 8; + } + result.push(Binary$dump16bitNumber$I((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/binary-util.jsx:60:51] null access\n result.push(Binary.dump16bitNumber(bytes));\n ^^^^^\n"); + } + return v; + }(bytes)))); + } + if (report) { + report.add$II(length, Math.ceil(length / 2)); + } + } else { + result = [ Binary$dump16bitNumber$I(length), str ]; + if (report) { + report.add$II(length, length); + } + } + return result.join(''); +}; + +var Binary$dumpString$SLCompressionReport$ = Binary.dumpString$SLCompressionReport$; + +/** + * @param {!string} buffer + * @param {!number} offset + * @return {LoadedStringResult} + */ +Binary.loadString$SI = function (buffer, offset) { + return new LoadedStringResult$SI(buffer, offset); +}; + +var Binary$loadString$SI = Binary.loadString$SI; + +/** + * @param {Array.} strList + * @return {!string} + */ +Binary.dumpStringList$AS = function (strList) { + return Binary$dumpStringList$ASLCompressionReport$(strList, null); +}; + +var Binary$dumpStringList$AS = Binary.dumpStringList$AS; + +/** + * @param {Array.} strList + * @param {CompressionReport} report + * @return {!string} + */ +Binary.dumpStringList$ASLCompressionReport$ = function (strList, report) { + /** @type {Array.} */ + var result; + /** @type {!number} */ + var i; + result = [ Binary$dump32bitNumber$N(strList.length) ]; + for (i = 0; i < strList.length; i++) { + result.push(Binary$dumpString$SLCompressionReport$((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/binary-util.jsx:93:49] null access\n result.push(Binary.dumpString(strList[i], report));\n ^\n"); + } + return v; + }(strList[i])), report)); + } + return result.join(''); +}; + +var Binary$dumpStringList$ASLCompressionReport$ = Binary.dumpStringList$ASLCompressionReport$; + +/** + * @param {!string} buffer + * @param {!number} offset + * @return {LoadedStringListResult} + */ +Binary.loadStringList$SI = function (buffer, offset) { + return new LoadedStringListResult$SI(buffer, offset); +}; + +var Binary$loadStringList$SI = Binary.loadStringList$SI; + +/** + * @param {Object.>} strMap + * @return {!string} + */ +Binary.dumpStringListMap$HAS = function (strMap) { + return Binary$dumpStringListMap$HASLCompressionReport$(strMap, null); +}; + +var Binary$dumpStringListMap$HAS = Binary.dumpStringListMap$HAS; + +/** + * @param {Object.>} strMap + * @param {CompressionReport} report + * @return {!string} + */ +Binary.dumpStringListMap$HASLCompressionReport$ = function (strMap, report) { + /** @type {Array.} */ + var result; + /** @type {!number} */ + var counter; + /** @type {!string} */ + var key; + result = [ ]; + counter = 0; + for (key in strMap) { + result.push(Binary$dumpString$SLCompressionReport$(key, report)); + result.push(Binary$dumpStringList$ASLCompressionReport$(strMap[key], report)); + counter++; + } + return Binary$dump32bitNumber$N(counter) + result.join(''); +}; + +var Binary$dumpStringListMap$HASLCompressionReport$ = Binary.dumpStringListMap$HASLCompressionReport$; + +/** + * @param {!string} buffer + * @param {!number} offset + * @return {LoadedStringListMapResult} + */ +Binary.loadStringListMap$SI = function (buffer, offset) { + return new LoadedStringListMapResult$SI(buffer, offset); +}; + +var Binary$loadStringListMap$SI = Binary.loadStringListMap$SI; + +/** + * @param {Array.} array + * @return {!string} + */ +Binary.dump32bitNumberList$AN = function (array) { + return Binary$dump32bitNumberList$ANLCompressionReport$(array, null); +}; + +var Binary$dump32bitNumberList$AN = Binary.dump32bitNumberList$AN; + +/** + * @param {Array.} array + * @param {CompressionReport} report + * @return {!string} + */ +Binary.dump32bitNumberList$ANLCompressionReport$ = function (array, report) { + /** @type {Array.} */ + var result; + /** @type {!number} */ + var index; + /** @type {!number} */ + var inputLength; + /** @type {!number} */ + var length; + /** @type {!string} */ + var resultString; + result = [ Binary$dump32bitNumber$N(array.length) ]; + index = 0; + inputLength = array.length; + while (index < inputLength) { + if (array[index] == 0) { + length = Binary$_countZero$ANI(array, index); + result.push(Binary$_zeroBlock$I(length)); + index += length; + } else { + if (Binary$_shouldZebraCode$ANI(array, index)) { + result.push(Binary$_createZebraCode$ANI(array, index)); + index = Math.min(array.length, index + 15); + } else { + length = Binary$_searchDoubleZero$ANI(array, index); + result.push(Binary$_nonZeroBlock$ANII(array, index, length)); + if (length === 0) { + throw new Error(''); + } + index += length; + } + } + } + resultString = result.join(''); + if (report) { + report.add$II(array.length * 2 + 2, resultString.length); + } + return resultString; +}; + +var Binary$dump32bitNumberList$ANLCompressionReport$ = Binary.dump32bitNumberList$ANLCompressionReport$; + +/** + * @param {!string} buffer + * @param {!number} offset + * @return {LoadedNumberListResult} + */ +Binary.load32bitNumberList$SI = function (buffer, offset) { + return new LoadedNumberListResult$SI(buffer, offset); +}; + +var Binary$load32bitNumberList$SI = Binary.load32bitNumberList$SI; + +/** + * @param {Array.} array + * @param {!number} offset + * @return {!number} + */ +Binary._countZero$ANI = function (array, offset) { + /** @type {!number} */ + var i; + for (i = offset; i < array.length; i++) { + if (array[i] != 0) { + return (i - offset | 0); + } + } + return (array.length - offset | 0); +}; + +var Binary$_countZero$ANI = Binary._countZero$ANI; + +/** + * @param {!number} length + * @return {!string} + */ +Binary._zeroBlock$I = function (length) { + /** @type {Array.} */ + var result; + result = [ ]; + while (length > 0) { + if (length > 16384) { + result.push(Binary$dump16bitNumber$I(16384 - 1)); + length -= 16384; + } else { + result.push(Binary$dump16bitNumber$I(length - 1)); + length = 0; + } + } + return result.join(''); +}; + +var Binary$_zeroBlock$I = Binary._zeroBlock$I; + +/** + * @param {Array.} array + * @param {!number} offset + * @return {!boolean} + */ +Binary._shouldZebraCode$ANI = function (array, offset) { + /** @type {!number} */ + var change; + /** @type {!boolean} */ + var isLastZero; + /** @type {!number} */ + var i; + if (array.length - offset < 16) { + return true; + } + change = 0; + isLastZero = false; + for (i = offset; i < offset + 15; i++) { + if (array[i] == 0) { + if (! isLastZero) { + isLastZero = true; + change++; + } + } else { + if (isLastZero) { + isLastZero = false; + change++; + } + } + } + return change > 2; +}; + +var Binary$_shouldZebraCode$ANI = Binary._shouldZebraCode$ANI; + +/** + * @param {Array.} array + * @param {!number} offset + * @return {!number} + */ +Binary._searchDoubleZero$ANI = function (array, offset) { + /** @type {!boolean} */ + var isLastZero; + /** @type {!number} */ + var i; + isLastZero = false; + for (i = offset; i < array.length; i++) { + if (array[i] == 0) { + if (isLastZero) { + return (i - offset - 1 | 0); + } + isLastZero = true; + } else { + isLastZero = false; + } + } + return (array.length - offset | 0); +}; + +var Binary$_searchDoubleZero$ANI = Binary._searchDoubleZero$ANI; + +/** + * @param {Array.} array + * @param {!number} offset + * @param {!number} length + * @return {!string} + */ +Binary._nonZeroBlock$ANII = function (array, offset, length) { + /** @type {Array.} */ + var result; + /** @type {!number} */ + var blockLength; + /** @type {!number} */ + var i; + result = [ ]; + while (length > 0) { + if (length > 16384) { + blockLength = 16384; + length -= 16384; + } else { + blockLength = length; + length = 0; + } + result.push(Binary$dump16bitNumber$I(blockLength - 1 + 0x4000)); + for (i = offset; i < offset + blockLength; i++) { + result.push(Binary$dump32bitNumber$N((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/binary-util.jsx:274:56] null access\n result.push(Binary.dump32bitNumber(array[i]));\n ^\n"); + } + return v; + }(array[i])))); + } + offset += blockLength; + } + return result.join(''); +}; + +var Binary$_nonZeroBlock$ANII = Binary._nonZeroBlock$ANII; + +/** + * @param {Array.} array + * @param {!number} offset + * @return {!string} + */ +Binary._createZebraCode$ANI = function (array, offset) { + /** @type {!number} */ + var last; + /** @type {!number} */ + var code; + /** @type {Array.} */ + var result; + /** @type {!number} */ + var i; + last = Math.min(offset + 15, array.length); + code = 0x8000; + result = [ ]; + for (i = offset; i < last; i++) { + if (array[i] != 0) { + result.push(Binary$dump32bitNumber$N((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/binary-util.jsx:290:56] null access\n result.push(Binary.dump32bitNumber(array[i]));\n ^\n"); + } + return v; + }(array[i])))); + code = code + (0x1 << i - offset); + } + } + return String.fromCharCode(code) + result.join(''); +}; + +var Binary$_createZebraCode$ANI = Binary._createZebraCode$ANI; + +/** + * @param {!string} str + * @return {!string} + */ +Binary.base64encode$S = function (str) { + /** @type {Array.} */ + var out; + /** @type {Array.} */ + var source; + /** @type {!number} */ + var i; + /** @type {!number} */ + var code; + /** @type {!number} */ + var len; + /** @type {!number} */ + var c1; + /** @type {undefined|!number} */ + var c2; + /** @type {undefined|!number} */ + var c3; + out = [ ]; + source = [ ]; + for (i = 0; i < str.length; i++) { + code = str.charCodeAt(i); + source.push(code & 0x00ff, code >>> 8); + } + len = str.length * 2; + i = 0; + while (i < len) { + c1 = (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/binary-util.jsx:319:23] null access\n var c1 = source[i++] & 0xff;\n ^\n"); + } + return v; + }(source[i++])) & 0xff; + if (i === len) { + out.push(Binary._base64EncodeChars.charAt(c1 >> 2)); + out.push(Binary._base64EncodeChars.charAt((c1 & 0x3) << 4)); + out.push("=="); + break; + } + c2 = source[i++]; + if (i === len) { + out.push(Binary._base64EncodeChars.charAt(c1 >> 2)); + out.push(Binary._base64EncodeChars.charAt((c1 & 0x3) << 4 | ((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/binary-util.jsx:331:75] null access\n out.push(Binary._base64EncodeChars.charAt(((c1 & 0x3)<< 4) | ((c2 & 0xF0) >> 4)));\n ^^\n"); + } + return v; + }(c2)) & 0xF0) >> 4)); + out.push(Binary._base64EncodeChars.charAt(((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/binary-util.jsx:332:55] null access\n out.push(Binary._base64EncodeChars.charAt((c2 & 0xF) << 2));\n ^^\n"); + } + return v; + }(c2)) & 0xF) << 2)); + out.push("="); + break; + } + c3 = source[i++]; + out.push(Binary._base64EncodeChars.charAt(c1 >> 2)); + out.push(Binary._base64EncodeChars.charAt((c1 & 0x3) << 4 | ((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/binary-util.jsx:338:71] null access\n out.push(Binary._base64EncodeChars.charAt(((c1 & 0x3)<< 4) | ((c2 & 0xF0) >> 4)));\n ^^\n"); + } + return v; + }(c2)) & 0xF0) >> 4)); + out.push(Binary._base64EncodeChars.charAt(((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/binary-util.jsx:339:52] null access\n out.push(Binary._base64EncodeChars.charAt(((c2 & 0xF) << 2) | ((c3 & 0xC0) >>6)));\n ^^\n"); + } + return v; + }(c2)) & 0xF) << 2 | ((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/binary-util.jsx:339:72] null access\n out.push(Binary._base64EncodeChars.charAt(((c2 & 0xF) << 2) | ((c3 & 0xC0) >>6)));\n ^^\n"); + } + return v; + }(c3)) & 0xC0) >> 6)); + out.push(Binary._base64EncodeChars.charAt((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/binary-util.jsx:340:50] null access\n out.push(Binary._base64EncodeChars.charAt(c3 & 0x3F));\n ^^\n"); + } + return v; + }(c3)) & 0x3F)); + } + return out.join(''); +}; + +var Binary$base64encode$S = Binary.base64encode$S; + +/** + * @param {Array.} source + * @return {!string} + */ +Binary._mergeCharCode$AI = function (source) { + /** @type {Array.} */ + var result; + /** @type {!number} */ + var i; + result = [ ]; + for (i = 0; i < source.length; i += 2) { + result.push(String.fromCharCode((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/binary-util.jsx:360:50] null access\n result.push(String.fromCharCode(source[i] + (source[i + 1] << 8)));\n ^\n"); + } + return v; + }(source[i])) + ((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/binary-util.jsx:360:63] null access\n result.push(String.fromCharCode(source[i] + (source[i + 1] << 8)));\n ^\n"); + } + return v; + }(source[i + 1])) << 8))); + } + return result.join(''); +}; + +var Binary$_mergeCharCode$AI = Binary._mergeCharCode$AI; + +/** + * @param {!string} str + * @return {!string} + */ +Binary.base64decode$S = function (str) { + /** @type {!number} */ + var len; + /** @type {!number} */ + var i; + /** @type {Array.} */ + var out; + /** @type {undefined|!number} */ + var c1; + /** @type {undefined|!number} */ + var c2; + /** @type {!number} */ + var c3; + /** @type {!number} */ + var c4; + len = str.length; + i = 0; + out = [ ]; + while (i < len) { + do { + c1 = Binary._base64DecodeChars[str.charCodeAt(i++) & 0xff]; + } while (i < len && c1 == - 1); + if (c1 == - 1) { + break; + } + do { + c2 = Binary._base64DecodeChars[str.charCodeAt(i++) & 0xff]; + } while (i < len && c2 == - 1); + if (c2 == - 1) { + break; + } + out.push((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/binary-util.jsx:391:18] null access\n out.push((c1 << 2) | ((c2 & 0x30) >> 4));\n ^^\n"); + } + return v; + }(c1)) << 2 | ((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/binary-util.jsx:391:31] null access\n out.push((c1 << 2) | ((c2 & 0x30) >> 4));\n ^^\n"); + } + return v; + }(c2)) & 0x30) >> 4); + do { + c3 = str.charCodeAt(i++) & 0xff; + if (c3 === 61) { + return Binary$_mergeCharCode$AI(out); + } + c3 = (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/binary-util.jsx:399:42] null access\n c3 = Binary._base64DecodeChars[c3];\n ^\n"); + } + return v; + }(Binary._base64DecodeChars[c3])); + } while (i < len && c3 === - 1); + if (c3 === - 1) { + break; + } + out.push(((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/binary-util.jsx:405:19] null access\n out.push(((c2 & 0XF) << 4) | ((c3 & 0x3C) >> 2));\n ^^\n"); + } + return v; + }(c2)) & 0XF) << 4 | (c3 & 0x3C) >> 2); + do { + c4 = str.charCodeAt(i++) & 0xff; + if (c4 === 61) { + return Binary$_mergeCharCode$AI(out); + } + c4 = ((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/binary-util.jsx:414:42] null access\n c4 = Binary._base64DecodeChars[c4];\n ^\n"); + } + return v; + }(Binary._base64DecodeChars[c4])) | 0); + } while (i < len && c4 === - 1); + if (c4 === - 1) { + break; + } + out.push((c3 & 0x03) << 6 | c4); + } + return Binary$_mergeCharCode$AI(out); +}; + +var Binary$base64decode$S = Binary.base64decode$S; + +/** + * class LoadedStringResult extends Object + * @constructor + */ +function LoadedStringResult() { +} + +/** + * @constructor + * @param {!string} data + * @param {!number} offset + */ +function LoadedStringResult$SI(data, offset) { + /** @type {!number} */ + var strLength; + /** @type {Array.} */ + var bytes; + /** @type {!number} */ + var i; + /** @type {!number} */ + var code; + this.result = ""; + this.offset = 0; + strLength = Binary$load16bitNumber$SI(data, offset++); + if (strLength > 32767) { + strLength = strLength - 32768; + bytes = [ ]; + for (i = 0; i < strLength; i += 2) { + code = data.charCodeAt(offset); + bytes.push(String.fromCharCode(code & 0x00ff)); + if (i !== strLength - 1) { + bytes.push(String.fromCharCode(code >>> 8)); + } + offset++; + } + this.result = bytes.join(''); + this.offset = offset; + } else { + this.result = data.slice(offset, offset + strLength); + this.offset = (offset + strLength | 0); + } +}; + +LoadedStringResult$SI.prototype = new LoadedStringResult; + +/** + * class LoadedStringListResult extends Object + * @constructor + */ +function LoadedStringListResult() { +} + +/** + * @constructor + * @param {!string} data + * @param {!number} offset + */ +function LoadedStringListResult$SI(data, offset) { + /** @type {!number} */ + var length; + /** @type {!number} */ + var i; + /** @type {!number} */ + var strLength; + /** @type {!string} */ + var resultStr; + /** @type {Array.} */ + var bytes; + /** @type {!number} */ + var j; + /** @type {!number} */ + var code; + this.offset = 0; + this.result = [ ]; + length = Binary$load32bitNumber$SI(data, offset); + offset += 2; + for (i = 0; i < length; i++) { + strLength = Binary$load16bitNumber$SI(data, offset++); + if (strLength > 32767) { + strLength = strLength - 32768; + bytes = [ ]; + for (j = 0; j < strLength; j += 2) { + code = data.charCodeAt(offset); + bytes.push(String.fromCharCode(code & 0x00ff)); + if (j !== strLength - 1) { + bytes.push(String.fromCharCode(code >>> 8)); + } + offset++; + } + resultStr = bytes.join(''); + } else { + resultStr = data.slice(offset, offset + strLength); + offset = (offset + strLength | 0); + } + this.result.push(resultStr); + } + this.offset = offset; +}; + +LoadedStringListResult$SI.prototype = new LoadedStringListResult; + +/** + * class LoadedStringListMapResult extends Object + * @constructor + */ +function LoadedStringListMapResult() { +} + +/** + * @constructor + * @param {!string} data + * @param {!number} offset + */ +function LoadedStringListMapResult$SI(data, offset) { + /** @type {!number} */ + var length; + /** @type {!number} */ + var i; + /** @type {LoadedStringResult} */ + var keyResult; + /** @type {LoadedStringListResult} */ + var valueResult; + this.offset = 0; + this.result = ({ }); + length = Binary$load32bitNumber$SI(data, offset); + offset += 2; + for (i = 0; i < length; i++) { + keyResult = Binary$loadString$SI(data, offset); + valueResult = Binary$loadStringList$SI(data, keyResult.offset); + this.result[keyResult.result] = valueResult.result; + offset = valueResult.offset; + } + this.offset = offset; +}; + +LoadedStringListMapResult$SI.prototype = new LoadedStringListMapResult; + +/** + * class LoadedNumberListResult extends Object + * @constructor + */ +function LoadedNumberListResult() { +} + +/** + * @constructor + * @param {!string} data + * @param {!number} offset + */ +function LoadedNumberListResult$SI(data, offset) { + /** @type {!number} */ + var resultLength; + /** @type {!number} */ + var originalOffset; + /** @type {Array.} */ + var result; + /** @type {!number} */ + var tag; + /** @type {!number} */ + var length; + /** @type {!number} */ + var i; + this.result = null; + this.offset = 0; + resultLength = Binary$load32bitNumber$SI(data, offset); + originalOffset = offset; + offset += 2; + result = [ ]; + while (result.length < resultLength) { + tag = data.charCodeAt(offset++); + if (tag >>> 15 === 1) { + length = Math.min(resultLength - result.length, 15); + for (i = 0; i < length; i++) { + if (tag >>> i & 0x1) { + result.push(Binary$load32bitNumber$SI(data, offset)); + offset += 2; + } else { + result.push(0); + } + } + } else { + if (tag >>> 14 === 1) { + length = tag - 0x4000 + 1; + for (i = 0; i < length; i++) { + result.push(Binary$load32bitNumber$SI(data, offset)); + offset += 2; + } + } else { + length = tag + 1; + for (i = 0; i < length; i++) { + result.push(0); + } + } + } + } + this.result = result; + this.offset = offset; +}; + +LoadedNumberListResult$SI.prototype = new LoadedNumberListResult; + +/** + * class CompressionReport extends Object + * @constructor + */ +function CompressionReport() { +} + +/** + * @constructor + */ +function CompressionReport$() { + this.source = 0; + this.result = 0; +}; + +CompressionReport$.prototype = new CompressionReport; + +/** + * @param {!number} source + * @param {!number} result + */ +CompressionReport.prototype.add$II = function (source, result) { + this.source += source; + this.result += result; +}; + +/** + * @return {!number} + */ +CompressionReport.prototype.rate$ = function () { + return (Math.round(this.result * 100.0 / this.source) | 0); +}; + +/** + * class Query extends Object + * @constructor + */ +function Query() { +} + +/** + * @constructor + */ +function Query$() { + this.word = ''; + this.or = false; + this.not = false; + this.raw = false; +}; + +Query$.prototype = new Query; + +/** + * @return {!string} + */ +Query.prototype.toString = function () { + /** @type {Array.} */ + var result; + result = [ ]; + if (this.or) { + result.push("OR "); + } + if (this.not) { + result.push("-"); + } + if (this.raw) { + result.push('"', this.word, '"'); + } else { + result.push(this.word); + } + return result.join(''); +}; + +/** + * class QueryStringParser extends Object + * @constructor + */ +function QueryStringParser() { +} + +/** + * @constructor + */ +function QueryStringParser$() { + this.queries = [ ]; +}; + +QueryStringParser$.prototype = new QueryStringParser; + +/** + * @param {!string} queryString + */ +QueryStringParser.prototype.parse$S = function (queryString) { + /** @type {!boolean} */ + var nextOr; + /** @type {!boolean} */ + var nextNot; + /** @type {!number} */ + var currentWordStart; + /** @type {!number} */ + var status; + /** @type {RegExp} */ + var isSpace; + /** @type {!number} */ + var i; + /** @type {!string} */ + var ch; + /** @type {!string} */ + var word; + /** @type {Query} */ + var query; + nextOr = false; + nextNot = false; + currentWordStart = 0; + status = 0; + isSpace = /[\s\u3000]/; + for (i = 0; i < queryString.length; i++) { + ch = queryString.charAt(i); + switch (status) { + case 0: + if (! isSpace.test(ch)) { + if (ch === '-') { + nextNot = true; + } else { + if (ch === '"') { + currentWordStart = i + 1; + status = 2; + } else { + currentWordStart = i; + status = 1; + } + } + } else { + nextNot = false; + } + break; + case 1: + if (isSpace.test(ch)) { + word = queryString.slice(currentWordStart, i); + if (word === 'OR') { + nextOr = true; + } else { + query = new Query$(); + query.word = word; + query.or = nextOr; + query.not = nextNot; + this.queries.push(query); + nextOr = false; + nextNot = false; + } + status = 0; + } + break; + case 2: + if (ch === '"') { + word = queryString.slice(currentWordStart, i); + query = new Query$(); + query.word = word; + query.or = nextOr; + query.not = nextNot; + query.raw = true; + this.queries.push(query); + nextOr = false; + nextNot = false; + status = 0; + } + break; + } + } + switch (status) { + case 0: + break; + case 1: + query = new Query$(); + word = queryString.slice(currentWordStart, queryString.length); + if (word !== 'OR') { + query.word = word; + query.or = nextOr; + query.not = nextNot; + this.queries.push(query); + } + break; + case 2: + query = new Query$(); + query.word = queryString.slice(currentWordStart, queryString.length); + query.or = nextOr; + query.not = nextNot; + query.raw = true; + this.queries.push(query); + break; + } +}; + +/** + * class Proposal extends Object + * @constructor + */ +function Proposal() { +} + +/** + * @constructor + * @param {!number} omit + * @param {!number} expect + */ +function Proposal$II(omit, expect) { + this.omit = omit; + this.expect = expect; +}; + +Proposal$II.prototype = new Proposal; + +/** + * class Position extends Object + * @constructor + */ +function Position() { +} + +/** + * @constructor + * @param {!string} word + * @param {!number} position + * @param {!boolean} stemmed + */ +function Position$SIB(word, position, stemmed) { + this.word = word; + this.position = position; + this.stemmed = stemmed; +}; + +Position$SIB.prototype = new Position; + +/** + * class SearchUnit extends Object + * @constructor + */ +function SearchUnit() { +} + +/** + * @constructor + * @param {!number} id + */ +function SearchUnit$I(id) { + this.positions = ({ }); + this.id = id; + this._size = 0; + this.score = 0; + this.startPosition = (- 1 | 0); +}; + +SearchUnit$I.prototype = new SearchUnit; + +/** + * @param {!string} word + * @param {!number} position + * @param {!boolean} stemmed + */ +SearchUnit.prototype.addPosition$SIB = function (word, position, stemmed) { + /** @type {Position} */ + var positionObj; + positionObj = this.positions[position + ""]; + if (! positionObj) { + this._size++; + this.positions[position + ""] = new Position$SIB(word, position, stemmed); + } else { + if (positionObj.word.length < word.length) { + positionObj.word = word; + } + positionObj.stemmed = positionObj.stemmed && stemmed; + } +}; + +/** + * @param {!number} position + * @return {Position} + */ +SearchUnit.prototype.get$I = function (position) { + return this.positions[position + ""]; +}; + +/** + * @return {!number} + */ +SearchUnit.prototype.size$ = function () { + return this._size; +}; + +/** + * @param {SearchUnit} rhs + */ +SearchUnit.prototype.merge$LSearchUnit$ = function (rhs) { + /** @type {!string} */ + var position; + /** @type {Position} */ + var pos; + for (position in rhs.positions) { + pos = rhs.positions[position]; + this.addPosition$SIB(pos.word, pos.position, pos.stemmed); + } +}; + +/** + * @return {Array.} + */ +SearchUnit.prototype.getPositions$ = function () { + var $this = this; + /** @type {Array.} */ + var result; + /** @type {!string} */ + var pos; + result = [ ]; + for (pos in this.positions) { + result.push(this.positions[pos]); + } + result.sort((function (a, b) { + return a.position - b.position; + })); + return result; +}; + +/** + * class SingleResult extends Object + * @constructor + */ +function SingleResult() { +} + +/** + * @constructor + */ +function SingleResult$() { + this.units = [ ]; + this.unitIds = [ ]; + this.or = false; + this.not = false; + this.searchWord = ''; +}; + +SingleResult$.prototype = new SingleResult; + +/** + * @constructor + * @param {!string} searchWord + * @param {!boolean} or + * @param {!boolean} not + */ +function SingleResult$SBB(searchWord, or, not) { + this.units = [ ]; + this.unitIds = [ ]; + this.or = or; + this.not = not; + this.searchWord = searchWord; +}; + +SingleResult$SBB.prototype = new SingleResult; + +/** + * @param {!number} unitId + * @return {SearchUnit} + */ +SingleResult.prototype.getSearchUnit$I = function (unitId) { + /** @type {!number} */ + var existing; + /** @type {SearchUnit} */ + var result; + existing = this.unitIds.indexOf(unitId); + if (existing === - 1) { + result = new SearchUnit$I(unitId); + this.units.push(result); + this.unitIds.push(unitId); + } else { + result = this.units[existing]; + } + return result; +}; + +/** + * @param {SingleResult} rhs + * @return {SingleResult} + */ +SingleResult.prototype.merge$LSingleResult$ = function (rhs) { + /** @type {SingleResult} */ + var result; + result = new SingleResult$(); + if (rhs.or) { + this._orMerge$LSingleResult$LSingleResult$(result, rhs); + } else { + if (rhs.not) { + this._notMerge$LSingleResult$LSingleResult$(result, rhs); + } else { + this._andMerge$LSingleResult$LSingleResult$(result, rhs); + } + } + return result; +}; + +/** + * @return {!number} + */ +SingleResult.prototype.size$ = function () { + return (this.units.length | 0); +}; + +/** + * @param {SingleResult} result + * @param {SingleResult} rhs + */ +SingleResult.prototype._andMerge$LSingleResult$LSingleResult$ = function (result, rhs) { + /** @type {!number} */ + var i; + /** @type {undefined|!number} */ + var id; + /** @type {SearchUnit} */ + var lhsSection; + for (i = 0; i < this.unitIds.length; i++) { + id = this.unitIds[i]; + if (rhs.unitIds.indexOf(id) !== - 1) { + lhsSection = this.units[i]; + result.unitIds.push((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/search-result.jsx:168:36] null access\n result.unitIds.push(id);\n ^^\n"); + } + return v; + }(id))); + result.units.push(lhsSection); + } + } +}; + +/** + * @param {SingleResult} result + * @param {SingleResult} rhs + */ +SingleResult.prototype._orMerge$LSingleResult$LSingleResult$ = function (result, rhs) { + /** @type {!number} */ + var i; + /** @type {undefined|!number} */ + var id; + /** @type {SearchUnit} */ + var rhsSection; + /** @type {SearchUnit} */ + var lhsSection; + result.unitIds = this.unitIds.slice(0, this.unitIds.length); + result.units = this.units.slice(0, this.units.length); + for (i = 0; i < rhs.unitIds.length; i++) { + id = rhs.unitIds[i]; + rhsSection = rhs.units[i]; + if (result.unitIds.indexOf(id) !== - 1) { + lhsSection = result.units[result.unitIds.indexOf(id)]; + lhsSection.merge$LSearchUnit$(rhsSection); + } else { + result.unitIds.push((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/search-result.jsx:190:36] null access\n result.unitIds.push(id);\n ^^\n"); + } + return v; + }(id))); + result.units.push(rhsSection); + } + } +}; + +/** + * @param {SingleResult} result + * @param {SingleResult} rhs + */ +SingleResult.prototype._notMerge$LSingleResult$LSingleResult$ = function (result, rhs) { + /** @type {!number} */ + var i; + /** @type {undefined|!number} */ + var id; + /** @type {SearchUnit} */ + var lhsSection; + for (i = 0; i < this.unitIds.length; i++) { + id = this.unitIds[i]; + if (rhs.unitIds.indexOf(id) === - 1) { + lhsSection = this.units[i]; + result.unitIds.push((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/search-result.jsx:204:36] null access\n result.unitIds.push(id);\n ^^\n"); + } + return v; + }(id))); + result.units.push(lhsSection); + } + } +}; + +/** + * class SearchSummary extends Object + * @constructor + */ +function SearchSummary() { +} + +/** + * @constructor + */ +function SearchSummary$() { + this.sourceResults = [ ]; + this.result = null; + this.oktavia = null; +}; + +SearchSummary$.prototype = new SearchSummary; + +/** + * @constructor + * @param {Oktavia} oktavia + */ +function SearchSummary$LOktavia$(oktavia) { + this.sourceResults = [ ]; + this.result = null; + this.oktavia = oktavia; +}; + +SearchSummary$LOktavia$.prototype = new SearchSummary; + +/** + * @param {SingleResult} result + */ +SearchSummary.prototype.addQuery$LSingleResult$ = function (result) { + this.sourceResults.push(result); +}; + +/** + */ +SearchSummary.prototype.mergeResult$ = function () { + this.result = this.mergeResult$ALSingleResult$(this.sourceResults); +}; + +/** + * @param {Array.} results + * @return {SingleResult} + */ +SearchSummary.prototype.mergeResult$ALSingleResult$ = function (results) { + /** @type {SingleResult} */ + var rhs; + /** @type {!number} */ + var i; + rhs = results[0]; + for (i = 1; i < results.length; i++) { + rhs = rhs.merge$LSingleResult$(results[i]); + } + return rhs; +}; + +/** + * @return {Array.} + */ +SearchSummary.prototype.getProposal$ = function () { + var $this = this; + /** @type {Array.} */ + var proposals; + /** @type {!number} */ + var i; + /** @type {Array.} */ + var tmpSource; + /** @type {!number} */ + var j; + /** @type {SingleResult} */ + var result; + proposals = [ ]; + for (i = 0; i < this.sourceResults.length; i++) { + tmpSource = [ ]; + for (j = 0; j < this.sourceResults.length; j++) { + if (i !== j) { + tmpSource.push(this.sourceResults[j]); + } + } + result = this.mergeResult$ALSingleResult$(tmpSource); + proposals.push(new Proposal$II(i, result.size$())); + } + proposals.sort((function (a, b) { + return b.expect - a.expect; + })); + return proposals; +}; + +/** + * @return {Array.} + */ +SearchSummary.prototype.getSortedResult$ = function () { + var $this = this; + /** @type {Array.} */ + var result; + result = this.result.units.slice(0, this.result.units.length); + result.sort((function (a, b) { + return b.score - a.score; + })); + return result; +}; + +/** + * @return {!number} + */ +SearchSummary.prototype.size$ = function () { + return this.result.size$(); +}; + +/** + * @param {SingleResult} result + */ +SearchSummary.prototype.add$LSingleResult$ = function (result) { + this.sourceResults.push(result); +}; + +/** + * class Style extends Object + * @constructor + */ +function Style() { +} + +/** + * @constructor + * @param {!string} mode + */ +function Style$S(mode) { + this.styles = null; + this.escapeHTML = false; + switch (mode) { + case 'console': + this.styles = Style.console; + break; + case 'html': + this.styles = Style.html; + break; + case 'ignore': + this.styles = Style.ignore; + break; + default: + this.styles = Style.ignore; + break; + } + this.escapeHTML = mode === 'html'; +}; + +Style$S.prototype = new Style; + +/** + * @param {!string} source + * @return {!string} + */ +Style.prototype.convert$S = function (source) { + /** @type {_HTMLHandler} */ + var handler; + /** @type {SAXParser} */ + var parser; + handler = new _HTMLHandler$HASB(this.styles, this.escapeHTML); + parser = new SAXParser$LSAXHandler$(handler); + parser.parse$S(source); + return handler.result$(); +}; + +/** + * class Stemmer + * @constructor + */ +function Stemmer() { +} + +Stemmer.prototype.$__jsx_implements_Stemmer = true; + +/** + * @constructor + */ +function Stemmer$() { +}; + +Stemmer$.prototype = new Stemmer; + +/** + * class BaseStemmer extends Object + * @constructor + */ +function BaseStemmer() { +} + +$__jsx_merge_interface(BaseStemmer, Stemmer); + +/** + * @constructor + */ +function BaseStemmer$() { + Stemmer$.call(this); + this.current = ""; + this.cursor = 0; + this.limit = 0; + this.limit_backward = 0; + this.bra = 0; + this.ket = 0; + this.cache = ({ }); + this.setCurrent$S(""); +}; + +BaseStemmer$.prototype = new BaseStemmer; + +/** + * @param {!string} value + */ +BaseStemmer.prototype.setCurrent$S = function (value) { + this.current = value; + this.cursor = 0; + this.limit = this.current.length; + this.limit_backward = 0; + this.bra = this.cursor; + this.ket = this.limit; +}; + +/** + * @return {!string} + */ +BaseStemmer.prototype.getCurrent$ = function () { + return this.current; +}; + +/** + * @param {BaseStemmer} other + */ +BaseStemmer.prototype.copy_from$LBaseStemmer$ = function (other) { + this.current = other.current; + this.cursor = other.cursor; + this.limit = other.limit; + this.limit_backward = other.limit_backward; + this.bra = other.bra; + this.ket = other.ket; +}; + +/** + * @param {Array.} s + * @param {!number} min + * @param {!number} max + * @return {!boolean} + */ +BaseStemmer.prototype.in_grouping$AIII = function (s, min, max) { + /** @type {!number} */ + var ch; + if (this.cursor >= this.limit) { + return false; + } + ch = this.current.charCodeAt(this.cursor); + if (ch > max || ch < min) { + return false; + } + ch -= min; + if (((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/stemmer/base-stemmer.jsx:59:10] null access\n if ((s[ch >>> 3] & (0x1 << (ch & 0x7))) == 0) return false;\n ^\n"); + } + return v; + }(s[ch >>> 3])) & 0x1 << (ch & 0x7)) === 0) { + return false; + } + this.cursor++; + return true; +}; + +/** + * @param {Array.} s + * @param {!number} min + * @param {!number} max + * @return {!boolean} + */ +BaseStemmer.prototype.in_grouping_b$AIII = function (s, min, max) { + /** @type {!number} */ + var ch; + if (this.cursor <= this.limit_backward) { + return false; + } + ch = this.current.charCodeAt(this.cursor - 1); + if (ch > max || ch < min) { + return false; + } + ch -= min; + if (((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/stemmer/base-stemmer.jsx:70:10] null access\n if ((s[ch >>> 3] & (0x1 << (ch & 0x7))) == 0) return false;\n ^\n"); + } + return v; + }(s[ch >>> 3])) & 0x1 << (ch & 0x7)) === 0) { + return false; + } + this.cursor--; + return true; +}; + +/** + * @param {Array.} s + * @param {!number} min + * @param {!number} max + * @return {!boolean} + */ +BaseStemmer.prototype.out_grouping$AIII = function (s, min, max) { + /** @type {!number} */ + var ch; + if (this.cursor >= this.limit) { + return false; + } + ch = this.current.charCodeAt(this.cursor); + if (ch > max || ch < min) { + this.cursor++; + return true; + } + ch -= min; + if (((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/stemmer/base-stemmer.jsx:84:10] null access\n if ((s[ch >>> 3] & (0X1 << (ch & 0x7))) == 0) {\n ^\n"); + } + return v; + }(s[ch >>> 3])) & 0X1 << (ch & 0x7)) === 0) { + this.cursor++; + return true; + } + return false; +}; + +/** + * @param {Array.} s + * @param {!number} min + * @param {!number} max + * @return {!boolean} + */ +BaseStemmer.prototype.out_grouping_b$AIII = function (s, min, max) { + /** @type {!number} */ + var ch; + if (this.cursor <= this.limit_backward) { + return false; + } + ch = this.current.charCodeAt(this.cursor - 1); + if (ch > max || ch < min) { + this.cursor--; + return true; + } + ch -= min; + if (((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/stemmer/base-stemmer.jsx:100:10] null access\n if ((s[ch >>> 3] & (0x1 << (ch & 0x7))) == 0) {\n ^\n"); + } + return v; + }(s[ch >>> 3])) & 0x1 << (ch & 0x7)) === 0) { + this.cursor--; + return true; + } + return false; +}; + +/** + * @param {!number} min + * @param {!number} max + * @return {!boolean} + */ +BaseStemmer.prototype.in_range$II = function (min, max) { + /** @type {!number} */ + var ch; + if (this.cursor >= this.limit) { + return false; + } + ch = this.current.charCodeAt(this.cursor); + if (ch > max || ch < min) { + return false; + } + this.cursor++; + return true; +}; + +/** + * @param {!number} min + * @param {!number} max + * @return {!boolean} + */ +BaseStemmer.prototype.in_range_b$II = function (min, max) { + /** @type {!number} */ + var ch; + if (this.cursor <= this.limit_backward) { + return false; + } + ch = this.current.charCodeAt(this.cursor - 1); + if (ch > max || ch < min) { + return false; + } + this.cursor--; + return true; +}; + +/** + * @param {!number} min + * @param {!number} max + * @return {!boolean} + */ +BaseStemmer.prototype.out_range$II = function (min, max) { + /** @type {!number} */ + var ch; + if (this.cursor >= this.limit) { + return false; + } + ch = this.current.charCodeAt(this.cursor); + if (! (ch > max || ch < min)) { + return false; + } + this.cursor++; + return true; +}; + +/** + * @param {!number} min + * @param {!number} max + * @return {!boolean} + */ +BaseStemmer.prototype.out_range_b$II = function (min, max) { + /** @type {!number} */ + var ch; + if (this.cursor <= this.limit_backward) { + return false; + } + ch = this.current.charCodeAt(this.cursor - 1); + if (! (ch > max || ch < min)) { + return false; + } + this.cursor--; + return true; +}; + +/** + * @param {!number} s_size + * @param {!string} s + * @return {!boolean} + */ +BaseStemmer.prototype.eq_s$IS = function (s_size, s) { + if (this.limit - this.cursor < s_size) { + return false; + } + if (this.current.slice(this.cursor, this.cursor + s_size) !== s) { + return false; + } + this.cursor += s_size; + return true; +}; + +/** + * @param {!number} s_size + * @param {!string} s + * @return {!boolean} + */ +BaseStemmer.prototype.eq_s_b$IS = function (s_size, s) { + if (this.cursor - this.limit_backward < s_size) { + return false; + } + if (this.current.slice(this.cursor - s_size, this.cursor) !== s) { + return false; + } + this.cursor -= s_size; + return true; +}; + +/** + * @param {!string} s + * @return {!boolean} + */ +BaseStemmer.prototype.eq_v$S = function (s) { + return this.eq_s$IS(s.length, s); +}; + +/** + * @param {!string} s + * @return {!boolean} + */ +BaseStemmer.prototype.eq_v_b$S = function (s) { + return this.eq_s_b$IS(s.length, s); +}; + +/** + * @param {Array.} v + * @param {!number} v_size + * @return {!number} + */ +BaseStemmer.prototype.find_among$ALAmong$I = function (v, v_size) { + /** @type {!number} */ + var i; + /** @type {!number} */ + var j; + /** @type {!number} */ + var c; + /** @type {!number} */ + var l; + /** @type {!number} */ + var common_i; + /** @type {!number} */ + var common_j; + /** @type {!boolean} */ + var first_key_inspected; + /** @type {!number} */ + var k; + /** @type {!number} */ + var diff; + /** @type {!number} */ + var common; + /** @type {Among} */ + var w; + /** @type {!number} */ + var i2; + /** @type {!boolean} */ + var res; + i = 0; + j = v_size; + c = this.cursor; + l = this.limit; + common_i = 0; + common_j = 0; + first_key_inspected = false; + while (true) { + k = i + (j - i >>> 1); + diff = 0; + common = (common_i < common_j ? common_i : common_j); + w = v[k]; + for (i2 = common; i2 < w.s_size; i2++) { + if (c + common === l) { + diff = - 1; + break; + } + diff = this.current.charCodeAt(c + common) - w.s.charCodeAt(i2); + if (diff !== 0) { + break; + } + common++; + } + if (diff < 0) { + j = k; + common_j = common; + } else { + i = k; + common_i = common; + } + if (j - i <= 1) { + if (i > 0) { + break; + } + if (j === i) { + break; + } + if (first_key_inspected) { + break; + } + first_key_inspected = true; + } + } + while (true) { + w = v[i]; + if (common_i >= w.s_size) { + this.cursor = (c + w.s_size | 0); + if (w.method == null) { + return w.result; + } + res = w.method(w.instance); + this.cursor = (c + w.s_size | 0); + if (res) { + return w.result; + } + } + i = w.substring_i; + if (i < 0) { + return 0; + } + } + return (- 1 | 0); +}; + +/** + * @param {Array.} v + * @param {!number} v_size + * @return {!number} + */ +BaseStemmer.prototype.find_among_b$ALAmong$I = function (v, v_size) { + /** @type {!number} */ + var i; + /** @type {!number} */ + var j; + /** @type {!number} */ + var c; + /** @type {!number} */ + var lb; + /** @type {!number} */ + var common_i; + /** @type {!number} */ + var common_j; + /** @type {!boolean} */ + var first_key_inspected; + /** @type {!number} */ + var k; + /** @type {!number} */ + var diff; + /** @type {!number} */ + var common; + /** @type {Among} */ + var w; + /** @type {!number} */ + var i2; + /** @type {!boolean} */ + var res; + i = 0; + j = v_size; + c = this.cursor; + lb = this.limit_backward; + common_i = 0; + common_j = 0; + first_key_inspected = false; + while (true) { + k = i + (j - i >> 1); + diff = 0; + common = (common_i < common_j ? common_i : common_j); + w = v[k]; + for (i2 = w.s_size - 1 - common; i2 >= 0; i2--) { + if (c - common === lb) { + diff = - 1; + break; + } + diff = this.current.charCodeAt(c - 1 - common) - w.s.charCodeAt(i2); + if (diff !== 0) { + break; + } + common++; + } + if (diff < 0) { + j = k; + common_j = common; + } else { + i = k; + common_i = common; + } + if (j - i <= 1) { + if (i > 0) { + break; + } + if (j === i) { + break; + } + if (first_key_inspected) { + break; + } + first_key_inspected = true; + } + } + while (true) { + w = v[i]; + if (common_i >= w.s_size) { + this.cursor = (c - w.s_size | 0); + if (w.method == null) { + return w.result; + } + res = w.method(this); + this.cursor = (c - w.s_size | 0); + if (res) { + return w.result; + } + } + i = w.substring_i; + if (i < 0) { + return 0; + } + } + return (- 1 | 0); +}; + +/** + * @param {!number} c_bra + * @param {!number} c_ket + * @param {!string} s + * @return {!number} + */ +BaseStemmer.prototype.replace_s$IIS = function (c_bra, c_ket, s) { + /** @type {!number} */ + var adjustment; + adjustment = s.length - (c_ket - c_bra); + this.current = this.current.slice(0, c_bra) + s + this.current.slice(c_ket); + this.limit += (adjustment | 0); + if (this.cursor >= c_ket) { + this.cursor += (adjustment | 0); + } else { + if (this.cursor > c_bra) { + this.cursor = c_bra; + } + } + return (adjustment | 0); +}; + +/** + * @return {!boolean} + */ +BaseStemmer.prototype.slice_check$ = function () { + if (this.bra < 0 || this.bra > this.ket || this.ket > this.limit || this.limit > this.current.length) { + return false; + } + return true; +}; + +/** + * @param {!string} s + * @return {!boolean} + */ +BaseStemmer.prototype.slice_from$S = function (s) { + /** @type {!boolean} */ + var result; + result = false; + if (this.slice_check$()) { + this.replace_s$IIS(this.bra, this.ket, s); + result = true; + } + return result; +}; + +/** + * @return {!boolean} + */ +BaseStemmer.prototype.slice_del$ = function () { + return this.slice_from$S(""); +}; + +/** + * @param {!number} c_bra + * @param {!number} c_ket + * @param {!string} s + */ +BaseStemmer.prototype.insert$IIS = function (c_bra, c_ket, s) { + /** @type {!number} */ + var adjustment; + adjustment = this.replace_s$IIS(c_bra, c_ket, s); + if (c_bra <= this.bra) { + this.bra += (adjustment | 0); + } + if (c_bra <= this.ket) { + this.ket += (adjustment | 0); + } +}; + +/** + * @param {!string} s + * @return {!string} + */ +BaseStemmer.prototype.slice_to$S = function (s) { + /** @type {!string} */ + var result; + result = ''; + if (this.slice_check$()) { + result = this.current.slice(this.bra, this.ket); + } + return result; +}; + +/** + * @param {!string} s + * @return {!string} + */ +BaseStemmer.prototype.assign_to$S = function (s) { + return this.current.slice(0, this.limit); +}; + +/** + * @return {!boolean} + */ +BaseStemmer.prototype.stem$ = function () { + return false; +}; + +/** + * @param {!string} word + * @return {!string} + */ +BaseStemmer.prototype.stemWord$S = function (word) { + /** @type {undefined|!string} */ + var result; + result = this.cache['.' + word]; + if (result == null) { + this.setCurrent$S(word); + this.stem$(); + result = this.getCurrent$(); + this.cache['.' + word] = result; + } + return (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/stemmer/base-stemmer.jsx:398:15] null access\n return result;\n ^^^^^^\n"); + } + return v; + }(result)); +}; + +/** + * @param {Array.} words + * @return {Array.} + */ +BaseStemmer.prototype.stemWords$AS = function (words) { + /** @type {Array.} */ + var results; + /** @type {!number} */ + var i; + /** @type {undefined|!string} */ + var word; + /** @type {undefined|!string} */ + var result; + results = [ ]; + for (i = 0; i < words.length; i++) { + word = words[i]; + result = this.cache['.' + (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/stemmer/base-stemmer.jsx:407:42] null access\n var result = this.cache[\'.\' + word];\n ^^^^\n"); + } + return v; + }(word))]; + if (result == null) { + this.setCurrent$S((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/stemmer/base-stemmer.jsx:410:32] null access\n this.setCurrent(word);\n ^^^^\n"); + } + return v; + }(word))); + this.stem$(); + result = this.getCurrent$(); + this.cache['.' + (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/stemmer/base-stemmer.jsx:413:33] null access\n this.cache[\'.\' + word] = result;\n ^^^^\n"); + } + return v; + }(word))] = result; + } + results.push((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/stemmer/base-stemmer.jsx:415:25] null access\n results.push(result);\n ^^^^^^\n"); + } + return v; + }(result))); + } + return results; +}; + +/** + * class EnglishStemmer extends BaseStemmer + * @constructor + */ +function EnglishStemmer() { +} + +EnglishStemmer.prototype = new BaseStemmer; +/** + * @constructor + */ +function EnglishStemmer$() { + BaseStemmer$.call(this); + this.B_Y_found = false; + this.I_p2 = 0; + this.I_p1 = 0; +}; + +EnglishStemmer$.prototype = new EnglishStemmer; + +/** + * @param {EnglishStemmer} other + */ +EnglishStemmer.prototype.copy_from$LEnglishStemmer$ = function (other) { + this.B_Y_found = other.B_Y_found; + this.I_p2 = other.I_p2; + this.I_p1 = other.I_p1; + BaseStemmer.prototype.copy_from$LBaseStemmer$.call(this, other); +}; + +/** + * @return {!boolean} + */ +EnglishStemmer.prototype.r_prelude$ = function () { + /** @type {!number} */ + var v_1; + /** @type {!number} */ + var v_2; + /** @type {!number} */ + var v_3; + /** @type {!number} */ + var v_4; + /** @type {!number} */ + var v_5; + /** @type {!boolean} */ + var lab0; + /** @type {!boolean} */ + var lab1; + /** @type {!boolean} */ + var lab2; + /** @type {!boolean} */ + var lab4; + /** @type {!boolean} */ + var lab6; + this.B_Y_found = false; + v_1 = this.cursor; + lab0 = true; +lab0: + while (lab0 === true) { + lab0 = false; + this.bra = this.cursor; + if (! this.eq_s$IS(1, "'")) { + break lab0; + } + this.ket = this.cursor; + if (! this.slice_del$()) { + return false; + } + } + this.cursor = v_1; + v_2 = this.cursor; + lab1 = true; +lab1: + while (lab1 === true) { + lab1 = false; + this.bra = this.cursor; + if (! this.eq_s$IS(1, "y")) { + break lab1; + } + this.ket = this.cursor; + if (! this.slice_from$S("Y")) { + return false; + } + this.B_Y_found = true; + } + this.cursor = v_2; + v_3 = this.cursor; + lab2 = true; +lab2: + while (lab2 === true) { + lab2 = false; + replab3: + while (true) { + v_4 = this.cursor; + lab4 = true; + lab4: + while (lab4 === true) { + lab4 = false; + golab5: + while (true) { + v_5 = this.cursor; + lab6 = true; + lab6: + while (lab6 === true) { + lab6 = false; + if (! this.in_grouping$AIII(EnglishStemmer.g_v, 97, 121)) { + break lab6; + } + this.bra = this.cursor; + if (! this.eq_s$IS(1, "y")) { + break lab6; + } + this.ket = this.cursor; + this.cursor = v_5; + break golab5; + } + this.cursor = v_5; + if (this.cursor >= this.limit) { + break lab4; + } + this.cursor++; + } + if (! this.slice_from$S("Y")) { + return false; + } + this.B_Y_found = true; + continue replab3; + } + this.cursor = v_4; + break replab3; + } + } + this.cursor = v_3; + return true; +}; + +/** + * @return {!boolean} + */ +EnglishStemmer.prototype.r_mark_regions$ = function () { + /** @type {!number} */ + var v_1; + /** @type {!number} */ + var v_2; + /** @type {!boolean} */ + var lab0; + /** @type {!boolean} */ + var lab1; + /** @type {!boolean} */ + var lab2; + /** @type {!boolean} */ + var lab4; + /** @type {!boolean} */ + var lab6; + /** @type {!boolean} */ + var lab8; + /** @type {!boolean} */ + var lab10; + this.I_p1 = this.limit; + this.I_p2 = this.limit; + v_1 = this.cursor; + lab0 = true; +lab0: + while (lab0 === true) { + lab0 = false; + lab1 = true; + lab1: + while (lab1 === true) { + lab1 = false; + v_2 = this.cursor; + lab2 = true; + lab2: + while (lab2 === true) { + lab2 = false; + if (this.find_among$ALAmong$I(EnglishStemmer.a_0, 3) === 0) { + break lab2; + } + break lab1; + } + this.cursor = v_2; + golab3: + while (true) { + lab4 = true; + lab4: + while (lab4 === true) { + lab4 = false; + if (! this.in_grouping$AIII(EnglishStemmer.g_v, 97, 121)) { + break lab4; + } + break golab3; + } + if (this.cursor >= this.limit) { + break lab0; + } + this.cursor++; + } + golab5: + while (true) { + lab6 = true; + lab6: + while (lab6 === true) { + lab6 = false; + if (! this.out_grouping$AIII(EnglishStemmer.g_v, 97, 121)) { + break lab6; + } + break golab5; + } + if (this.cursor >= this.limit) { + break lab0; + } + this.cursor++; + } + } + this.I_p1 = this.cursor; + golab7: + while (true) { + lab8 = true; + lab8: + while (lab8 === true) { + lab8 = false; + if (! this.in_grouping$AIII(EnglishStemmer.g_v, 97, 121)) { + break lab8; + } + break golab7; + } + if (this.cursor >= this.limit) { + break lab0; + } + this.cursor++; + } + golab9: + while (true) { + lab10 = true; + lab10: + while (lab10 === true) { + lab10 = false; + if (! this.out_grouping$AIII(EnglishStemmer.g_v, 97, 121)) { + break lab10; + } + break golab9; + } + if (this.cursor >= this.limit) { + break lab0; + } + this.cursor++; + } + this.I_p2 = this.cursor; + } + this.cursor = v_1; + return true; +}; + +/** + * @return {!boolean} + */ +EnglishStemmer.prototype.r_shortv$ = function () { + /** @type {!number} */ + var v_1; + /** @type {!boolean} */ + var lab0; + /** @type {!boolean} */ + var lab1; + lab0 = true; +lab0: + while (lab0 === true) { + lab0 = false; + v_1 = this.limit - this.cursor; + lab1 = true; + lab1: + while (lab1 === true) { + lab1 = false; + if (! this.out_grouping_b$AIII(EnglishStemmer.g_v_WXY, 89, 121)) { + break lab1; + } + if (! this.in_grouping_b$AIII(EnglishStemmer.g_v, 97, 121)) { + break lab1; + } + if (! this.out_grouping_b$AIII(EnglishStemmer.g_v, 97, 121)) { + break lab1; + } + break lab0; + } + this.cursor = this.limit - v_1; + if (! this.out_grouping_b$AIII(EnglishStemmer.g_v, 97, 121)) { + return false; + } + if (! this.in_grouping_b$AIII(EnglishStemmer.g_v, 97, 121)) { + return false; + } + if (this.cursor > this.limit_backward) { + return false; + } + } + return true; +}; + +/** + * @return {!boolean} + */ +EnglishStemmer.prototype.r_R1$ = function () { + if (! (this.I_p1 <= this.cursor)) { + return false; + } + return true; +}; + +/** + * @return {!boolean} + */ +EnglishStemmer.prototype.r_R2$ = function () { + if (! (this.I_p2 <= this.cursor)) { + return false; + } + return true; +}; + +/** + * @return {!boolean} + */ +EnglishStemmer.prototype.r_Step_1a$ = function () { + /** @type {!number} */ + var among_var; + /** @type {!number} */ + var v_1; + /** @type {!number} */ + var v_2; + /** @type {!boolean} */ + var lab0; + /** @type {!boolean} */ + var lab1; + /** @type {!boolean} */ + var lab2; + /** @type {!number} */ + var c; + /** @type {!boolean} */ + var lab4; + v_1 = this.limit - this.cursor; + lab0 = true; +lab0: + while (lab0 === true) { + lab0 = false; + this.ket = this.cursor; + among_var = this.find_among_b$ALAmong$I(EnglishStemmer.a_1, 3); + if (among_var === 0) { + this.cursor = this.limit - v_1; + break lab0; + } + this.bra = this.cursor; + switch (among_var) { + case 0: + this.cursor = this.limit - v_1; + break lab0; + case 1: + if (! this.slice_del$()) { + return false; + } + break; + } + } + this.ket = this.cursor; + among_var = this.find_among_b$ALAmong$I(EnglishStemmer.a_2, 6); + if (among_var === 0) { + return false; + } + this.bra = this.cursor; + switch (among_var) { + case 0: + return false; + case 1: + if (! this.slice_from$S("ss")) { + return false; + } + break; + case 2: + lab1 = true; + lab1: + while (lab1 === true) { + lab1 = false; + v_2 = this.limit - this.cursor; + lab2 = true; + lab2: + while (lab2 === true) { + lab2 = false; + c = (this.cursor - 2 | 0); + if (this.limit_backward > c || c > this.limit) { + break lab2; + } + this.cursor = c; + if (! this.slice_from$S("i")) { + return false; + } + break lab1; + } + this.cursor = this.limit - v_2; + if (! this.slice_from$S("ie")) { + return false; + } + } + break; + case 3: + if (this.cursor <= this.limit_backward) { + return false; + } + this.cursor--; + golab3: + while (true) { + lab4 = true; + lab4: + while (lab4 === true) { + lab4 = false; + if (! this.in_grouping_b$AIII(EnglishStemmer.g_v, 97, 121)) { + break lab4; + } + break golab3; + } + if (this.cursor <= this.limit_backward) { + return false; + } + this.cursor--; + } + if (! this.slice_del$()) { + return false; + } + break; + } + return true; +}; + +/** + * @return {!boolean} + */ +EnglishStemmer.prototype.r_Step_1b$ = function () { + /** @type {!number} */ + var among_var; + /** @type {!number} */ + var v_1; + /** @type {!number} */ + var v_3; + /** @type {!number} */ + var v_4; + /** @type {!boolean} */ + var lab1; + /** @type {!number} */ + var c; + this.ket = this.cursor; + among_var = this.find_among_b$ALAmong$I(EnglishStemmer.a_4, 6); + if (among_var === 0) { + return false; + } + this.bra = this.cursor; + switch (among_var) { + case 0: + return false; + case 1: + if (! this.r_R1$()) { + return false; + } + if (! this.slice_from$S("ee")) { + return false; + } + break; + case 2: + v_1 = this.limit - this.cursor; + golab0: + while (true) { + lab1 = true; + lab1: + while (lab1 === true) { + lab1 = false; + if (! this.in_grouping_b$AIII(EnglishStemmer.g_v, 97, 121)) { + break lab1; + } + break golab0; + } + if (this.cursor <= this.limit_backward) { + return false; + } + this.cursor--; + } + this.cursor = this.limit - v_1; + if (! this.slice_del$()) { + return false; + } + v_3 = this.limit - this.cursor; + among_var = this.find_among_b$ALAmong$I(EnglishStemmer.a_3, 13); + if (among_var === 0) { + return false; + } + this.cursor = this.limit - v_3; + switch (among_var) { + case 0: + return false; + case 1: + c = this.cursor; + this.insert$IIS(this.cursor, this.cursor, "e"); + this.cursor = c; + break; + case 2: + this.ket = this.cursor; + if (this.cursor <= this.limit_backward) { + return false; + } + this.cursor--; + this.bra = this.cursor; + if (! this.slice_del$()) { + return false; + } + break; + case 3: + if (this.cursor !== this.I_p1) { + return false; + } + v_4 = this.limit - this.cursor; + if (! this.r_shortv$()) { + return false; + } + this.cursor = this.limit - v_4; + c = this.cursor; + this.insert$IIS(this.cursor, this.cursor, "e"); + this.cursor = c; + break; + } + break; + } + return true; +}; + +/** + * @return {!boolean} + */ +EnglishStemmer.prototype.r_Step_1c$ = function () { + /** @type {!number} */ + var v_1; + /** @type {!number} */ + var v_2; + /** @type {!boolean} */ + var lab0; + /** @type {!boolean} */ + var lab1; + /** @type {!boolean} */ + var lab2; + this.ket = this.cursor; + lab0 = true; +lab0: + while (lab0 === true) { + lab0 = false; + v_1 = this.limit - this.cursor; + lab1 = true; + lab1: + while (lab1 === true) { + lab1 = false; + if (! this.eq_s_b$IS(1, "y")) { + break lab1; + } + break lab0; + } + this.cursor = this.limit - v_1; + if (! this.eq_s_b$IS(1, "Y")) { + return false; + } + } + this.bra = this.cursor; + if (! this.out_grouping_b$AIII(EnglishStemmer.g_v, 97, 121)) { + return false; + } + v_2 = this.limit - this.cursor; + lab2 = true; +lab2: + while (lab2 === true) { + lab2 = false; + if (this.cursor > this.limit_backward) { + break lab2; + } + return false; + } + this.cursor = this.limit - v_2; + if (! this.slice_from$S("i")) { + return false; + } + return true; +}; + +/** + * @return {!boolean} + */ +EnglishStemmer.prototype.r_Step_2$ = function () { + /** @type {!number} */ + var among_var; + this.ket = this.cursor; + among_var = this.find_among_b$ALAmong$I(EnglishStemmer.a_5, 24); + if (among_var === 0) { + return false; + } + this.bra = this.cursor; + if (! this.r_R1$()) { + return false; + } + switch (among_var) { + case 0: + return false; + case 1: + if (! this.slice_from$S("tion")) { + return false; + } + break; + case 2: + if (! this.slice_from$S("ence")) { + return false; + } + break; + case 3: + if (! this.slice_from$S("ance")) { + return false; + } + break; + case 4: + if (! this.slice_from$S("able")) { + return false; + } + break; + case 5: + if (! this.slice_from$S("ent")) { + return false; + } + break; + case 6: + if (! this.slice_from$S("ize")) { + return false; + } + break; + case 7: + if (! this.slice_from$S("ate")) { + return false; + } + break; + case 8: + if (! this.slice_from$S("al")) { + return false; + } + break; + case 9: + if (! this.slice_from$S("ful")) { + return false; + } + break; + case 10: + if (! this.slice_from$S("ous")) { + return false; + } + break; + case 11: + if (! this.slice_from$S("ive")) { + return false; + } + break; + case 12: + if (! this.slice_from$S("ble")) { + return false; + } + break; + case 13: + if (! this.eq_s_b$IS(1, "l")) { + return false; + } + if (! this.slice_from$S("og")) { + return false; + } + break; + case 14: + if (! this.slice_from$S("ful")) { + return false; + } + break; + case 15: + if (! this.slice_from$S("less")) { + return false; + } + break; + case 16: + if (! this.in_grouping_b$AIII(EnglishStemmer.g_valid_LI, 99, 116)) { + return false; + } + if (! this.slice_del$()) { + return false; + } + break; + } + return true; +}; + +/** + * @return {!boolean} + */ +EnglishStemmer.prototype.r_Step_3$ = function () { + /** @type {!number} */ + var among_var; + this.ket = this.cursor; + among_var = this.find_among_b$ALAmong$I(EnglishStemmer.a_6, 9); + if (among_var === 0) { + return false; + } + this.bra = this.cursor; + if (! this.r_R1$()) { + return false; + } + switch (among_var) { + case 0: + return false; + case 1: + if (! this.slice_from$S("tion")) { + return false; + } + break; + case 2: + if (! this.slice_from$S("ate")) { + return false; + } + break; + case 3: + if (! this.slice_from$S("al")) { + return false; + } + break; + case 4: + if (! this.slice_from$S("ic")) { + return false; + } + break; + case 5: + if (! this.slice_del$()) { + return false; + } + break; + case 6: + if (! this.r_R2$()) { + return false; + } + if (! this.slice_del$()) { + return false; + } + break; + } + return true; +}; + +/** + * @return {!boolean} + */ +EnglishStemmer.prototype.r_Step_4$ = function () { + /** @type {!number} */ + var among_var; + /** @type {!number} */ + var v_1; + /** @type {!boolean} */ + var lab0; + /** @type {!boolean} */ + var lab1; + this.ket = this.cursor; + among_var = this.find_among_b$ALAmong$I(EnglishStemmer.a_7, 18); + if (among_var === 0) { + return false; + } + this.bra = this.cursor; + if (! this.r_R2$()) { + return false; + } + switch (among_var) { + case 0: + return false; + case 1: + if (! this.slice_del$()) { + return false; + } + break; + case 2: + lab0 = true; + lab0: + while (lab0 === true) { + lab0 = false; + v_1 = this.limit - this.cursor; + lab1 = true; + lab1: + while (lab1 === true) { + lab1 = false; + if (! this.eq_s_b$IS(1, "s")) { + break lab1; + } + break lab0; + } + this.cursor = this.limit - v_1; + if (! this.eq_s_b$IS(1, "t")) { + return false; + } + } + if (! this.slice_del$()) { + return false; + } + break; + } + return true; +}; + +/** + * @return {!boolean} + */ +EnglishStemmer.prototype.r_Step_5$ = function () { + /** @type {!number} */ + var among_var; + /** @type {!number} */ + var v_1; + /** @type {!number} */ + var v_2; + /** @type {!boolean} */ + var lab0; + /** @type {!boolean} */ + var lab1; + /** @type {!boolean} */ + var lab2; + this.ket = this.cursor; + among_var = this.find_among_b$ALAmong$I(EnglishStemmer.a_8, 2); + if (among_var === 0) { + return false; + } + this.bra = this.cursor; + switch (among_var) { + case 0: + return false; + case 1: + lab0 = true; + lab0: + while (lab0 === true) { + lab0 = false; + v_1 = this.limit - this.cursor; + lab1 = true; + lab1: + while (lab1 === true) { + lab1 = false; + if (! this.r_R2$()) { + break lab1; + } + break lab0; + } + this.cursor = this.limit - v_1; + if (! this.r_R1$()) { + return false; + } + v_2 = this.limit - this.cursor; + lab2 = true; + lab2: + while (lab2 === true) { + lab2 = false; + if (! this.r_shortv$()) { + break lab2; + } + return false; + } + this.cursor = this.limit - v_2; + } + if (! this.slice_del$()) { + return false; + } + break; + case 2: + if (! this.r_R2$()) { + return false; + } + if (! this.eq_s_b$IS(1, "l")) { + return false; + } + if (! this.slice_del$()) { + return false; + } + break; + } + return true; +}; + +/** + * @return {!boolean} + */ +EnglishStemmer.prototype.r_exception2$ = function () { + this.ket = this.cursor; + if (this.find_among_b$ALAmong$I(EnglishStemmer.a_9, 8) === 0) { + return false; + } + this.bra = this.cursor; + if (this.cursor > this.limit_backward) { + return false; + } + return true; +}; + +/** + * @return {!boolean} + */ +EnglishStemmer.prototype.r_exception1$ = function () { + /** @type {!number} */ + var among_var; + this.bra = this.cursor; + among_var = this.find_among$ALAmong$I(EnglishStemmer.a_10, 18); + if (among_var === 0) { + return false; + } + this.ket = this.cursor; + if (this.cursor < this.limit) { + return false; + } + switch (among_var) { + case 0: + return false; + case 1: + if (! this.slice_from$S("ski")) { + return false; + } + break; + case 2: + if (! this.slice_from$S("sky")) { + return false; + } + break; + case 3: + if (! this.slice_from$S("die")) { + return false; + } + break; + case 4: + if (! this.slice_from$S("lie")) { + return false; + } + break; + case 5: + if (! this.slice_from$S("tie")) { + return false; + } + break; + case 6: + if (! this.slice_from$S("idl")) { + return false; + } + break; + case 7: + if (! this.slice_from$S("gentl")) { + return false; + } + break; + case 8: + if (! this.slice_from$S("ugli")) { + return false; + } + break; + case 9: + if (! this.slice_from$S("earli")) { + return false; + } + break; + case 10: + if (! this.slice_from$S("onli")) { + return false; + } + break; + case 11: + if (! this.slice_from$S("singl")) { + return false; + } + break; + } + return true; +}; + +/** + * @return {!boolean} + */ +EnglishStemmer.prototype.r_postlude$ = function () { + /** @type {!number} */ + var v_1; + /** @type {!number} */ + var v_2; + /** @type {!boolean} */ + var lab1; + /** @type {!boolean} */ + var lab3; + if (! this.B_Y_found) { + return false; + } +replab0: + while (true) { + v_1 = this.cursor; + lab1 = true; + lab1: + while (lab1 === true) { + lab1 = false; + golab2: + while (true) { + v_2 = this.cursor; + lab3 = true; + lab3: + while (lab3 === true) { + lab3 = false; + this.bra = this.cursor; + if (! this.eq_s$IS(1, "Y")) { + break lab3; + } + this.ket = this.cursor; + this.cursor = v_2; + break golab2; + } + this.cursor = v_2; + if (this.cursor >= this.limit) { + break lab1; + } + this.cursor++; + } + if (! this.slice_from$S("y")) { + return false; + } + continue replab0; + } + this.cursor = v_1; + break replab0; + } + return true; +}; + +/** + * @return {!boolean} + */ +EnglishStemmer.prototype.stem$ = function () { + /** @type {!number} */ + var v_1; + /** @type {!number} */ + var v_2; + /** @type {!number} */ + var v_3; + /** @type {!number} */ + var v_4; + /** @type {!number} */ + var v_5; + /** @type {!number} */ + var v_6; + /** @type {!number} */ + var v_7; + /** @type {!number} */ + var v_8; + /** @type {!number} */ + var v_9; + /** @type {!number} */ + var v_10; + /** @type {!number} */ + var v_11; + /** @type {!number} */ + var v_12; + /** @type {!number} */ + var v_13; + /** @type {!boolean} */ + var lab0; + /** @type {!boolean} */ + var lab1; + /** @type {!boolean} */ + var lab2; + /** @type {!boolean} */ + var lab3; + /** @type {!number} */ + var c; + /** @type {!boolean} */ + var lab4; + /** @type {!boolean} */ + var lab5; + /** @type {!boolean} */ + var lab6; + /** @type {!boolean} */ + var lab7; + /** @type {!boolean} */ + var lab8; + /** @type {!boolean} */ + var lab9; + /** @type {!boolean} */ + var lab10; + /** @type {!boolean} */ + var lab11; + /** @type {!boolean} */ + var lab12; + /** @type {!boolean} */ + var lab13; + /** @type {!boolean} */ + var lab14; + /** @type {!boolean} */ + var lab15; + lab0 = true; +lab0: + while (lab0 === true) { + lab0 = false; + v_1 = this.cursor; + lab1 = true; + lab1: + while (lab1 === true) { + lab1 = false; + if (! this.r_exception1$()) { + break lab1; + } + break lab0; + } + this.cursor = v_1; + lab2 = true; + lab2: + while (lab2 === true) { + lab2 = false; + v_2 = this.cursor; + lab3 = true; + lab3: + while (lab3 === true) { + lab3 = false; + c = (this.cursor + 3 | 0); + if (0 > c || c > this.limit) { + break lab3; + } + this.cursor = c; + break lab2; + } + this.cursor = v_2; + break lab0; + } + this.cursor = v_1; + v_3 = this.cursor; + lab4 = true; + lab4: + while (lab4 === true) { + lab4 = false; + if (! this.r_prelude$()) { + break lab4; + } + } + this.cursor = v_3; + v_4 = this.cursor; + lab5 = true; + lab5: + while (lab5 === true) { + lab5 = false; + if (! this.r_mark_regions$()) { + break lab5; + } + } + this.cursor = v_4; + this.limit_backward = this.cursor; + this.cursor = this.limit; + v_5 = this.limit - this.cursor; + lab6 = true; + lab6: + while (lab6 === true) { + lab6 = false; + if (! this.r_Step_1a$()) { + break lab6; + } + } + this.cursor = this.limit - v_5; + lab7 = true; + lab7: + while (lab7 === true) { + lab7 = false; + v_6 = this.limit - this.cursor; + lab8 = true; + lab8: + while (lab8 === true) { + lab8 = false; + if (! this.r_exception2$()) { + break lab8; + } + break lab7; + } + this.cursor = this.limit - v_6; + v_7 = this.limit - this.cursor; + lab9 = true; + lab9: + while (lab9 === true) { + lab9 = false; + if (! this.r_Step_1b$()) { + break lab9; + } + } + this.cursor = this.limit - v_7; + v_8 = this.limit - this.cursor; + lab10 = true; + lab10: + while (lab10 === true) { + lab10 = false; + if (! this.r_Step_1c$()) { + break lab10; + } + } + this.cursor = this.limit - v_8; + v_9 = this.limit - this.cursor; + lab11 = true; + lab11: + while (lab11 === true) { + lab11 = false; + if (! this.r_Step_2$()) { + break lab11; + } + } + this.cursor = this.limit - v_9; + v_10 = this.limit - this.cursor; + lab12 = true; + lab12: + while (lab12 === true) { + lab12 = false; + if (! this.r_Step_3$()) { + break lab12; + } + } + this.cursor = this.limit - v_10; + v_11 = this.limit - this.cursor; + lab13 = true; + lab13: + while (lab13 === true) { + lab13 = false; + if (! this.r_Step_4$()) { + break lab13; + } + } + this.cursor = this.limit - v_11; + v_12 = this.limit - this.cursor; + lab14 = true; + lab14: + while (lab14 === true) { + lab14 = false; + if (! this.r_Step_5$()) { + break lab14; + } + } + this.cursor = this.limit - v_12; + } + this.cursor = this.limit_backward; + v_13 = this.cursor; + lab15 = true; + lab15: + while (lab15 === true) { + lab15 = false; + if (! this.r_postlude$()) { + break lab15; + } + } + this.cursor = v_13; + } + return true; +}; + +/** + * @param {*} o + * @return {!boolean} + */ +EnglishStemmer.prototype.equals$X = function (o) { + return o instanceof EnglishStemmer; +}; + +/** + * @return {!number} + */ +EnglishStemmer.prototype.hashCode$ = function () { + /** @type {!string} */ + var classname; + /** @type {!number} */ + var hash; + /** @type {!number} */ + var i; + /** @type {!number} */ + var char; + classname = "EnglishStemmer"; + hash = 0; + if (classname.length === 0) { + return (hash | 0); + } + for (i = 0; i < classname.length; i++) { + char = classname.charCodeAt(i); + hash = (hash << 5) - hash + char; + hash = hash & hash; + } + return (hash | 0); +}; + +/** + * class Among extends Object + * @constructor + */ +function Among() { +} + +/** + * @constructor + * @param {!string} s + * @param {!number} substring_i + * @param {!number} result + */ +function Among$SII(s, substring_i, result) { + this.s_size = s.length; + this.s = s; + this.substring_i = substring_i; + this.result = result; + this.method = null; + this.instance = null; +}; + +Among$SII.prototype = new Among; + +/** + * @constructor + * @param {!string} s + * @param {!number} substring_i + * @param {!number} result + * @param {*} method + * @param {BaseStemmer} instance + */ +function Among$SIIF$LBaseStemmer$B$LBaseStemmer$(s, substring_i, result, method, instance) { + this.s_size = s.length; + this.s = s; + this.substring_i = substring_i; + this.result = result; + this.method = method; + this.instance = instance; +}; + +Among$SIIF$LBaseStemmer$B$LBaseStemmer$.prototype = new Among; + +/** + * class Metadata extends Object + * @constructor + */ +function Metadata() { +} + +/** + * @constructor + * @param {Oktavia} parent + */ +function Metadata$LOktavia$(parent) { + this._parent = parent; + this._bitVector = new BitVector$(); +}; + +Metadata$LOktavia$.prototype = new Metadata; + +/** + * @return {!number} + */ +Metadata.prototype._size$ = function () { + return this._bitVector.rank$I(this._bitVector.size$()); +}; + +/** + * @param {!number} index + * @return {!string} + */ +Metadata.prototype.getContent$I = function (index) { + /** @type {!number} */ + var startPosition; + /** @type {!number} */ + var length; + if (index < 0 || this._size$() <= index) { + throw new Error("Section.getContent() : range error " + (index + "")); + } + startPosition = 0; + if (index > 0) { + startPosition = this._bitVector.select$I(index - 1) + 1; + } + console.log(startPosition); + length = this._bitVector.select$I(index) - startPosition + 1; + console.log(length); + return this._parent._getSubstring$II(startPosition, length); +}; + +/** + * @param {!number} index + * @return {!number} + */ +Metadata.prototype.getStartPosition$I = function (index) { + /** @type {!number} */ + var startPosition; + if (index < 0 || this._size$() <= index) { + throw new Error("Section.getContent() : range error " + (index + "")); + } + startPosition = 0; + if (index > 0) { + startPosition = this._bitVector.select$I(index - 1) + 1; + } + return (startPosition | 0); +}; + +/** + * @param {SingleResult} result + * @param {Array.} positions + * @param {!string} word + * @param {!boolean} stemmed + */ +Metadata.prototype.grouping$LSingleResult$AISB = function (result, positions, word, stemmed) { +}; + +/** + * @param {!number} index + * @return {!string} + */ +Metadata.prototype.getInformation$I = function (index) { + return ''; +}; + +/** + */ +Metadata.prototype._build$ = function () { + this._bitVector.build$(); +}; + +/** + * @param {!string} name + * @param {!string} data + * @param {!number} offset + * @return {!number} + */ +Metadata.prototype._load$SSI = function (name, data, offset) { + offset = this._bitVector.load$SI(data, offset); + this._parent._metadataLabels.push(name); + this._parent._metadatas[name] = this; + return offset; +}; + +/** + * @return {!string} + */ +Metadata.prototype._dump$ = function () { + return this._bitVector.dump$(); +}; + +/** + * @param {CompressionReport} report + * @return {!string} + */ +Metadata.prototype._dump$LCompressionReport$ = function (report) { + return this._bitVector.dump$LCompressionReport$(report); +}; + +/** + * class Section extends Metadata + * @constructor + */ +function Section() { +} + +Section.prototype = new Metadata; +/** + * @constructor + * @param {Oktavia} parent + */ +function Section$LOktavia$(parent) { + Metadata$LOktavia$.call(this, parent); + this._names = [ ]; +}; + +Section$LOktavia$.prototype = new Section; + +/** + * @param {!string} name + */ +Section.prototype.setTail$S = function (name) { + this.setTail$SI(name, this._parent.contentSize$()); +}; + +/** + * @param {!string} name + * @param {!number} index + */ +Section.prototype.setTail$SI = function (name, index) { + this._names.push(name); + this._bitVector.set$I(index - 1); +}; + +/** + * @return {!number} + */ +Section.prototype.size$ = function () { + return (this._names.length | 0); +}; + +/** + * @param {!number} position + * @return {!number} + */ +Section.prototype.getSectionIndex$I = function (position) { + if (position < 0 || this._bitVector.size$() <= position) { + throw new Error("Section.getSectionIndex() : range error " + (position + "")); + } + return this._bitVector.rank$I(position); +}; + +/** + * @param {!number} index + * @return {!string} + */ +Section.prototype.getName$I = function (index) { + if (index < 0 || this.size$() <= index) { + throw new Error("Section.getName() : range error"); + } + return (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/metadata.jsx:129:26] null access\n return this._names[index];\n ^\n"); + } + return v; + }(this._names[index])); +}; + +/** + * @param {SingleResult} result + * @param {Array.} positions + * @param {!string} word + * @param {!boolean} stemmed + */ +Section.prototype.grouping$LSingleResult$AISB = function (result, positions, word, stemmed) { + /** @type {!number} */ + var i; + /** @type {undefined|!number} */ + var position; + /** @type {!number} */ + var index; + /** @type {SearchUnit} */ + var unit; + for (i = 0; i < positions.length; i++) { + position = positions[i]; + index = this.getSectionIndex$I((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/metadata.jsx:137:45] null access\n var index = this.getSectionIndex(position);\n ^^^^^^^^\n"); + } + return v; + }(position))); + unit = result.getSearchUnit$I(index); + if (unit.startPosition < 0) { + unit.startPosition = this.getStartPosition$I(index); + } + unit.addPosition$SIB(word, (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/metadata.jsx:143:35] null access\n unit.addPosition(word, position - unit.startPosition, stemmed);\n ^^^^^^^^\n"); + } + return v; + }(position)) - unit.startPosition, stemmed); + } +}; + +/** + * @param {!number} index + * @return {!string} + */ +Section.prototype.getInformation$I = function (index) { + return this.getName$I(index); +}; + +/** + * @param {Oktavia} parent + * @param {!string} name + * @param {!string} data + * @param {!number} offset + * @return {!number} + */ +Section._load$LOktavia$SSI = function (parent, name, data, offset) { + /** @type {LoadedStringListResult} */ + var strs; + /** @type {Section} */ + var section; + strs = Binary$loadStringList$SI(data, offset); + section = new Section$LOktavia$(parent); + section._names = strs.result; + return section._load$SSI(name, data, strs.offset); +}; + +var Section$_load$LOktavia$SSI = Section._load$LOktavia$SSI; + +/** + * @return {!string} + */ +Section.prototype._dump$ = function () { + return [ Binary$dump16bitNumber$I(0), Binary$dumpStringList$AS(this._names), Metadata.prototype._dump$.call(this) ].join(''); +}; + +/** + * @param {CompressionReport} report + * @return {!string} + */ +Section.prototype._dump$LCompressionReport$ = function (report) { + report.add$II(1, 1); + return [ Binary$dump16bitNumber$I(0), Binary$dumpStringList$ASLCompressionReport$(this._names, report), Metadata.prototype._dump$LCompressionReport$.call(this, report) ].join(''); +}; + +/** + * class Splitter extends Metadata + * @constructor + */ +function Splitter() { +} + +Splitter.prototype = new Metadata; +/** + * @constructor + * @param {Oktavia} parent + */ +function Splitter$LOktavia$(parent) { + Metadata$LOktavia$.call(this, parent); + this.name = null; +}; + +Splitter$LOktavia$.prototype = new Splitter; + +/** + * @constructor + * @param {Oktavia} parent + * @param {!string} name + */ +function Splitter$LOktavia$S(parent, name) { + Metadata$LOktavia$.call(this, parent); + this.name = name; +}; + +Splitter$LOktavia$S.prototype = new Splitter; + +/** + * @return {!number} + */ +Splitter.prototype.size$ = function () { + return this._size$(); +}; + +/** + */ +Splitter.prototype.split$ = function () { + this.split$I(this._parent.contentSize$()); +}; + +/** + * @param {!number} index + */ +Splitter.prototype.split$I = function (index) { + this._bitVector.set$I(index - 1); +}; + +/** + * @param {!number} position + * @return {!number} + */ +Splitter.prototype.getIndex$I = function (position) { + if (position < 0 || this._bitVector.size$() <= position) { + throw new Error("Section.getSectionIndex() : range error"); + } + return this._bitVector.rank$I(position); +}; + +/** + * @param {SingleResult} result + * @param {Array.} positions + * @param {!string} word + * @param {!boolean} stemmed + */ +Splitter.prototype.grouping$LSingleResult$AISB = function (result, positions, word, stemmed) { +}; + +/** + * @param {!number} index + * @return {!string} + */ +Splitter.prototype.getInformation$I = function (index) { + if (this.name != null) { + return (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/metadata.jsx:221:23] null access\n return this.name + ((index + 1) as string);\n ^\n"); + } + return v; + }(this.name)) + (index + 1 + ""); + } + return ''; +}; + +/** + * @param {Oktavia} parent + * @param {!string} name + * @param {!string} data + * @param {!number} offset + * @return {!number} + */ +Splitter._load$LOktavia$SSI = function (parent, name, data, offset) { + /** @type {Splitter} */ + var section; + section = new Splitter$LOktavia$(parent); + return section._load$SSI(name, data, offset); +}; + +var Splitter$_load$LOktavia$SSI = Splitter._load$LOktavia$SSI; + +/** + * @return {!string} + */ +Splitter.prototype._dump$ = function () { + return [ Binary$dump16bitNumber$I(1), Metadata.prototype._dump$.call(this) ].join(''); +}; + +/** + * @param {CompressionReport} report + * @return {!string} + */ +Splitter.prototype._dump$LCompressionReport$ = function (report) { + report.add$II(1, 1); + return [ Binary$dump16bitNumber$I(1), Metadata.prototype._dump$LCompressionReport$.call(this, report) ].join(''); +}; + +/** + * class Table extends Metadata + * @constructor + */ +function Table() { +} + +Table.prototype = new Metadata; +/** + * @constructor + * @param {Oktavia} parent + * @param {Array.} headers + */ +function Table$LOktavia$AS(parent, headers) { + Metadata$LOktavia$.call(this, parent); + this._headers = headers; + this._columnTails = new BitVector$(); +}; + +Table$LOktavia$AS.prototype = new Table; + +/** + * @return {!number} + */ +Table.prototype.rowSize$ = function () { + return this._size$(); +}; + +/** + * @return {!number} + */ +Table.prototype.columnSize$ = function () { + return (this._headers.length | 0); +}; + +/** + */ +Table.prototype.setColumnTail$ = function () { + /** @type {!number} */ + var index; + index = this._parent.contentSize$(); + this._parent.addEndOfBlock$(); + this._columnTails.set$I(index - 1); +}; + +/** + */ +Table.prototype.setRowTail$ = function () { + /** @type {!number} */ + var index; + index = this._parent.contentSize$(); + this._bitVector.set$I(index - 1); +}; + +/** + * @param {!number} position + * @return {Array.} + */ +Table.prototype.getCell$I = function (position) { + /** @type {!number} */ + var row; + /** @type {!number} */ + var currentColumn; + /** @type {!number} */ + var lastRowColumn; + /** @type {!number} */ + var startPosition; + /** @type {Array.} */ + var result; + if (position < 0 || this._bitVector.size$() <= position) { + throw new Error("Section.getSectionIndex() : range error " + (position + "")); + } + row = this._bitVector.rank$I(position); + currentColumn = this._columnTails.rank$I(position); + lastRowColumn = 0; + if (row > 0) { + startPosition = this._bitVector.select$I(row - 1) + 1; + lastRowColumn = this._columnTails.rank$I(startPosition); + } + result = [ row, currentColumn - lastRowColumn ]; + return result; +}; + +/** + * @param {!number} rowIndex + * @return {Object.} + */ +Table.prototype.getRowContent$I = function (rowIndex) { + /** @type {!string} */ + var content; + /** @type {Array.} */ + var values; + /** @type {Object.} */ + var result; + /** @type {!number} */ + var i; + content = this.getContent$I(rowIndex); + values = content.split(Oktavia.eob, this._headers.length); + result = ({ }); + for (i in this._headers) { + if (i < values.length) { + result[this._headers[i]] = values[i]; + } else { + result[this._headers[i]] = ''; + } + } + return result; +}; + +/** + * @param {SingleResult} result + * @param {Array.} positions + * @param {!string} word + * @param {!boolean} stemmed + */ +Table.prototype.grouping$LSingleResult$AISB = function (result, positions, word, stemmed) { +}; + +/** + * @param {!number} index + * @return {!string} + */ +Table.prototype.getInformation$I = function (index) { + return ''; +}; + +/** + */ +Table.prototype._build$ = function () { + this._bitVector.build$(); + this._columnTails.build$(); +}; + +/** + * @param {Oktavia} parent + * @param {!string} name + * @param {!string} data + * @param {!number} offset + * @return {!number} + */ +Table._load$LOktavia$SSI = function (parent, name, data, offset) { + /** @type {LoadedStringListResult} */ + var strs; + /** @type {Table} */ + var table; + strs = Binary$loadStringList$SI(data, offset); + table = new Table$LOktavia$AS(parent, strs.result); + offset = table._load$SSI(name, data, strs.offset); + return table._columnTails.load$SI(data, offset); +}; + +var Table$_load$LOktavia$SSI = Table._load$LOktavia$SSI; + +/** + * @return {!string} + */ +Table.prototype._dump$ = function () { + return [ Binary$dump16bitNumber$I(2), Binary$dumpStringList$AS(this._headers), Metadata.prototype._dump$.call(this), this._columnTails.dump$() ].join(''); +}; + +/** + * @param {CompressionReport} report + * @return {!string} + */ +Table.prototype._dump$LCompressionReport$ = function (report) { + report.add$II(1, 1); + return [ Binary$dump16bitNumber$I(2), Binary$dumpStringList$ASLCompressionReport$(this._headers, report), Metadata.prototype._dump$LCompressionReport$.call(this, report), this._columnTails.dump$LCompressionReport$(report) ].join(''); +}; + +/** + * class Block extends Metadata + * @constructor + */ +function Block() { +} + +Block.prototype = new Metadata; +/** + * @constructor + * @param {Oktavia} parent + */ +function Block$LOktavia$(parent) { + Metadata$LOktavia$.call(this, parent); + this._names = [ ]; + this._start = false; +}; + +Block$LOktavia$.prototype = new Block; + +/** + * @param {!string} blockName + */ +Block.prototype.startBlock$S = function (blockName) { + this.startBlock$SI(blockName, this._parent.contentSize$()); +}; + +/** + * @param {!string} blockName + * @param {!number} index + */ +Block.prototype.startBlock$SI = function (blockName, index) { + if (this._start) { + throw new Error('Splitter `' + (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/metadata.jsx:380:54] null access\n throw new Error(\'Splitter `\' + this._names[this._names.length - 1] + \'` is not closed\');\n ^\n"); + } + return v; + }(this._names[this._names.length - 1])) + '` is not closed'); + } + this._start = true; + this._names.push(blockName); + this._bitVector.set$I(index - 1); +}; + +/** + */ +Block.prototype.endBlock$ = function () { + this.endBlock$I(this._parent.contentSize$()); +}; + +/** + * @param {!number} index + */ +Block.prototype.endBlock$I = function (index) { + if (! this._start) { + throw new Error('Splitter is not started'); + } + this._start = false; + this._bitVector.set$I(index - 1); +}; + +/** + * @return {!number} + */ +Block.prototype.size$ = function () { + return (this._names.length | 0); +}; + +/** + * @param {!number} position + * @return {!number} + */ +Block.prototype.blockIndex$I = function (position) { + /** @type {!number} */ + var result; + if (position < 0 || this._parent._fmindex.size$() - 1 <= position) { + throw new Error("Block.blockIndex() : range error " + (position + "")); + } + if (position >= this._bitVector.size$()) { + position = (this._bitVector.size$() - 1 | 0); + result = (this._bitVector.rank$I(position) + 1 | 0); + } else { + result = this._bitVector.rank$I(position); + } + return result; +}; + +/** + * @param {!number} position + * @return {!boolean} + */ +Block.prototype.inBlock$I = function (position) { + /** @type {!number} */ + var blockIndex; + blockIndex = this.blockIndex$I(position); + return blockIndex % 2 !== 0; +}; + +/** + * @param {!number} position + * @return {!string} + */ +Block.prototype.getBlockContent$I = function (position) { + /** @type {!number} */ + var blockIndex; + /** @type {!string} */ + var result; + blockIndex = this.blockIndex$I(position); + if (blockIndex % 2 !== 0) { + result = this.getContent$I(blockIndex); + } else { + result = ''; + } + return result; +}; + +/** + * @param {!number} position + * @return {!string} + */ +Block.prototype.getBlockName$I = function (position) { + /** @type {!number} */ + var blockIndex; + /** @type {!string} */ + var result; + blockIndex = this.blockIndex$I(position); + if (blockIndex % 2 !== 0) { + result = (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/metadata.jsx:453:32] null access\n result = this._names[blockIndex >>> 1];\n ^\n"); + } + return v; + }(this._names[blockIndex >>> 1])); + } else { + result = ''; + } + return result; +}; + +/** + * @param {SingleResult} result + * @param {Array.} positions + * @param {!string} word + * @param {!boolean} stemmed + */ +Block.prototype.grouping$LSingleResult$AISB = function (result, positions, word, stemmed) { +}; + +/** + * @param {!number} index + * @return {!string} + */ +Block.prototype.getInformation$I = function (index) { + return ''; +}; + +/** + * @param {Oktavia} parent + * @param {!string} name + * @param {!string} data + * @param {!number} offset + * @return {!number} + */ +Block._load$LOktavia$SSI = function (parent, name, data, offset) { + /** @type {LoadedStringListResult} */ + var strs; + /** @type {Block} */ + var block; + strs = Binary$loadStringList$SI(data, offset); + block = new Block$LOktavia$(parent); + block._names = strs.result; + return block._load$SSI(name, data, strs.offset); +}; + +var Block$_load$LOktavia$SSI = Block._load$LOktavia$SSI; + +/** + * @return {!string} + */ +Block.prototype._dump$ = function () { + return [ Binary$dump16bitNumber$I(3), Binary$dumpStringList$AS(this._names), Metadata.prototype._dump$.call(this) ].join(''); +}; + +/** + * @param {CompressionReport} report + * @return {!string} + */ +Block.prototype._dump$LCompressionReport$ = function (report) { + report.add$II(1, 1); + return [ Binary$dump16bitNumber$I(3), Binary$dumpStringList$ASLCompressionReport$(this._names, report), Metadata.prototype._dump$LCompressionReport$.call(this, report) ].join(''); +}; + +/** + * class FMIndex extends Object + * @constructor + */ +function FMIndex() { +} + +/** + * @constructor + */ +function FMIndex$() { + this._ssize = 0; + (this._ddic = 0, this._head = 0); + this._substr = ""; + this._sv = new WaveletMatrix$(); + this._posdic = [ ]; + this._idic = [ ]; + this._rlt = [ ]; + this._rlt.length = 65536; +}; + +FMIndex$.prototype = new FMIndex; + +/** + */ +FMIndex.prototype.clear$ = function () { + this._sv.clear$(); + this._posdic.length = 0; + this._idic.length = 0; + this._ddic = 0; + this._head = 0; + this._substr = ""; +}; + +/** + * @return {!number} + */ +FMIndex.prototype.size$ = function () { + return this._sv.size$(); +}; + +/** + * @return {!number} + */ +FMIndex.prototype.contentSize$ = function () { + return this._substr.length; +}; + +/** + * @param {!string} key + * @return {!number} + */ +FMIndex.prototype.getRows$S = function (key) { + /** @type {Array.} */ + var pos; + pos = [ ]; + return this.getRows$SAI(key, pos); +}; + +/** + * @param {!string} key + * @param {Array.} pos + * @return {!number} + */ +FMIndex.prototype.getRows$SAI = function (key, pos) { + /** @type {!number} */ + var i; + /** @type {!number} */ + var code; + /** @type {!number} */ + var first; + /** @type {undefined|!number} */ + var last; + /** @type {!number} */ + var c; + i = key.length - 1; + code = key.charCodeAt(i); + first = (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/fm-index.jsx:67:29] null access\n var first = this._rlt[code] + 1;\n ^\n"); + } + return v; + }(this._rlt[code])) + 1; + last = this._rlt[code + 1]; + while (first <= (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/fm-index.jsx:69:24] null access\n while (first <= last)\n ^^^^\n"); + } + return v; + }(last))) { + if (i === 0) { + pos[0] = (-- first | 0); + pos[1] = -- last; + return ((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/fm-index.jsx:75:24] null access\n return (last - first + 1);\n ^^^^\n"); + } + return v; + }(last)) - first + 1 | 0); + } + i--; + c = key.charCodeAt(i); + first = (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/fm-index.jsx:79:29] null access\n first = this._rlt[c] + this._sv.rank(first - 1, c) + 1;\n ^\n"); + } + return v; + }(this._rlt[c])) + this._sv.rank$II(first - 1, c) + 1; + last = (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/fm-index.jsx:80:29] null access\n last = this._rlt[c] + this._sv.rank(last, c);\n ^\n"); + } + return v; + }(this._rlt[c])) + this._sv.rank$II((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/fm-index.jsx:80:49] null access\n last = this._rlt[c] + this._sv.rank(last, c);\n ^^^^\n"); + } + return v; + }(last)), c); + } + return 0; +}; + +/** + * @param {!number} i + * @return {!number} + */ +FMIndex.prototype.getPosition$I = function (i) { + /** @type {!number} */ + var pos; + /** @type {!number} */ + var c; + if (i >= this.size$()) { + throw new Error("FMIndex.getPosition() : range error"); + } + pos = 0; + while (i !== this._head) { + if (i % this._ddic === 0) { + pos += (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/fm-index.jsx:96:36] null access\n pos += (this._posdic[i / this._ddic] + 1);\n ^\n"); + } + return v; + }(this._posdic[i / this._ddic])) + 1; + break; + } + c = this._sv.get$I(i); + i = (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/fm-index.jsx:100:25] null access\n i = this._rlt[c] + this._sv.rank(i, c); //LF\n ^\n"); + } + return v; + }(this._rlt[c])) + this._sv.rank$II(i, c); + pos++; + } + return (pos % this.size$() | 0); +}; + +/** + * @param {!number} pos + * @param {!number} len + * @return {!string} + */ +FMIndex.prototype.getSubstring$II = function (pos, len) { + /** @type {!number} */ + var pos_end; + /** @type {!number} */ + var pos_tmp; + /** @type {!number} */ + var i; + /** @type {!number} */ + var pos_idic; + /** @type {!string} */ + var substr; + /** @type {!number} */ + var c; + if (pos >= this.size$()) { + throw new Error("FMIndex.getSubstring() : range error"); + } + pos_end = Math.min(pos + len, this.size$()); + pos_tmp = this.size$() - 1; + i = this._head; + pos_idic = Math.floor((pos_end + this._ddic - 2) / this._ddic); + if (pos_idic < this._idic.length) { + pos_tmp = pos_idic * this._ddic; + i = (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/fm-index.jsx:119:32] null access\n i = this._idic[pos_idic];\n ^\n"); + } + return v; + }(this._idic[pos_idic])); + } + substr = ""; + while (pos_tmp >= pos) { + c = this._sv.get$I(i); + i = (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/fm-index.jsx:126:25] null access\n i = this._rlt[c] + this._sv.rank(i, c); //LF\n ^\n"); + } + return v; + }(this._rlt[c])) + this._sv.rank$II(i, c); + if (pos_tmp < pos_end) { + substr = String.fromCharCode(c) + substr; + } + if (pos_tmp === 0) { + break; + } + pos_tmp--; + } + return substr; +}; + +/** + */ +FMIndex.prototype.build$ = function () { + this.build$SIIB(String.fromCharCode(0), 65535, 20, false); +}; + +/** + * @param {!string} end_marker + * @param {!number} ddic + * @param {!boolean} verbose + */ +FMIndex.prototype.build$SIB = function (end_marker, ddic, verbose) { + this.build$SIIB(end_marker, 65535, ddic, verbose); +}; + +/** + * @param {!string} end_marker + * @param {!number} maxChar + * @param {!number} ddic + * @param {!boolean} verbose + */ +FMIndex.prototype.build$SIIB = function (end_marker, maxChar, ddic, verbose) { + /** @type {BurrowsWheelerTransform} */ + var b; + /** @type {!string} */ + var s; + /** @type {!number} */ + var c; + if (verbose) { + console.time("building burrows-wheeler transform"); + } + this._substr += end_marker; + b = new BurrowsWheelerTransform$(); + b.build$S(this._substr); + s = b.get$(); + this._ssize = s.length; + this._head = b.head$(); + b.clear$(); + this._substr = ""; + if (verbose) { + console.timeEnd("building burrows-wheeler transform"); + } + if (verbose) { + console.time("building wavelet matrix"); + } + this._sv.setMaxCharCode$I(maxChar); + if (verbose) { + console.log(" maxCharCode: ", maxChar); + console.log(" bitSize: ", this._sv.bitsize$()); + } + this._sv.build$S(s); + if (verbose) { + console.timeEnd("building wavelet matrix"); + } + if (verbose) { + console.time("caching rank less than"); + } + for (c = 0; c < maxChar; c++) { + this._rlt[c] = this._sv.rank_less_than$II(this._sv.size$(), c); + } + if (verbose) { + console.timeEnd("caching rank less than"); + } + this._ddic = ddic; + if (verbose) { + console.time("building dictionaries"); + } + this._buildDictionaries$(); + if (verbose) { + console.timeEnd("building dictionaries"); + console.log(''); + } +}; + +/** + */ +FMIndex.prototype._buildDictionaries$ = function () { + /** @type {!number} */ + var i; + /** @type {!number} */ + var pos; + /** @type {!number} */ + var c; + for (i = 0; i < this._ssize / this._ddic + 1; i++) { + this._posdic.push(0); + this._idic.push(0); + } + i = this._head; + pos = this.size$() - 1; + do { + if (i % this._ddic === 0) { + this._posdic[Math.floor(i / this._ddic)] = (pos | 0); + } + if (pos % this._ddic === 0) { + this._idic[Math.floor(pos / this._ddic)] = (i | 0); + } + c = this._sv.get$I(i); + i = (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/fm-index.jsx:228:25] null access\n i = this._rlt[c] + this._sv.rank(i, c); //LF\n ^\n"); + } + return v; + }(this._rlt[c])) + this._sv.rank$II(i, c); + pos--; + } while (i !== this._head); +}; + +/** + * @param {!string} doc + */ +FMIndex.prototype.push$S = function (doc) { + if (doc.length <= 0) { + throw new Error("FMIndex::push(): empty string"); + } + this._substr += doc; +}; + +/** + * @param {!string} keyword + * @return {Array.} + */ +FMIndex.prototype.search$S = function (keyword) { + /** @type {Object.} */ + var result_map; + /** @type {Array.} */ + var result; + /** @type {Array.} */ + var position; + /** @type {!number} */ + var rows; + /** @type {undefined|!number} */ + var first; + /** @type {undefined|!number} */ + var last; + /** @type {undefined|!number} */ + var i; + result_map = ({ }); + result = [ ]; + position = [ ]; + rows = this.getRows$SAI(keyword, position); + if (rows > 0) { + first = position[0]; + last = position[1]; + for (i = first; (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/fm-index.jsx:252:32] null access\n for (var i = first; i <= last; i++)\n ^\n"); + } + return v; + }(i)) <= (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/fm-index.jsx:252:37] null access\n for (var i = first; i <= last; i++)\n ^^^^\n"); + } + return v; + }(last)); i++) { + result.push(this.getPosition$I((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/fm-index.jsx:254:45] null access\n result.push(this.getPosition(i));\n ^\n"); + } + return v; + }(i)))); + } + } + return result; +}; + +/** + * @return {!string} + */ +FMIndex.prototype.dump$ = function () { + return this.dump$B(false); +}; + +/** + * @param {!boolean} verbose + * @return {!string} + */ +FMIndex.prototype.dump$B = function (verbose) { + /** @type {Array.} */ + var contents; + /** @type {CompressionReport} */ + var report; + /** @type {!number} */ + var i; + contents = [ ]; + report = new CompressionReport$(); + contents.push(Binary$dump32bitNumber$N(this._ddic)); + contents.push(Binary$dump32bitNumber$N(this._ssize)); + contents.push(Binary$dump32bitNumber$N(this._head)); + report.add$II(6, 6); + contents.push(this._sv.dump$LCompressionReport$(report)); + if (verbose) { + console.log("Serializing FM-index"); + console.log(' Wavelet Matrix: ' + (contents[3].length * 2 + "") + ' bytes (' + (report.rate$() + "") + '%)'); + } + contents.push(Binary$dump32bitNumber$N(this._posdic.length)); + for (i in this._posdic) { + contents.push(Binary$dump32bitNumber$N((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/fm-index.jsx:282:61] null access\n contents.push(Binary.dump32bitNumber(this._posdic[i]));\n ^\n"); + } + return v; + }(this._posdic[i])))); + } + for (i in this._idic) { + contents.push(Binary$dump32bitNumber$N((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/fm-index.jsx:286:59] null access\n contents.push(Binary.dump32bitNumber(this._idic[i]));\n ^\n"); + } + return v; + }(this._idic[i])))); + } + if (verbose) { + console.log(' Dictionary Cache: ' + (this._idic.length * 16 + "") + ' bytes'); + } + return contents.join(""); +}; + +/** + * @param {!string} data + * @return {!number} + */ +FMIndex.prototype.load$S = function (data) { + return this.load$SI(data, 0); +}; + +/** + * @param {!string} data + * @param {!number} offset + * @return {!number} + */ +FMIndex.prototype.load$SI = function (data, offset) { + /** @type {!number} */ + var maxChar; + /** @type {!number} */ + var c; + /** @type {!number} */ + var size; + /** @type {!number} */ + var i; + this._ddic = (Binary$load32bitNumber$SI(data, offset) | 0); + this._ssize = (Binary$load32bitNumber$SI(data, offset + 2) | 0); + this._head = (Binary$load32bitNumber$SI(data, offset + 4) | 0); + offset = this._sv.load$SI(data, offset + 6); + maxChar = Math.pow(2, this._sv.bitsize$()); + for (c = 0; c < maxChar; c++) { + this._rlt[c] = this._sv.rank_less_than$II(this._sv.size$(), c); + } + size = Binary$load32bitNumber$SI(data, offset); + offset += 2; + for (i = 0; i < size; (i++, offset += 2)) { + this._posdic.push(Binary$load32bitNumber$SI(data, offset)); + } + for (i = 0; i < size; (i++, offset += 2)) { + this._idic.push(Binary$load32bitNumber$SI(data, offset)); + } + return offset; +}; + +/** + * class Tag extends Object + * @constructor + */ +function Tag() { +} + +/** + * @constructor + * @param {!string} name + */ +function Tag$S(name) { + this.name = name; + this.attributes = ({ }); + this.isSelfClosing = false; +}; + +Tag$S.prototype = new Tag; + +/** + * class _Common extends Object + * @constructor + */ +function _Common() { +} + +/** + * @constructor + */ +function _Common$() { +}; + +_Common$.prototype = new _Common; + +/** + * class _State extends Object + * @constructor + */ +function _State() { +} + +/** + * @constructor + */ +function _State$() { +}; + +_State$.prototype = new _State; + +/** + * class SAXHandler extends Object + * @constructor + */ +function SAXHandler() { +} + +/** + * @constructor + */ +function SAXHandler$() { + this.position = 0; + this.column = 0; + this.line = 0; +}; + +SAXHandler$.prototype = new SAXHandler; + +/** + * @param {Error} error + */ +SAXHandler.prototype.onerror$LError$ = function (error) { +}; + +/** + * @param {!string} text + */ +SAXHandler.prototype.ontext$S = function (text) { +}; + +/** + * @param {!string} doctype + */ +SAXHandler.prototype.ondoctype$S = function (doctype) { +}; + +/** + * @param {!string} name + * @param {!string} body + */ +SAXHandler.prototype.onprocessinginstruction$SS = function (name, body) { +}; + +/** + * @param {!string} sgmlDecl + */ +SAXHandler.prototype.onsgmldeclaration$S = function (sgmlDecl) { +}; + +/** + * @param {!string} tagname + * @param {Object.} attributes + */ +SAXHandler.prototype.onopentag$SHS = function (tagname, attributes) { +}; + +/** + * @param {!string} tagname + */ +SAXHandler.prototype.onclosetag$S = function (tagname) { +}; + +/** + * @param {!string} name + * @param {!string} value + */ +SAXHandler.prototype.onattribute$SS = function (name, value) { +}; + +/** + * @param {!string} comment + */ +SAXHandler.prototype.oncomment$S = function (comment) { +}; + +/** + */ +SAXHandler.prototype.onopencdata$ = function () { +}; + +/** + * @param {!string} cdata + */ +SAXHandler.prototype.oncdata$S = function (cdata) { +}; + +/** + */ +SAXHandler.prototype.onclosecdata$ = function () { +}; + +/** + */ +SAXHandler.prototype.onend$ = function () { +}; + +/** + */ +SAXHandler.prototype.onready$ = function () { +}; + +/** + * @param {!string} script + */ +SAXHandler.prototype.onscript$S = function (script) { +}; + +/** + * class _HTMLHandler extends SAXHandler + * @constructor + */ +function _HTMLHandler() { +} + +_HTMLHandler.prototype = new SAXHandler; +/** + * @constructor + * @param {Object.>} styles + * @param {!boolean} escape + */ +function _HTMLHandler$HASB(styles, escape) { + SAXHandler$.call(this); + this.text = [ ]; + this.escape = escape; + this.styles = styles; +}; + +_HTMLHandler$HASB.prototype = new _HTMLHandler; + +/** + * @param {!string} str + * @return {!string} + */ +_HTMLHandler.escapeHTML$S = function (str) { + return str.replace(/\n/g, "
").replace(/&/g, "&").replace(/"/g, """).replace(//g, ">"); +}; + +var _HTMLHandler$escapeHTML$S = _HTMLHandler.escapeHTML$S; + +/** + * @param {!string} tagname + * @param {Object.} attributes + */ +_HTMLHandler.prototype.onopentag$SHS = function (tagname, attributes) { + this.text.push((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/style.jsx:23:43] null access\n this.text.push(this.styles[tagname][0]);\n ^\n"); + } + return v; + }(this.styles[tagname][0]))); +}; + +/** + * @param {!string} tagname + */ +_HTMLHandler.prototype.onclosetag$S = function (tagname) { + this.text.push((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/style.jsx:28:43] null access\n this.text.push(this.styles[tagname][1]);\n ^\n"); + } + return v; + }(this.styles[tagname][1]))); +}; + +/** + * @param {!string} text + */ +_HTMLHandler.prototype.ontext$S = function (text) { + if (this.escape) { + this.text.push(_HTMLHandler$escapeHTML$S(text)); + } else { + this.text.push(text); + } +}; + +/** + * @return {!string} + */ +_HTMLHandler.prototype.result$ = function () { + return this.text.join(''); +}; + +/** + * class SAXParser extends Object + * @constructor + */ +function SAXParser() { +} + +/** + * @constructor + * @param {SAXHandler} handler + */ +function SAXParser$LSAXHandler$(handler) { + this.q = ""; + this.c = ""; + this.bufferCheckPosition = 0; + this.looseCase = ""; + this.tags = [ ]; + this.closed = false; + this.closedRoot = false; + this.sawRoot = false; + this.tag = null; + this.error = null; + this.handler = null; + this.ENTITIES = null; + this.strict = false; + this.tagName = ""; + this.state = 0; + this.line = 0; + this.column = 0; + this.position = 0; + this.startTagPosition = 0; + this.attribName = ""; + this.attribValue = ""; + this.script = ""; + this.textNode = ""; + this.attribList = null; + this.noscript = false; + this.cdata = ""; + this.procInstBody = ""; + this.procInstName = ""; + this.doctype = ""; + this.entity = ""; + this.sgmlDecl = ""; + this.comment = ""; + this.preTags = 0; + this._init$LSAXHandler$B(handler, false); +}; + +SAXParser$LSAXHandler$.prototype = new SAXParser; + +/** + * @constructor + * @param {SAXHandler} handler + * @param {!boolean} strict + */ +function SAXParser$LSAXHandler$B(handler, strict) { + this.q = ""; + this.c = ""; + this.bufferCheckPosition = 0; + this.looseCase = ""; + this.tags = [ ]; + this.closed = false; + this.closedRoot = false; + this.sawRoot = false; + this.tag = null; + this.error = null; + this.handler = null; + this.ENTITIES = null; + this.strict = false; + this.tagName = ""; + this.state = 0; + this.line = 0; + this.column = 0; + this.position = 0; + this.startTagPosition = 0; + this.attribName = ""; + this.attribValue = ""; + this.script = ""; + this.textNode = ""; + this.attribList = null; + this.noscript = false; + this.cdata = ""; + this.procInstBody = ""; + this.procInstName = ""; + this.doctype = ""; + this.entity = ""; + this.sgmlDecl = ""; + this.comment = ""; + this.preTags = 0; + this._init$LSAXHandler$B(handler, strict); +}; + +SAXParser$LSAXHandler$B.prototype = new SAXParser; + +/** + * @param {SAXHandler} handler + * @param {!boolean} strict + */ +SAXParser.prototype._init$LSAXHandler$B = function (handler, strict) { + this.handler = handler; + this.clearBuffers$(); + this.q = ""; + this.bufferCheckPosition = (_Common.MAX_BUFFER_LENGTH | 0); + this.looseCase = 'toLowerCase'; + this.tags = [ ]; + this.closed = this.closedRoot = this.sawRoot = false; + this.tag = null; + this.error = null; + this.strict = strict; + this.noscript = strict; + this.state = (_State.BEGIN | 0); + this.ENTITIES = _Entities$entity_list$(); + this.attribList = [ ]; + this.noscript = false; + this.preTags = 0; + this.handler.onready$(); +}; + +/** + * @param {!boolean} flag + */ +SAXParser.prototype.set_noscript$B = function (flag) { + this.noscript = flag; +}; + +/** + * @return {SAXParser} + */ +SAXParser.prototype.resume$ = function () { + this.error = null; + return this; +}; + +/** + * @return {SAXParser} + */ +SAXParser.prototype.close$ = function () { + return this.parse$S(''); +}; + +/** + * @param {!string} chunk + * @return {SAXParser} + */ +SAXParser.prototype.parse$S = function (chunk) { + /** @type {Char} */ + var _; + /** @type {!number} */ + var i; + /** @type {!string} */ + var c; + /** @type {!number} */ + var starti; + /** @type {!number} */ + var pad; + /** @type {!number} */ + var returnState; + _ = new Char$(); + if (this.error) { + throw this.error; + } + if (this.closed) { + return this.emiterror$S("Cannot write after close. Assign an onready handler."); + } + (i = 0, c = ""); + while (this.c = c = chunk.charAt(i++)) { + this.position++; + if (c === "\n") { + this.handler.line++; + this.handler.column = 0; + } else { + this.handler.column++; + } + switch (this.state) { + case _State.BEGIN: + if (c === "<") { + this.state = (_State.OPEN_WAKA | 0); + this.startTagPosition = this.position; + } else { + if (_.not$HBS(_.whitespace, c)) { + this.strictFail$S("Non-whitespace before first tag."); + this.textNode = c; + this.state = (_State.TEXT | 0); + } + } + continue; + case _State.TEXT: + if (this.sawRoot && ! this.closedRoot) { + starti = i - 1; + while (c && c !== "<" && c !== "&") { + c = chunk.charAt(i++); + if (c) { + this.position++; + if (c === "\n") { + this.handler.line++; + this.handler.column = 0; + } else { + this.handler.column++; + } + } + } + this.textNode += chunk.substring(starti, i - 1); + } + if (c === "<") { + this.state = (_State.OPEN_WAKA | 0); + this.startTagPosition = this.position; + } else { + if (_.not$HBS(_.whitespace, c) && (! this.sawRoot || this.closedRoot)) { + this.strictFail$S("Text data outside of root node."); + } + if (c === "&") { + this.state = (_State.TEXT_ENTITY | 0); + } else { + this.textNode += c; + } + } + continue; + case _State.SCRIPT: + if (c === "<") { + this.state = (_State.SCRIPT_ENDING | 0); + } else { + this.script += c; + } + continue; + case _State.SCRIPT_ENDING: + if (c === "/") { + this.state = (_State.CLOSE_TAG | 0); + } else { + this.script += "<" + c; + this.state = (_State.SCRIPT | 0); + } + continue; + case _State.OPEN_WAKA: + if (c === "!") { + this.state = (_State.SGML_DECL | 0); + this.sgmlDecl = ""; + } else { + if (_.is$HBS(_.whitespace, c)) { + } else { + if (_.is$LRegExp$S(_.nameStart, c)) { + this.state = (_State.OPEN_TAG | 0); + this.tagName = c; + } else { + if (c === "/") { + this.state = (_State.CLOSE_TAG | 0); + this.tagName = ""; + } else { + if (c === "?") { + this.state = (_State.PROC_INST | 0); + this.procInstName = this.procInstBody = ""; + } else { + this.strictFail$S("Unencoded <"); + if (this.startTagPosition + 1 < this.position) { + pad = this.position - this.startTagPosition; + for (i = 0; i < pad; i++) { + c = " " + c; + } + } + this.textNode += "<" + c; + this.state = (_State.TEXT | 0); + } + } + } + } + } + continue; + case _State.SGML_DECL: + if ((this.sgmlDecl + c).toUpperCase() === _.CDATA) { + this.closetext_if_exist$(); + this.handler.onopencdata$(); + this.state = (_State.CDATA | 0); + this.sgmlDecl = ""; + this.cdata = ""; + } else { + if (this.sgmlDecl + c === "--") { + this.state = (_State.COMMENT | 0); + this.comment = ""; + this.sgmlDecl = ""; + } else { + if ((this.sgmlDecl + c).toUpperCase() === _.DOCTYPE) { + this.state = (_State.DOCTYPE | 0); + if (this.doctype || this.sawRoot) { + this.strictFail$S("Inappropriately located doctype declaration"); + } + this.doctype = ""; + this.sgmlDecl = ""; + } else { + if (c === ">") { + this.closetext_if_exist$(); + this.handler.onsgmldeclaration$S(this.sgmlDecl); + this.sgmlDecl = ""; + this.state = (_State.TEXT | 0); + } else { + if (_.is$HBS(_.quote, c)) { + this.state = (_State.SGML_DECL_QUOTED | 0); + this.sgmlDecl += c; + } else { + this.sgmlDecl += c; + } + } + } + } + } + continue; + case _State.SGML_DECL_QUOTED: + if (c === this.q) { + this.state = (_State.SGML_DECL | 0); + this.q = ""; + } + this.sgmlDecl += c; + continue; + case _State.DOCTYPE: + if (c === ">") { + this.state = (_State.TEXT | 0); + this.closetext_if_exist$(); + this.handler.ondoctype$S(this.doctype); + } else { + this.doctype += c; + if (c === "[") { + this.state = (_State.DOCTYPE_DTD | 0); + } else { + if (_.is$HBS(_.quote, c)) { + this.state = (_State.DOCTYPE_QUOTED | 0); + this.q = c; + } + } + } + continue; + case _State.DOCTYPE_QUOTED: + this.doctype += c; + if (c === this.q) { + this.q = ""; + this.state = (_State.DOCTYPE | 0); + } + continue; + case _State.DOCTYPE_DTD: + this.doctype += c; + if (c === "]") { + this.state = (_State.DOCTYPE | 0); + } else { + if (_.is$HBS(_.quote, c)) { + this.state = (_State.DOCTYPE_DTD_QUOTED | 0); + this.q = c; + } + } + continue; + case _State.DOCTYPE_DTD_QUOTED: + this.doctype += c; + if (c === this.q) { + this.state = (_State.DOCTYPE_DTD | 0); + this.q = ""; + } + continue; + case _State.COMMENT: + if (c === "-") { + this.state = (_State.COMMENT_ENDING | 0); + } else { + this.comment += c; + } + continue; + case _State.COMMENT_ENDING: + if (c === "-") { + this.state = (_State.COMMENT_ENDED | 0); + this.comment = this.textopts$S(this.comment); + if (this.comment) { + this.closetext_if_exist$(); + this.handler.oncomment$S(this.comment); + } + this.comment = ""; + } else { + this.comment += "-" + c; + this.state = (_State.COMMENT | 0); + } + continue; + case _State.COMMENT_ENDED: + if (c !== ">") { + this.strictFail$S("Malformed comment"); + this.comment += "--" + c; + this.state = (_State.COMMENT | 0); + } else { + this.state = (_State.TEXT | 0); + } + continue; + case _State.CDATA: + if (c === "]") { + this.state = (_State.CDATA_ENDING | 0); + } else { + this.cdata += c; + } + continue; + case _State.CDATA_ENDING: + if (c === "]") { + this.state = (_State.CDATA_ENDING_2 | 0); + } else { + this.cdata += "]" + c; + this.state = (_State.CDATA | 0); + } + continue; + case _State.CDATA_ENDING_2: + if (c === ">") { + if (this.cdata) { + this.closetext_if_exist$(); + } + this.handler.oncdata$S(this.cdata); + this.handler.onclosecdata$(); + this.cdata = ""; + this.state = (_State.TEXT | 0); + } else { + if (c === "]") { + this.cdata += "]"; + } else { + this.cdata += "]]" + c; + this.state = (_State.CDATA | 0); + } + } + continue; + case _State.PROC_INST: + if (c === "?") { + this.state = (_State.PROC_INST_ENDING | 0); + } else { + if (_.is$HBS(_.whitespace, c)) { + this.state = (_State.PROC_INST_BODY | 0); + } else { + this.procInstName += c; + } + } + continue; + case _State.PROC_INST_BODY: + if (! this.procInstBody && _.is$HBS(_.whitespace, c)) { + continue; + } else { + if (c === "?") { + this.state = (_State.PROC_INST_ENDING | 0); + } else { + this.procInstBody += c; + } + } + continue; + case _State.PROC_INST_ENDING: + if (c === ">") { + this.closetext_if_exist$(); + this.handler.onprocessinginstruction$SS(this.procInstName, this.procInstBody); + this.procInstName = this.procInstBody = ""; + this.state = (_State.TEXT | 0); + } else { + this.procInstBody += "?" + c; + this.state = (_State.PROC_INST_BODY | 0); + } + continue; + case _State.OPEN_TAG: + if (_.is$LRegExp$S(_.nameBody, c)) { + this.tagName += c; + } else { + this.newTag$(); + if (c === ">") { + this.openTag$(); + } else { + if (c === "/") { + this.state = (_State.OPEN_TAG_SLASH | 0); + } else { + if (_.not$HBS(_.whitespace, c)) { + this.strictFail$S("Invalid character in tag name"); + } + this.state = (_State.ATTRIB | 0); + } + } + } + continue; + case _State.OPEN_TAG_SLASH: + if (c === ">") { + this.openTag$B(true); + this.closeTag$(); + } else { + this.strictFail$S("Forward-slash in opening tag not followed by >"); + this.state = (_State.ATTRIB | 0); + } + continue; + case _State.ATTRIB: + if (_.is$HBS(_.whitespace, c)) { + continue; + } else { + if (c === ">") { + this.openTag$(); + } else { + if (c === "/") { + this.state = (_State.OPEN_TAG_SLASH | 0); + } else { + if (_.is$LRegExp$S(_.nameStart, c)) { + this.attribName = c; + this.attribValue = ""; + this.state = (_State.ATTRIB_NAME | 0); + } else { + this.strictFail$S("Invalid attribute name"); + } + } + } + } + continue; + case _State.ATTRIB_NAME: + if (c === "=") { + this.state = (_State.ATTRIB_VALUE | 0); + } else { + if (c === ">") { + this.strictFail$S("Attribute without value"); + this.attribValue = this.attribName; + this.attrib$(); + this.openTag$(); + } else { + if (_.is$HBS(_.whitespace, c)) { + this.state = (_State.ATTRIB_NAME_SAW_WHITE | 0); + } else { + if (_.is$LRegExp$S(_.nameBody, c)) { + this.attribName += c; + } else { + this.strictFail$S("Invalid attribute name"); + } + } + } + } + continue; + case _State.ATTRIB_NAME_SAW_WHITE: + if (c === "=") { + this.state = (_State.ATTRIB_VALUE | 0); + } else { + if (_.is$HBS(_.whitespace, c)) { + continue; + } else { + this.strictFail$S("Attribute without value"); + this.tag.attributes[this.attribName] = ""; + this.attribValue = ""; + this.closetext_if_exist$(); + this.handler.onattribute$SS(this.attribName, ""); + this.attribName = ""; + if (c === ">") { + this.openTag$(); + } else { + if (_.is$LRegExp$S(_.nameStart, c)) { + this.attribName = c; + this.state = (_State.ATTRIB_NAME | 0); + } else { + this.strictFail$S("Invalid attribute name"); + this.state = (_State.ATTRIB | 0); + } + } + } + } + continue; + case _State.ATTRIB_VALUE: + if (_.is$HBS(_.whitespace, c)) { + continue; + } else { + if (_.is$HBS(_.quote, c)) { + this.q = c; + this.state = (_State.ATTRIB_VALUE_QUOTED | 0); + } else { + this.strictFail$S("Unquoted attribute value"); + this.state = (_State.ATTRIB_VALUE_UNQUOTED | 0); + this.attribValue = c; + } + } + continue; + case _State.ATTRIB_VALUE_QUOTED: + if (c !== this.q) { + if (c === "&") { + this.state = (_State.ATTRIB_VALUE_ENTITY_Q | 0); + } else { + this.attribValue += c; + } + continue; + } + this.attrib$(); + this.q = ""; + this.state = (_State.ATTRIB | 0); + continue; + case _State.ATTRIB_VALUE_UNQUOTED: + if (_.not$HBS(_.attribEnd, c)) { + if (c === "&") { + this.state = (_State.ATTRIB_VALUE_ENTITY_U | 0); + } else { + this.attribValue += c; + } + continue; + } + this.attrib$(); + if (c === ">") { + this.openTag$(); + } else { + this.state = (_State.ATTRIB | 0); + } + continue; + case _State.CLOSE_TAG: + if (! this.tagName) { + if (_.is$HBS(_.whitespace, c)) { + continue; + } else { + if (_.not$LRegExp$S(_.nameStart, c)) { + if (this.script) { + this.script += "") { + this.closeTag$(); + } else { + if (_.is$LRegExp$S(_.nameBody, c)) { + this.tagName += c; + } else { + if (this.script) { + this.script += "") { + this.closeTag$(); + } else { + this.strictFail$S("Invalid characters in closing tag"); + } + continue; + case _State.TEXT_ENTITY: + if (c === ";") { + this.textNode += this.parseEntity$(); + this.entity = ""; + this.state = (_State.TEXT | 0); + } else { + if (_.is$HBS(_.entity, c)) { + this.entity += c; + } else { + this.strictFail$S("Invalid character entity"); + this.textNode += "&" + this.entity + c; + this.entity = ""; + this.state = (_State.TEXT | 0); + } + } + continue; + case _State.ATTRIB_VALUE_ENTITY_Q: + case _State.ATTRIB_VALUE_ENTITY_U: + if (this.state === _State.ATTRIB_VALUE_ENTITY_Q) { + returnState = _State.ATTRIB_VALUE_QUOTED; + } else { + returnState = _State.ATTRIB_VALUE_UNQUOTED; + } + if (c === ";") { + this.attribValue += this.parseEntity$(); + this.entity = ""; + this.state = (returnState | 0); + } else { + if (_.is$HBS(_.entity, c)) { + this.entity += c; + } else { + this.strictFail$S("Invalid character entity"); + this.attribValue += "&" + this.entity + c; + this.entity = ""; + this.state = (returnState | 0); + } + } + continue; + default: + throw new Error("Unknown state: " + (this.state + "")); + } + } + this.end$(); + return this; +}; + +/** + */ +SAXParser.prototype.clearBuffers$ = function () { + this.comment = ''; + this.sgmlDecl = ''; + this.textNode = ''; + this.tagName = ''; + this.doctype = ''; + this.procInstName = ''; + this.procInstBody = ''; + this.entity = ''; + this.attribName = ''; + this.attribValue = ''; + this.cdata = ''; + this.script = ''; +}; + +/** + */ +SAXParser.prototype.closetext_if_exist$ = function () { + if (this.textNode !== '') { + this.closetext$(); + } +}; + +/** + */ +SAXParser.prototype.closetext$ = function () { + /** @type {!string} */ + var text; + if (this.preTags === 0) { + text = this.textopts$S(this.textNode); + if (text) { + this.handler.ontext$S(text); + } + } else { + if (this.textNode) { + this.handler.ontext$S(this.textNode); + } + } + this.textNode = ""; +}; + +/** + * @param {!string} text + * @return {!string} + */ +SAXParser.prototype.textopts$S = function (text) { + text = text.replace(/[\n\t]/g, ' '); + text = text.replace(/\s\s+/g, " "); + return text; +}; + +/** + * @param {!string} er + * @return {SAXParser} + */ +SAXParser.prototype.emiterror$S = function (er) { + /** @type {Error} */ + var error; + this.closetext$(); + er += "\nLine: " + (this.line + "") + "\nColumn: " + (this.column + "") + "\nChar: " + this.c; + error = new Error(er); + this.error = error; + this.handler.onerror$LError$(error); + return this; +}; + +/** + */ +SAXParser.prototype.end$ = function () { + if (! this.closedRoot) { + this.strictFail$S("Unclosed root tag"); + } + if (this.state !== _State.TEXT) { + this.emiterror$S("Unexpected end"); + } + this.closetext$(); + this.c = ""; + this.closed = true; + this.handler.onend$(); +}; + +/** + * @param {!string} message + */ +SAXParser.prototype.strictFail$S = function (message) { + if (this.strict) { + this.emiterror$S(message); + } +}; + +/** + */ +SAXParser.prototype.newTag$ = function () { + /** @type {!boolean} */ + var parent; + /** @type {Tag} */ + var tag; + if (! this.strict) { + this.tagName = this.tagName.toLowerCase(); + } + parent = !! (this.tags[this.tags.length - 1] || this); + tag = this.tag = new Tag$S(this.tagName); + this.attribList.length = 0; +}; + +/** + */ +SAXParser.prototype.attrib$ = function () { + if (! this.strict) { + this.attribName = this.attribName.toLowerCase(); + } + if ($__jsx_ObjectHasOwnProperty.call(this.tag.attributes, this.attribName)) { + this.attribName = this.attribValue = ""; + return; + } + this.tag.attributes[this.attribName] = this.attribValue; + this.closetext_if_exist$(); + this.handler.onattribute$SS(this.attribName, this.attribValue); + this.attribName = this.attribValue = ""; +}; + +/** + */ +SAXParser.prototype.openTag$ = function () { + this.openTag$B(false); +}; + +/** + * @param {!boolean} selfClosing + */ +SAXParser.prototype.openTag$B = function (selfClosing) { + this.tag.isSelfClosing = selfClosing; + this.sawRoot = true; + this.tags.push(this.tag); + this.closetext_if_exist$(); + this.handler.onopentag$SHS(this.tag.name, this.tag.attributes); + if (this.tag.name === 'pre') { + this.preTags++; + } + if (! selfClosing) { + if (! this.noscript && this.tagName.toLowerCase() === "script") { + this.state = (_State.SCRIPT | 0); + } else { + this.state = (_State.TEXT | 0); + } + this.tag = null; + this.tagName = ""; + } + this.attribName = this.attribValue = ""; + this.attribList.length = 0; +}; + +/** + */ +SAXParser.prototype.closeTag$ = function () { + /** @type {!number} */ + var t; + /** @type {!string} */ + var tagName; + /** @type {!string} */ + var closeTo; + /** @type {Tag} */ + var close; + /** @type {!number} */ + var s; + /** @type {Tag} */ + var tag; + /** @type {Tag} */ + var parent; + if (! this.tagName) { + this.strictFail$S("Weird empty close tag."); + this.textNode += ""; + this.state = (_State.TEXT | 0); + return; + } + if (this.script) { + if (this.tagName !== "script") { + this.script += ""; + this.tagName = ""; + this.state = (_State.SCRIPT | 0); + return; + } + this.closetext_if_exist$(); + this.handler.onscript$S(this.script); + this.script = ""; + } + t = this.tags.length; + tagName = this.tagName; + if (! this.strict) { + tagName = tagName.toLowerCase(); + } + closeTo = tagName; + while (t--) { + close = this.tags[t]; + if (close.name !== closeTo) { + this.strictFail$S("Unexpected close tag"); + } else { + break; + } + } + if (t < 0) { + this.strictFail$S("Unmatched closing tag: " + this.tagName); + this.textNode += ""; + this.state = (_State.TEXT | 0); + return; + } + this.tagName = tagName; + s = this.tags.length; + while (s-- > t) { + tag = this.tag = this.tags.pop(); + this.tagName = this.tag.name; + this.closetext_if_exist$(); + this.handler.onclosetag$S(this.tagName); + parent = this.tags[this.tags.length - 1]; + if (this.tagName === 'pre') { + this.preTags--; + } + } + if (t === 0) { + this.closedRoot = true; + } + this.tagName = this.attribValue = this.attribName = ""; + this.attribList.length = 0; + this.state = (_State.TEXT | 0); +}; + +/** + * @return {!string} + */ +SAXParser.prototype.parseEntity$ = function () { + /** @type {!string} */ + var entity; + /** @type {!string} */ + var entityLC; + /** @type {!number} */ + var num; + /** @type {!string} */ + var numStr; + entity = this.entity; + entityLC = entity.toLowerCase(); + num = 0; + numStr = ""; + if (this.ENTITIES[entity]) { + return (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/sax.jsx:977:32] null access\n return this.ENTITIES[entity];\n ^\n"); + } + return v; + }(this.ENTITIES[entity])); + } + if (this.ENTITIES[entityLC]) { + return (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/sax.jsx:981:32] null access\n return this.ENTITIES[entityLC];\n ^\n"); + } + return v; + }(this.ENTITIES[entityLC])); + } + entity = entityLC; + if (entity.charAt(0) === "#") { + if (entity.charAt(1) === "x") { + entity = entity.slice(2); + num = $__jsx_parseInt(entity, 16); + numStr = num.toString(16); + } else { + entity = entity.slice(1); + num = $__jsx_parseInt(entity, 10); + numStr = num.toString(10); + } + } + entity = entity.replace(/^0+/, ""); + if (numStr.toLowerCase() !== entity) { + this.strictFail$S("Invalid character entity"); + return "&" + this.entity + ";"; + } + return String.fromCharCode(num); +}; + +/** + * class Char extends Object + * @constructor + */ +function Char() { +} + +/** + * @constructor + */ +function Char$() { + /** @type {!string} */ + var whitespace; + /** @type {!string} */ + var number; + /** @type {!string} */ + var letter; + /** @type {!string} */ + var quote; + /** @type {!string} */ + var entity; + /** @type {!string} */ + var attribEnd; + whitespace = "\r\n\t "; + number = "0124356789"; + letter = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"; + quote = "'\""; + entity = number + letter + "#"; + attribEnd = whitespace + ">"; + this.CDATA = "[CDATA["; + this.DOCTYPE = "DOCTYPE"; + this.XML_NAMESPACE = "http://www.w3.org/XML/1998/namespace"; + this.whitespace = this._charClass$S(whitespace); + this.number = this._charClass$S(number); + this.letter = this._charClass$S(letter); + this.quote = this._charClass$S(quote); + this.entity = this._charClass$S(entity); + this.attribEnd = this._charClass$S(attribEnd); + this.nameStart = /[:_A-Za-z\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD]/; + this.nameBody = /[:_A-Za-z\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD\u00B7\u0300-\u036F\u203F-\u2040\.\d-]/; +}; + +Char$.prototype = new Char; + +/** + * @param {!string} str + * @return {Object.} + */ +Char.prototype._charClass$S = function (str) { + /** @type {Object.} */ + var result; + /** @type {!number} */ + var i; + result = ({ }); + for (i = 0; i < str.length; i++) { + result[str.slice(i, i + 1)] = true; + } + return result; +}; + +/** + * @param {RegExp} charclass + * @param {!string} c + * @return {!boolean} + */ +Char.prototype.is$LRegExp$S = function (charclass, c) { + return charclass.test(c); +}; + +/** + * @param {Object.} charclass + * @param {!string} c + * @return {!boolean} + */ +Char.prototype.is$HBS = function (charclass, c) { + return $__jsx_ObjectHasOwnProperty.call(charclass, c); +}; + +/** + * @param {RegExp} charclass + * @param {!string} c + * @return {!boolean} + */ +Char.prototype.not$LRegExp$S = function (charclass, c) { + return ! this.is$LRegExp$S(charclass, c); +}; + +/** + * @param {Object.} charclass + * @param {!string} c + * @return {!boolean} + */ +Char.prototype.not$HBS = function (charclass, c) { + return ! this.is$HBS(charclass, c); +}; + +/** + * class _Entities extends Object + * @constructor + */ +function _Entities() { +} + +/** + * @constructor + */ +function _Entities$() { +}; + +_Entities$.prototype = new _Entities; + +/** + * @return {Object.} + */ +_Entities.entity_list$ = function () { + /** @type {Object.} */ + var result; + /** @type {!string} */ + var key; + /** @type {*} */ + var value; + result = ({ }); + for (key in _Entities._entities) { + value = _Entities._entities[key]; + if (typeof value === 'string') { + result[key] = value + ""; + } else { + if (typeof value === 'number') { + result[key] = String.fromCharCode(value | 0); + } + } + } + return result; +}; + +var _Entities$entity_list$ = _Entities.entity_list$; + +/** + * class BitVector extends Object + * @constructor + */ +function BitVector() { +} + +/** + * @constructor + */ +function BitVector$() { + this._size = 0; + this._size1 = 0; + this._r = [ ]; + this._v = [ ]; + this.clear$(); +}; + +BitVector$.prototype = new BitVector; + +/** + */ +BitVector.prototype.build$ = function () { + /** @type {!number} */ + var i; + this._size1 = 0; + for (i = 0; i < this._v.length; i++) { + if (i % BitVector.BLOCK_RATE === 0) { + this._r.push(this.size$B(true)); + } + this._size1 += this._rank32$IIB((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/bit-vector.jsx:37:47] null access\n this._size1 += this._rank32(this._v[i], BitVector.SMALL_BLOCK_SIZE, true);\n ^\n"); + } + return v; + }(this._v[i])), BitVector.SMALL_BLOCK_SIZE, true); + } +}; + +/** + */ +BitVector.prototype.clear$ = function () { + this._v.length = 0; + this._r.length = 0; + this._size = 0; + this._size1 = 0; +}; + +/** + * @return {!number} + */ +BitVector.prototype.size$ = function () { + return this._size; +}; + +/** + * @param {!boolean} b + * @return {!number} + */ +BitVector.prototype.size$B = function (b) { + return (b ? this._size1 : this._size - this._size1); +}; + +/** + * @param {!number} value + */ +BitVector.prototype.set$I = function (value) { + this.set$IB(value, true); +}; + +/** + * @param {!number} value + * @param {!boolean} flag + */ +BitVector.prototype.set$IB = function (value, flag) { + /** @type {!number} */ + var q; + /** @type {!number} */ + var r; + /** @type {!number} */ + var m; + if (value >= this.size$()) { + this._size = (value + 1 | 0); + } + q = (value / BitVector.SMALL_BLOCK_SIZE | 0); + r = (value % BitVector.SMALL_BLOCK_SIZE | 0); + while (q >= this._v.length) { + this._v.push(0); + } + m = 0x1 << r; + if (flag) { + this._v[q] |= m; + } else { + this._v[q] &= ~ m; + } +}; + +/** + * @param {!number} value + * @return {!boolean} + */ +BitVector.prototype.get$I = function (value) { + /** @type {!number} */ + var q; + /** @type {!number} */ + var r; + /** @type {!number} */ + var m; + if (value >= this.size$()) { + throw new Error("BitVector.get() : range error"); + } + q = (value / BitVector.SMALL_BLOCK_SIZE | 0); + r = (value % BitVector.SMALL_BLOCK_SIZE | 0); + m = 0x1 << r; + return !! ((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/bit-vector.jsx:96:23] null access\n return (this._v[q] & m) as boolean;\n ^\n"); + } + return v; + }(this._v[q])) & m); +}; + +/** + * @param {!number} i + * @return {!number} + */ +BitVector.prototype.rank$I = function (i) { + return this.rank$IB(i, true); +}; + +/** + * @param {!number} i + * @param {!boolean} b + * @return {!number} + */ +BitVector.prototype.rank$IB = function (i, b) { + /** @type {!number} */ + var q_large; + /** @type {!number} */ + var q_small; + /** @type {!number} */ + var r; + /** @type {!number} */ + var rank; + /** @type {!number} */ + var begin; + /** @type {!number} */ + var j; + if (i > this.size$()) { + throw new Error("BitVector.rank() : range error"); + } + if (i === 0) { + return 0; + } + i--; + q_large = (Math.floor(i / BitVector.LARGE_BLOCK_SIZE) | 0); + q_small = (Math.floor(i / BitVector.SMALL_BLOCK_SIZE) | 0); + r = (Math.floor(i % BitVector.SMALL_BLOCK_SIZE) | 0); + rank = ((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/bit-vector.jsx:118:32] null access\n var rank : int = this._r[q_large];\n ^\n"); + } + return v; + }(this._r[q_large])) | 0); + if (! b) { + rank = q_large * BitVector.LARGE_BLOCK_SIZE - rank; + } + begin = q_large * BitVector.BLOCK_RATE; + for (j = begin; j < q_small; j++) { + rank += this._rank32$IIB((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/bit-vector.jsx:126:40] null access\n rank += this._rank32(this._v[j], BitVector.SMALL_BLOCK_SIZE, b);\n ^\n"); + } + return v; + }(this._v[j])), BitVector.SMALL_BLOCK_SIZE, b); + } + rank += this._rank32$IIB((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/bit-vector.jsx:128:36] null access\n rank += this._rank32(this._v[q_small], r + 1, b);\n ^\n"); + } + return v; + }(this._v[q_small])), r + 1, b); + return rank; +}; + +/** + * @param {!number} i + * @return {!number} + */ +BitVector.prototype.select$I = function (i) { + return this.select$IB(i, true); +}; + +/** + * @param {!number} i + * @param {!boolean} b + * @return {!number} + */ +BitVector.prototype.select$IB = function (i, b) { + /** @type {!number} */ + var left; + /** @type {!number} */ + var right; + /** @type {!number} */ + var pivot; + /** @type {undefined|!number} */ + var rank; + /** @type {!number} */ + var j; + if (i >= this.size$B(b)) { + throw new Error("BitVector.select() : range error"); + } + left = 0; + right = this._r.length; + while (left < right) { + pivot = Math.floor((left + right) / 2); + rank = this._r[pivot]; + if (! b) { + rank = pivot * BitVector.LARGE_BLOCK_SIZE - (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/bit-vector.jsx:152:60] null access\n rank = pivot * BitVector.LARGE_BLOCK_SIZE - rank;\n ^^^^\n"); + } + return v; + }(rank)); + } + if (i < (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/bit-vector.jsx:154:20] null access\n if (i < rank)\n ^^^^\n"); + } + return v; + }(rank))) { + right = pivot; + } else { + left = pivot + 1; + } + } + right--; + if (b) { + i -= ((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/bit-vector.jsx:167:24] null access\n i -= this._r[right];\n ^\n"); + } + return v; + }(this._r[right])) | 0); + } else { + i -= (right * BitVector.LARGE_BLOCK_SIZE - (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/bit-vector.jsx:171:61] null access\n i -= right * BitVector.LARGE_BLOCK_SIZE - this._r[right];\n ^\n"); + } + return v; + }(this._r[right])) | 0); + } + j = right * BitVector.BLOCK_RATE; + while (1) { + rank = this._rank32$IIB((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/bit-vector.jsx:176:43] null access\n var rank = this._rank32(this._v[j], BitVector.SMALL_BLOCK_SIZE, b);\n ^\n"); + } + return v; + }(this._v[j])), BitVector.SMALL_BLOCK_SIZE, b); + if (i < (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/bit-vector.jsx:177:20] null access\n if (i < rank)\n ^^^^\n"); + } + return v; + }(rank))) { + break; + } + j++; + i -= ((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/bit-vector.jsx:182:17] null access\n i -= rank;\n ^^^^\n"); + } + return v; + }(rank)) | 0); + } + return (j * BitVector.SMALL_BLOCK_SIZE + this._select32$IIB((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/bit-vector.jsx:184:70] null access\n return j * BitVector.SMALL_BLOCK_SIZE + this._select32(this._v[j], i, b);\n ^\n"); + } + return v; + }(this._v[j])), i, b) | 0); +}; + +/** + * @param {!number} x + * @param {!number} i + * @param {!boolean} b + * @return {!number} + */ +BitVector.prototype._rank32$IIB = function (x, i, b) { + if (! b) { + x = ~ x; + } + x <<= BitVector.SMALL_BLOCK_SIZE - i; + x = ((x & 0xaaaaaaaa) >>> 1) + (x & 0x55555555); + x = ((x & 0xcccccccc) >>> 2) + (x & 0x33333333); + x = ((x & 0xf0f0f0f0) >>> 4) + (x & 0x0f0f0f0f); + x = ((x & 0xff00ff00) >>> 8) + (x & 0x00ff00ff); + x = ((x & 0xffff0000) >>> 16) + (x & 0x0000ffff); + return x; +}; + +/** + * @param {!number} x + * @param {!number} i + * @param {!boolean} b + * @return {!number} + */ +BitVector.prototype._select32$IIB = function (x, i, b) { + /** @type {!number} */ + var x1; + /** @type {!number} */ + var x2; + /** @type {!number} */ + var x3; + /** @type {!number} */ + var x4; + /** @type {!number} */ + var x5; + /** @type {!number} */ + var pos; + /** @type {!number} */ + var v5; + /** @type {!number} */ + var v4; + /** @type {!number} */ + var v3; + /** @type {!number} */ + var v2; + /** @type {!number} */ + var v1; + /** @type {!number} */ + var v0; + if (! b) { + x = ~ x; + } + x1 = ((x & 0xaaaaaaaa) >>> 1) + (x & 0x55555555); + x2 = ((x1 & 0xcccccccc) >>> 2) + (x1 & 0x33333333); + x3 = ((x2 & 0xf0f0f0f0) >>> 4) + (x2 & 0x0f0f0f0f); + x4 = ((x3 & 0xff00ff00) >>> 8) + (x3 & 0x00ff00ff); + x5 = ((x4 & 0xffff0000) >>> 16) + (x4 & 0x0000ffff); + i++; + pos = 0; + v5 = x5 & 0xffffffff; + if (i > v5) { + i -= (v5 | 0); + pos += 32; + } + v4 = x4 >>> pos & 0x0000ffff; + if (i > v4) { + i -= (v4 | 0); + pos += 16; + } + v3 = x3 >>> pos & 0x000000ff; + if (i > v3) { + i -= (v3 | 0); + pos += 8; + } + v2 = x2 >>> pos & 0x0000000f; + if (i > v2) { + i -= (v2 | 0); + pos += 4; + } + v1 = x1 >>> pos & 0x00000003; + if (i > v1) { + i -= (v1 | 0); + pos += 2; + } + v0 = x >>> pos & 0x00000001; + if (i > v0) { + i -= (v0 | 0); + pos += 1; + } + return (pos | 0); +}; + +/** + * @return {!string} + */ +BitVector.prototype.dump$ = function () { + /** @type {Array.} */ + var contents; + contents = [ ]; + contents.push(Binary$dump32bitNumber$N(this._size)); + contents.push(Binary$dump32bitNumberList$AN(this._v)); + return contents.join(''); +}; + +/** + * @param {CompressionReport} report + * @return {!string} + */ +BitVector.prototype.dump$LCompressionReport$ = function (report) { + /** @type {Array.} */ + var contents; + contents = [ ]; + contents.push(Binary$dump32bitNumber$N(this._size)); + report.add$II(2, 2); + contents.push(Binary$dump32bitNumberList$ANLCompressionReport$(this._v, report)); + return contents.join(''); +}; + +/** + * @param {!string} data + * @return {!number} + */ +BitVector.prototype.load$S = function (data) { + return this.load$SI(data, 0); +}; + +/** + * @param {!string} data + * @param {!number} offset + * @return {!number} + */ +BitVector.prototype.load$SI = function (data, offset) { + /** @type {LoadedNumberListResult} */ + var result; + this.clear$(); + this._size = (Binary$load32bitNumber$SI(data, offset) | 0); + result = Binary$load32bitNumberList$SI(data, offset + 2); + this._v = result.result; + this.build$(); + return result.offset; +}; + +/** + * class WaveletMatrix extends Object + * @constructor + */ +function WaveletMatrix() { +} + +/** + * @constructor + */ +function WaveletMatrix$() { + this._size = 0; + this._range = ({ }); + this._bv = [ ]; + this._seps = [ ]; + this._bitsize = 16; + this.clear$(); +}; + +WaveletMatrix$.prototype = new WaveletMatrix; + +/** + * @return {!number} + */ +WaveletMatrix.prototype.bitsize$ = function () { + return this._bitsize; +}; + +/** + * @param {!number} charCode + */ +WaveletMatrix.prototype.setMaxCharCode$I = function (charCode) { + this._bitsize = (Math.ceil(Math.log(charCode) / Math.LN2) | 0); +}; + +/** + */ +WaveletMatrix.prototype.clear$ = function () { + this._bv.length = 0; + this._seps.length = 0; + this._size = 0; +}; + +/** + * @param {!string} v + */ +WaveletMatrix.prototype.build$S = function (v) { + /** @type {!number} */ + var size; + /** @type {!number} */ + var bitsize; + /** @type {!number} */ + var i; + /** @type {!number} */ + var depth; + /** @type {Object.} */ + var range_tmp; + /** @type {!number} */ + var code; + /** @type {!boolean} */ + var bit; + /** @type {!number} */ + var key; + /** @type {Object.} */ + var range_rev; + /** @type {!string} */ + var range_key; + /** @type {!number} */ + var value; + /** @type {!number} */ + var pos0; + /** @type {undefined|!number} */ + var pos1; + /** @type {!string} */ + var range_rev_key; + /** @type {!number} */ + var begin; + /** @type {undefined|!number} */ + var end; + /** @type {!number} */ + var num0; + /** @type {!number} */ + var num1; + this.clear$(); + size = v.length; + bitsize = this.bitsize$(); + for (i = 0; i < bitsize; i++) { + this._bv.push(new BitVector$()); + this._seps.push(0); + } + this._size = (size | 0); + for (i = 0; i < size; i++) { + this._bv[0].set$IB(i, this._uint2bit$II(v.charCodeAt(i), 0)); + } + this._bv[0].build$(); + this._seps[0] = this._bv[0].size$B(false); + this._range[0 + ""] = 0; + this._range[1 + ""] = this._seps[0]; + depth = 1; + while (depth < bitsize) { + range_tmp = WaveletMatrix$_shallow_copy$HI(this._range); + for (i = 0; i < size; i++) { + code = v.charCodeAt(i); + bit = this._uint2bit$II(code, depth); + key = code >>> bitsize - depth; + this._bv[depth].set$IB((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/wavelet-matrix.jsx:76:45] null access\n this._bv[depth].set(range_tmp[key as string], bit);\n ^\n"); + } + return v; + }(range_tmp[key + ""])), bit); + range_tmp[key + ""]++; + } + this._bv[depth].build$(); + this._seps[depth] = this._bv[depth].size$B(false); + range_rev = ({ }); + for (range_key in this._range) { + value = (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/wavelet-matrix.jsx:85:45] null access\n var value : int = this._range[range_key];\n ^\n"); + } + return v; + }(this._range[range_key])); + if (value != range_tmp[range_key]) { + range_rev[value + ""] = range_key | 0; + } + } + this._range = ({ }); + pos0 = 0; + pos1 = this._seps[depth]; + for (range_rev_key in range_rev) { + begin = range_rev_key | 0; + value = (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/wavelet-matrix.jsx:97:37] null access\n var value = range_rev[range_rev_key];\n ^\n"); + } + return v; + }(range_rev[range_rev_key])); + end = range_tmp[value + ""]; + num0 = this._bv[depth].rank$IB((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/wavelet-matrix.jsx:99:49] null access\n var num0 = this._bv[depth].rank(end , false) -\n ^^^\n"); + } + return v; + }(end)), false) - this._bv[depth].rank$IB(begin, false); + num1 = (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/wavelet-matrix.jsx:101:28] null access\n var num1 = end - begin - num0;\n ^^^\n"); + } + return v; + }(end)) - begin - num0; + if (num0 > 0) { + this._range[(value << 1) + ""] = (pos0 | 0); + pos0 += num0; + } + if (num1 > 0) { + this._range[(value << 1) + 1 + ""] = pos1; + pos1 += (num1 | 0); + } + } + depth++; + } +}; + +/** + * @return {!number} + */ +WaveletMatrix.prototype.size$ = function () { + return this._size; +}; + +/** + * @param {!number} c + * @return {!number} + */ +WaveletMatrix.prototype.size$I = function (c) { + return this.rank$II(this.size$(), c); +}; + +/** + * @param {!number} i + * @return {!number} + */ +WaveletMatrix.prototype.get$I = function (i) { + /** @type {!number} */ + var value; + /** @type {!number} */ + var depth; + /** @type {!boolean} */ + var bit; + if (i >= this.size$()) { + throw new Error("WaveletMatrix.get() : range error"); + } + value = 0; + depth = 0; + while (depth < this.bitsize$()) { + bit = this._bv[depth].get$I(i); + i = this._bv[depth].rank$IB(i, bit); + value <<= 1; + if (bit) { + i += (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/wavelet-matrix.jsx:142:31] null access\n i += this._seps[depth];\n ^\n"); + } + return v; + }(this._seps[depth])); + value += 1; + } + depth++; + } + return (value | 0); +}; + +/** + * @param {!number} i + * @param {!number} c + * @return {!number} + */ +WaveletMatrix.prototype.rank$II = function (i, c) { + /** @type {undefined|!number} */ + var begin; + /** @type {!number} */ + var end; + /** @type {!number} */ + var depth; + /** @type {!boolean} */ + var bit; + if (i > this.size$()) { + throw new Error("WaveletMatrix.rank(): range error"); + } + if (i === 0) { + return 0; + } + begin = this._range[c + ""]; + if (begin == null) { + return 0; + } + end = i; + depth = 0; + while (depth < this.bitsize$()) { + bit = this._uint2bit$II(c, depth); + end = this._bv[depth].rank$IB(end, bit); + if (bit) { + end += (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/wavelet-matrix.jsx:174:33] null access\n end += this._seps[depth];\n ^\n"); + } + return v; + }(this._seps[depth])); + } + depth++; + } + return (end - (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/wavelet-matrix.jsx:178:21] null access\n return end - begin;\n ^^^^^\n"); + } + return v; + }(begin)) | 0); +}; + +/** + * @param {!number} i + * @param {!number} c + * @return {!number} + */ +WaveletMatrix.prototype.rank_less_than$II = function (i, c) { + /** @type {!number} */ + var begin; + /** @type {!number} */ + var end; + /** @type {!number} */ + var depth; + /** @type {!number} */ + var rlt; + /** @type {!number} */ + var rank0_begin; + /** @type {!number} */ + var rank0_end; + if (i > this.size$()) { + throw new Error("WaveletMatrix.rank_less_than(): range error"); + } + if (i === 0) { + return 0; + } + begin = 0; + end = i; + depth = 0; + rlt = 0; + while (depth < this.bitsize$()) { + rank0_begin = this._bv[depth].rank$IB(begin, false); + rank0_end = this._bv[depth].rank$IB(end, false); + if (this._uint2bit$II(c, depth)) { + rlt += rank0_end - rank0_begin; + begin += (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/wavelet-matrix.jsx:203:36] null access\n begin += (this._seps[depth] - rank0_begin);\n ^\n"); + } + return v; + }(this._seps[depth])) - rank0_begin; + end += (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/wavelet-matrix.jsx:204:36] null access\n end += (this._seps[depth] - rank0_end);\n ^\n"); + } + return v; + }(this._seps[depth])) - rank0_end; + } else { + begin = rank0_begin; + end = rank0_end; + } + depth++; + } + return (rlt | 0); +}; + +/** + * @return {!string} + */ +WaveletMatrix.prototype.dump$ = function () { + /** @type {Array.} */ + var contents; + /** @type {!number} */ + var i; + /** @type {Array.} */ + var range_contents; + /** @type {!number} */ + var counter; + /** @type {!string} */ + var key; + contents = [ Binary$dump16bitNumber$I(this._bitsize), Binary$dump32bitNumber$N(this._size) ]; + for (i = 0; i < this.bitsize$(); i++) { + contents.push(this._bv[i].dump$()); + } + for (i = 0; i < this.bitsize$(); i++) { + contents.push(Binary$dump32bitNumber$N((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/wavelet-matrix.jsx:228:59] null access\n contents.push(Binary.dump32bitNumber(this._seps[i]));\n ^\n"); + } + return v; + }(this._seps[i])))); + } + range_contents = [ ]; + counter = 0; + for (key in this._range) { + range_contents.push(Binary$dump32bitNumber$N(key | 0)); + range_contents.push(Binary$dump32bitNumber$N((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/wavelet-matrix.jsx:235:66] null access\n range_contents.push(Binary.dump32bitNumber(this._range[key]));\n ^\n"); + } + return v; + }(this._range[key])))); + counter++; + } + contents.push(Binary$dump32bitNumber$N(counter)); + return contents.join('') + range_contents.join(''); +}; + +/** + * @param {CompressionReport} report + * @return {!string} + */ +WaveletMatrix.prototype.dump$LCompressionReport$ = function (report) { + /** @type {Array.} */ + var contents; + /** @type {!number} */ + var i; + /** @type {Array.} */ + var range_contents; + /** @type {!number} */ + var counter; + /** @type {!string} */ + var key; + contents = [ Binary$dump16bitNumber$I(this._bitsize), Binary$dump32bitNumber$N(this._size) ]; + report.add$II(3, 3); + for (i = 0; i < this.bitsize$(); i++) { + contents.push(this._bv[i].dump$LCompressionReport$(report)); + } + for (i = 0; i < this.bitsize$(); i++) { + contents.push(Binary$dump32bitNumber$N((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/wavelet-matrix.jsx:255:59] null access\n contents.push(Binary.dump32bitNumber(this._seps[i]));\n ^\n"); + } + return v; + }(this._seps[i])))); + report.add$II(2, 2); + } + range_contents = [ ]; + counter = 0; + for (key in this._range) { + range_contents.push(Binary$dump32bitNumber$N(key | 0)); + range_contents.push(Binary$dump32bitNumber$N((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/wavelet-matrix.jsx:263:66] null access\n range_contents.push(Binary.dump32bitNumber(this._range[key]));\n ^\n"); + } + return v; + }(this._range[key])))); + report.add$II(4, 4); + counter++; + } + report.add$II(2, 2); + contents.push(Binary$dump32bitNumber$N(counter)); + return contents.join('') + range_contents.join(''); +}; + +/** + * @param {!string} data + * @return {!number} + */ +WaveletMatrix.prototype.load$S = function (data) { + return this.load$SI(data, 0); +}; + +/** + * @param {!string} data + * @param {!number} offset + * @return {!number} + */ +WaveletMatrix.prototype.load$SI = function (data, offset) { + /** @type {!number} */ + var i; + /** @type {BitVector} */ + var bit_vector; + /** @type {!number} */ + var sep; + /** @type {!number} */ + var range_size; + /** @type {!number} */ + var key; + /** @type {!number} */ + var value; + this.clear$(); + this._bitsize = Binary$load16bitNumber$SI(data, offset++); + this._size = (Binary$load32bitNumber$SI(data, offset) | 0); + offset += 2; + for (i = 0; i < this.bitsize$(); i++) { + bit_vector = new BitVector$(); + offset = bit_vector.load$SI(data, offset); + this._bv.push(bit_vector); + } + sep = 0; + for (i = 0; i < this.bitsize$(); (i++, offset += 2)) { + this._seps.push(Binary$load32bitNumber$SI(data, offset)); + } + range_size = Binary$load32bitNumber$SI(data, offset); + offset += 2; + for (i = 0; i < range_size; (i++, offset += 4)) { + key = Binary$load32bitNumber$SI(data, offset); + value = Binary$load32bitNumber$SI(data, offset + 2); + this._range[key + ""] = (value | 0); + } + return offset; +}; + +/** + * @param {Object.} input + * @return {Object.} + */ +WaveletMatrix._shallow_copy$HI = function (input) { + /** @type {Object.} */ + var result; + /** @type {!string} */ + var key; + result = ({ }); + for (key in input) { + result[key] = input[key]; + } + return result; +}; + +var WaveletMatrix$_shallow_copy$HI = WaveletMatrix._shallow_copy$HI; + +/** + * @param {!number} c + * @param {!number} i + * @return {!boolean} + */ +WaveletMatrix.prototype._uint2bit$II = function (c, i) { + return (c >>> this._bitsize - 1 - i & 0x1) === 0x1; +}; + +/** + * class BurrowsWheelerTransform extends Object + * @constructor + */ +function BurrowsWheelerTransform() { +} + +/** + * @constructor + */ +function BurrowsWheelerTransform$() { + this._str = ""; + this._size = 0; + this._head = 0; + this._suffixarray = [ ]; +}; + +BurrowsWheelerTransform$.prototype = new BurrowsWheelerTransform; + +/** + * @return {!number} + */ +BurrowsWheelerTransform.prototype.size$ = function () { + return this._size; +}; + +/** + * @return {!number} + */ +BurrowsWheelerTransform.prototype.head$ = function () { + return this._head; +}; + +/** + */ +BurrowsWheelerTransform.prototype.clear$ = function () { + this._str = ""; + this._size = 0; + this._head = 0; + this._suffixarray.length = 0; +}; + +/** + * @param {!string} str + */ +BurrowsWheelerTransform.prototype.build$S = function (str) { + this._str = str; + this._size = this._str.length; + this._suffixarray = SAIS$make$S(str); + this._head = (this._suffixarray.indexOf(0) | 0); +}; + +/** + * @param {!number} i + * @return {!string} + */ +BurrowsWheelerTransform.prototype.get$I = function (i) { + /** @type {!number} */ + var size; + /** @type {!number} */ + var index; + size = this.size$(); + if (i >= size) { + throw new Error("BurrowsWheelerTransform.get() : range error"); + } + index = ((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/burrows-wheeler-transform.jsx:52:38] null access\n var index = (this._suffixarray[i] + size - 1) % size;\n ^\n"); + } + return v; + }(this._suffixarray[i])) + size - 1) % size; + return this._str.charAt(index); +}; + +/** + * @return {!string} + */ +BurrowsWheelerTransform.prototype.get$ = function () { + /** @type {Array.} */ + var str; + /** @type {!number} */ + var size; + /** @type {!number} */ + var i; + str = [ ]; + size = this.size$(); + for (i = 0; i < size; i++) { + str.push(this.get$I(i)); + } + return str.join(""); +}; + +/** + * @param {!string} replace + * @return {!string} + */ +BurrowsWheelerTransform.prototype.get$S = function (replace) { + /** @type {!string} */ + var result; + result = this.get$(); + return result.replace(BurrowsWheelerTransform.END_MARKER, replace); +}; + +/** + * class OArray extends Object + * @constructor + */ +function OArray() { +} + +/** + * @constructor + * @param {Array.} array + */ +function OArray$AI(array) { + this.array = array; + this.offset = 0; +}; + +OArray$AI.prototype = new OArray; + +/** + * @constructor + * @param {Array.} array + * @param {!number} offset + */ +function OArray$AII(array, offset) { + this.array = array; + this.offset = offset; +}; + +OArray$AII.prototype = new OArray; + +/** + * @param {!number} index + * @return {!number} + */ +OArray.prototype.get$I = function (index) { + return (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/sais.jsx:27:25] null access\n return this.array[index + this.offset];\n ^\n"); + } + return v; + }(this.array[index + this.offset])); +}; + +/** + * @param {!number} index + * @param {!number} value + */ +OArray.prototype.set$II = function (index, value) { + this.array[index + this.offset] = value; +}; + +/** + * @param {!number} index + * @return {!boolean} + */ +OArray.prototype.isS$I = function (index) { + return (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/sais.jsx:37:25] null access\n return this.array[index + this.offset] < this.array[index + this.offset + 1];\n ^\n"); + } + return v; + }(this.array[index + this.offset])) < (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/sais.jsx:37:59] null access\n return this.array[index + this.offset] < this.array[index + this.offset + 1];\n ^\n"); + } + return v; + }(this.array[index + this.offset + 1])); +}; + +/** + * @param {!number} index1 + * @param {!number} index2 + * @return {!boolean} + */ +OArray.prototype.compare$II = function (index1, index2) { + return this.array[index1 + this.offset] == this.array[index2 + this.offset]; +}; + +/** + * class SAIS extends Object + * @constructor + */ +function SAIS() { +} + +/** + * @constructor + */ +function SAIS$() { +}; + +SAIS$.prototype = new SAIS; + +/** + * @param {BitVector} t + * @param {!number} i + * @return {!boolean} + */ +SAIS._isLMS$LBitVector$I = function (t, i) { + return i > 0 && t.get$I(i) && ! t.get$I(i - 1); +}; + +var SAIS$_isLMS$LBitVector$I = SAIS._isLMS$LBitVector$I; + +/** + * @param {OArray} s + * @param {Array.} bkt + * @param {!number} n + * @param {!number} K + * @param {!boolean} end + */ +SAIS._getBuckets$LOArray$AIIIB = function (s, bkt, n, K, end) { + /** @type {!number} */ + var sum; + /** @type {!number} */ + var i; + sum = 0; + for (i = 0; i <= K; i++) { + bkt[i] = 0; + } + for (i = 0; i < n; i++) { + bkt[s.get$I(i)]++; + } + for (i = 0; i <= K; i++) { + sum += (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/sais.jsx:68:22] null access\n sum += bkt[i];\n ^\n"); + } + return v; + }(bkt[i])); + bkt[i] = ((end ? sum : sum - (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/sais.jsx:69:42] null access\n bkt[i] = end ? sum : sum - bkt[i];\n ^\n"); + } + return v; + }(bkt[i]))) | 0); + } +}; + +var SAIS$_getBuckets$LOArray$AIIIB = SAIS._getBuckets$LOArray$AIIIB; + +/** + * @param {BitVector} t + * @param {Array.} SA + * @param {OArray} s + * @param {Array.} bkt + * @param {!number} n + * @param {!number} K + * @param {!boolean} end + */ +SAIS._induceSAl$LBitVector$AILOArray$AIIIB = function (t, SA, s, bkt, n, K, end) { + /** @type {!number} */ + var i; + /** @type {!number} */ + var j; + SAIS$_getBuckets$LOArray$AIIIB(s, bkt, n, K, end); + for (i = 0; i < n; i++) { + j = (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/sais.jsx:79:22] null access\n var j = SA[i] - 1;\n ^\n"); + } + return v; + }(SA[i])) - 1; + if (j >= 0 && ! t.get$I(j)) { + SA[bkt[s.get$I(j)]++] = (j | 0); + } + } +}; + +var SAIS$_induceSAl$LBitVector$AILOArray$AIIIB = SAIS._induceSAl$LBitVector$AILOArray$AIIIB; + +/** + * @param {BitVector} t + * @param {Array.} SA + * @param {OArray} s + * @param {Array.} bkt + * @param {!number} n + * @param {!number} K + * @param {!boolean} end + */ +SAIS._induceSAs$LBitVector$AILOArray$AIIIB = function (t, SA, s, bkt, n, K, end) { + /** @type {!number} */ + var i; + /** @type {!number} */ + var j; + SAIS$_getBuckets$LOArray$AIIIB(s, bkt, n, K, end); + for (i = n - 1; i >= 0; i--) { + j = (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/sais.jsx:93:22] null access\n var j = SA[i] - 1;\n ^\n"); + } + return v; + }(SA[i])) - 1; + if (j >= 0 && t.get$I(j)) { + SA[-- bkt[s.get$I(j)]] = (j | 0); + } + } +}; + +var SAIS$_induceSAs$LBitVector$AILOArray$AIIIB = SAIS._induceSAs$LBitVector$AILOArray$AIIIB; + +/** + * @param {!string} source + * @return {Array.} + */ +SAIS.make$S = function (source) { + /** @type {Array.} */ + var charCodes; + /** @type {!number} */ + var maxCode; + /** @type {!number} */ + var i; + /** @type {!number} */ + var code; + /** @type {Array.} */ + var SA; + /** @type {OArray} */ + var s; + charCodes = [ ]; + charCodes.length = source.length; + maxCode = 0; + for (i = 0; i < source.length; i++) { + code = source.charCodeAt(i); + charCodes[i] = (code | 0); + maxCode = (code > maxCode ? code : maxCode); + } + SA = [ ]; + SA.length = source.length; + s = new OArray$AI(charCodes); + SAIS$_make$LOArray$AIII(s, SA, source.length, maxCode); + return SA; +}; + +var SAIS$make$S = SAIS.make$S; + +/** + * @param {OArray} s + * @param {Array.} SA + * @param {!number} n + * @param {!number} K + */ +SAIS._make$LOArray$AIII = function (s, SA, n, K) { + /** @type {BitVector} */ + var t; + /** @type {!number} */ + var i; + /** @type {Array.} */ + var bkt; + /** @type {!number} */ + var n1; + /** @type {!number} */ + var name; + /** @type {!number} */ + var prev; + /** @type {undefined|!number} */ + var pos; + /** @type {!boolean} */ + var diff; + /** @type {!number} */ + var d; + /** @type {!number} */ + var j; + /** @type {Array.} */ + var SA1; + /** @type {OArray} */ + var s1; + t = new BitVector$(); + t.set$IB(n - 2, false); + t.set$IB(n - 1, true); + for (i = n - 3; i >= 0; i--) { + t.set$IB(i, s.isS$I(i) || s.compare$II(i, i + 1) && t.get$I(i + 1)); + } + bkt = [ ]; + bkt.length = K + 1; + SAIS$_getBuckets$LOArray$AIIIB(s, bkt, n, K, true); + for (i = 0; i < n; i++) { + SA[i] = (- 1 | 0); + } + for (i = 1; i < n; i++) { + if (SAIS$_isLMS$LBitVector$I(t, i)) { + SA[-- bkt[s.get$I(i)]] = (i | 0); + } + } + SAIS$_induceSAl$LBitVector$AILOArray$AIIIB(t, SA, s, bkt, n, K, false); + SAIS$_induceSAs$LBitVector$AILOArray$AIIIB(t, SA, s, bkt, n, K, true); + n1 = 0; + for (i = 0; i < n; i++) { + if (SAIS$_isLMS$LBitVector$I(t, (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/sais.jsx:157:33] null access\n if (SAIS._isLMS(t, SA[i]))\n ^\n"); + } + return v; + }(SA[i])))) { + SA[n1++] = SA[i]; + } + } + for (i = n1; i < n; i++) { + SA[i] = (- 1 | 0); + } + name = 0; + prev = - 1; + for (i = 0; i < n1; i++) { + pos = SA[i]; + diff = false; + for (d = 0; d < n; d++) { + if (prev === - 1 || ! s.compare$II((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/sais.jsx:176:45] null access\n if (prev == -1 || !s.compare(pos + d, prev + d) || t.get(pos + d) != t.get(prev + d))\n ^^^\n"); + } + return v; + }(pos)) + d, prev + d) || t.get$I((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/sais.jsx:176:73] null access\n if (prev == -1 || !s.compare(pos + d, prev + d) || t.get(pos + d) != t.get(prev + d))\n ^^^\n"); + } + return v; + }(pos)) + d) !== t.get$I(prev + d)) { + diff = true; + break; + } else { + if (d > 0 && (SAIS$_isLMS$LBitVector$I(t, (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/sais.jsx:181:50] null access\n else if (d > 0 && (SAIS._isLMS(t, pos+d) || SAIS._isLMS(t, prev + d)))\n ^^^\n"); + } + return v; + }(pos)) + d) || SAIS$_isLMS$LBitVector$I(t, prev + d))) { + break; + } + } + } + if (diff) { + name++; + prev = (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/sais.jsx:189:23] null access\n prev = pos;\n ^^^\n"); + } + return v; + }(pos)); + } + pos = (((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/sais.jsx:191:19] null access\n pos = (pos % 2 == 0) ? pos / 2 : (pos - 1) / 2;\n ^^^\n"); + } + return v; + }(pos)) % 2 === 0 ? (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/sais.jsx:191:35] null access\n pos = (pos % 2 == 0) ? pos / 2 : (pos - 1) / 2;\n ^^^\n"); + } + return v; + }(pos)) / 2 : ((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/sais.jsx:191:46] null access\n pos = (pos % 2 == 0) ? pos / 2 : (pos - 1) / 2;\n ^^^\n"); + } + return v; + }(pos)) - 1) / 2) | 0); + SA[n1 + (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/sais.jsx:192:20] null access\n SA[n1 + pos] = name - 1;\n ^^^\n"); + } + return v; + }(pos))] = (name - 1 | 0); + } + for ((i = n - 1, j = n - 1); i >= n1; i--) { + if ((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/sais.jsx:196:18] null access\n if (SA[i] >= 0)\n ^\n"); + } + return v; + }(SA[i])) >= 0) { + SA[j--] = SA[i]; + } + } + SA1 = SA; + s1 = new OArray$AII(SA, n - n1); + if (name < n1) { + SAIS$_make$LOArray$AIII(s1, SA1, n1, name - 1); + } else { + for (i = 0; i < n1; i++) { + SA1[s1.get$I(i)] = (i | 0); + } + } + bkt = [ ]; + bkt.length = K + 1; + SAIS$_getBuckets$LOArray$AIIIB(s, bkt, n, K, true); + for ((i = 1, j = 0); i < n; i++) { + if (SAIS$_isLMS$LBitVector$I(t, i)) { + s1.set$II(j++, i); + } + } + for (i = 0; i < n1; i++) { + SA1[i] = s1.get$I((function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/sais.jsx:235:31] null access\n SA1[i] = s1.get(SA1[i]); // get index in s\n ^\n"); + } + return v; + }(SA1[i]))); + } + for (i = n1; i < n; i++) { + SA[i] = (- 1 | 0); + } + for (i = n1 - 1; i >= 0; i--) { + j = (function (v) { + if (! (v != null)) { + debugger; + throw new Error("[src/sais.jsx:243:18] null access\n j = SA[i];\n ^\n"); + } + return v; + }(SA[i])); + SA[i] = (- 1 | 0); + SA[-- bkt[s.get$I(j)]] = (j | 0); + } + SAIS$_induceSAl$LBitVector$AILOArray$AIIIB(t, SA, s, bkt, n, K, false); + SAIS$_induceSAs$LBitVector$AILOArray$AIIIB(t, SA, s, bkt, n, K, true); +}; + +var SAIS$_make$LOArray$AIII = SAIS._make$LOArray$AIII; + +OktaviaSearch._stemmer = null; +OktaviaSearch._instance = null; +$__jsx_lazy_init(Oktavia, "eof", function () { + return String.fromCharCode(0); +}); +$__jsx_lazy_init(Oktavia, "eob", function () { + return String.fromCharCode(1); +}); +$__jsx_lazy_init(Oktavia, "unknown", function () { + return String.fromCharCode(3); +}); +Binary._base64EncodeChars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; +$__jsx_lazy_init(Binary, "_base64DecodeChars", function () { + return [ - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, - 1, 62, - 1, - 1, - 1, 63, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, - 1, - 1, - 1, - 1, - 1, - 1, - 1, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, - 1, - 1, - 1, - 1, - 1, - 1, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, - 1, - 1, - 1, - 1, - 1 ]; +}); +$__jsx_lazy_init(Style, "console", function () { + return ({ 'title': [ '\x1B[32m\x1b[4m', '\x1B[39m\x1b[0m' ], 'url': [ '\x1B[34m', '\x1B[39m' ], 'hit': [ '\x1B[4m', '\x1B[0m' ], 'del': [ '\x1B[9m', '\x1B[0m' ], 'summary': [ '\x1B[90m', '\x1B[39m' ] }); +}); +$__jsx_lazy_init(Style, "html", function () { + return ({ 'title': [ '', '' ], 'url': [ '', '' ], 'hit': [ '', '' ], 'del': [ '', '' ], 'summary': [ '', '' ] }); +}); +$__jsx_lazy_init(Style, "ignore", function () { + return ({ 'tilte': [ '', '' ], 'url': [ '', '' ], 'hit': [ '', '' ], 'del': [ '', '' ], 'summary': [ '', '' ] }); +}); +EnglishStemmer.serialVersionUID = 1; +$__jsx_lazy_init(EnglishStemmer, "methodObject", function () { + return new EnglishStemmer$(); +}); +$__jsx_lazy_init(EnglishStemmer, "a_0", function () { + return [ new Among$SII("arsen", - 1, - 1), new Among$SII("commun", - 1, - 1), new Among$SII("gener", - 1, - 1) ]; +}); +$__jsx_lazy_init(EnglishStemmer, "a_1", function () { + return [ new Among$SII("'", - 1, 1), new Among$SII("'s'", 0, 1), new Among$SII("'s", - 1, 1) ]; +}); +$__jsx_lazy_init(EnglishStemmer, "a_2", function () { + return [ new Among$SII("ied", - 1, 2), new Among$SII("s", - 1, 3), new Among$SII("ies", 1, 2), new Among$SII("sses", 1, 1), new Among$SII("ss", 1, - 1), new Among$SII("us", 1, - 1) ]; +}); +$__jsx_lazy_init(EnglishStemmer, "a_3", function () { + return [ new Among$SII("", - 1, 3), new Among$SII("bb", 0, 2), new Among$SII("dd", 0, 2), new Among$SII("ff", 0, 2), new Among$SII("gg", 0, 2), new Among$SII("bl", 0, 1), new Among$SII("mm", 0, 2), new Among$SII("nn", 0, 2), new Among$SII("pp", 0, 2), new Among$SII("rr", 0, 2), new Among$SII("at", 0, 1), new Among$SII("tt", 0, 2), new Among$SII("iz", 0, 1) ]; +}); +$__jsx_lazy_init(EnglishStemmer, "a_4", function () { + return [ new Among$SII("ed", - 1, 2), new Among$SII("eed", 0, 1), new Among$SII("ing", - 1, 2), new Among$SII("edly", - 1, 2), new Among$SII("eedly", 3, 1), new Among$SII("ingly", - 1, 2) ]; +}); +$__jsx_lazy_init(EnglishStemmer, "a_5", function () { + return [ new Among$SII("anci", - 1, 3), new Among$SII("enci", - 1, 2), new Among$SII("ogi", - 1, 13), new Among$SII("li", - 1, 16), new Among$SII("bli", 3, 12), new Among$SII("abli", 4, 4), new Among$SII("alli", 3, 8), new Among$SII("fulli", 3, 14), new Among$SII("lessli", 3, 15), new Among$SII("ousli", 3, 10), new Among$SII("entli", 3, 5), new Among$SII("aliti", - 1, 8), new Among$SII("biliti", - 1, 12), new Among$SII("iviti", - 1, 11), new Among$SII("tional", - 1, 1), new Among$SII("ational", 14, 7), new Among$SII("alism", - 1, 8), new Among$SII("ation", - 1, 7), new Among$SII("ization", 17, 6), new Among$SII("izer", - 1, 6), new Among$SII("ator", - 1, 7), new Among$SII("iveness", - 1, 11), new Among$SII("fulness", - 1, 9), new Among$SII("ousness", - 1, 10) ]; +}); +$__jsx_lazy_init(EnglishStemmer, "a_6", function () { + return [ new Among$SII("icate", - 1, 4), new Among$SII("ative", - 1, 6), new Among$SII("alize", - 1, 3), new Among$SII("iciti", - 1, 4), new Among$SII("ical", - 1, 4), new Among$SII("tional", - 1, 1), new Among$SII("ational", 5, 2), new Among$SII("ful", - 1, 5), new Among$SII("ness", - 1, 5) ]; +}); +$__jsx_lazy_init(EnglishStemmer, "a_7", function () { + return [ new Among$SII("ic", - 1, 1), new Among$SII("ance", - 1, 1), new Among$SII("ence", - 1, 1), new Among$SII("able", - 1, 1), new Among$SII("ible", - 1, 1), new Among$SII("ate", - 1, 1), new Among$SII("ive", - 1, 1), new Among$SII("ize", - 1, 1), new Among$SII("iti", - 1, 1), new Among$SII("al", - 1, 1), new Among$SII("ism", - 1, 1), new Among$SII("ion", - 1, 2), new Among$SII("er", - 1, 1), new Among$SII("ous", - 1, 1), new Among$SII("ant", - 1, 1), new Among$SII("ent", - 1, 1), new Among$SII("ment", 15, 1), new Among$SII("ement", 16, 1) ]; +}); +$__jsx_lazy_init(EnglishStemmer, "a_8", function () { + return [ new Among$SII("e", - 1, 1), new Among$SII("l", - 1, 2) ]; +}); +$__jsx_lazy_init(EnglishStemmer, "a_9", function () { + return [ new Among$SII("succeed", - 1, - 1), new Among$SII("proceed", - 1, - 1), new Among$SII("exceed", - 1, - 1), new Among$SII("canning", - 1, - 1), new Among$SII("inning", - 1, - 1), new Among$SII("earring", - 1, - 1), new Among$SII("herring", - 1, - 1), new Among$SII("outing", - 1, - 1) ]; +}); +$__jsx_lazy_init(EnglishStemmer, "a_10", function () { + return [ new Among$SII("andes", - 1, - 1), new Among$SII("atlas", - 1, - 1), new Among$SII("bias", - 1, - 1), new Among$SII("cosmos", - 1, - 1), new Among$SII("dying", - 1, 3), new Among$SII("early", - 1, 9), new Among$SII("gently", - 1, 7), new Among$SII("howe", - 1, - 1), new Among$SII("idly", - 1, 6), new Among$SII("lying", - 1, 4), new Among$SII("news", - 1, - 1), new Among$SII("only", - 1, 10), new Among$SII("singly", - 1, 11), new Among$SII("skies", - 1, 2), new Among$SII("skis", - 1, 1), new Among$SII("sky", - 1, - 1), new Among$SII("tying", - 1, 5), new Among$SII("ugly", - 1, 8) ]; +}); +$__jsx_lazy_init(EnglishStemmer, "g_v", function () { + return [ 17, 65, 16, 1 ]; +}); +$__jsx_lazy_init(EnglishStemmer, "g_v_WXY", function () { + return [ 1, 17, 65, 208, 1 ]; +}); +$__jsx_lazy_init(EnglishStemmer, "g_valid_LI", function () { + return [ 55, 141, 2 ]; +}); +$__jsx_lazy_init(_Common, "buffers", function () { + return [ "comment", "sgmlDecl", "textNode", "tagName", "doctype", "procInstName", "procInstBody", "entity", "attribName", "attribValue", "cdata", "script" ]; +}); +$__jsx_lazy_init(_Common, "EVENTS", function () { + return [ "text", "processinginstruction", "sgmldeclaration", "doctype", "comment", "attribute", "opentag", "closetag", "opencdata", "cdata", "clo_State.CDATA", "error", "end", "ready", "script", "opennamespace", "closenamespace" ]; +}); +$__jsx_lazy_init(_Common, "MAX_BUFFER_LENGTH", function () { + return 64 * 1024; +}); +_State.BEGIN = 1; +_State.TEXT = 2; +_State.TEXT_ENTITY = 3; +_State.OPEN_WAKA = 4; +_State.SGML_DECL = 5; +_State.SGML_DECL_QUOTED = 6; +_State.DOCTYPE = 7; +_State.DOCTYPE_QUOTED = 8; +_State.DOCTYPE_DTD = 9; +_State.DOCTYPE_DTD_QUOTED = 10; +_State.COMMENT_STARTING = 11; +_State.COMMENT = 12; +_State.COMMENT_ENDING = 13; +_State.COMMENT_ENDED = 14; +_State.CDATA = 15; +_State.CDATA_ENDING = 16; +_State.CDATA_ENDING_2 = 17; +_State.PROC_INST = 18; +_State.PROC_INST_BODY = 19; +_State.PROC_INST_ENDING = 20; +_State.OPEN_TAG = 21; +_State.OPEN_TAG_SLASH = 22; +_State.ATTRIB = 23; +_State.ATTRIB_NAME = 24; +_State.ATTRIB_NAME_SAW_WHITE = 25; +_State.ATTRIB_VALUE = 26; +_State.ATTRIB_VALUE_QUOTED = 27; +_State.ATTRIB_VALUE_UNQUOTED = 28; +_State.ATTRIB_VALUE_ENTITY_Q = 29; +_State.ATTRIB_VALUE_ENTITY_U = 30; +_State.CLOSE_TAG = 31; +_State.CLOSE_TAG_SAW_WHITE = 32; +_State.SCRIPT = 33; +_State.SCRIPT_ENDING = 34; +$__jsx_lazy_init(_Entities, "_entities", function () { + return ({ "amp": "&", "gt": ">", "lt": "<", "quot": "\"", "apos": "'", "AElig": 198, "Aacute": 193, "Acirc": 194, "Agrave": 192, "Aring": 197, "Atilde": 195, "Auml": 196, "Ccedil": 199, "ETH": 208, "Eacute": 201, "Ecirc": 202, "Egrave": 200, "Euml": 203, "Iacute": 205, "Icirc": 206, "Igrave": 204, "Iuml": 207, "Ntilde": 209, "Oacute": 211, "Ocirc": 212, "Ograve": 210, "Oslash": 216, "Otilde": 213, "Ouml": 214, "THORN": 222, "Uacute": 218, "Ucirc": 219, "Ugrave": 217, "Uuml": 220, "Yacute": 221, "aacute": 225, "acirc": 226, "aelig": 230, "agrave": 224, "aring": 229, "atilde": 227, "auml": 228, "ccedil": 231, "eacute": 233, "ecirc": 234, "egrave": 232, "eth": 240, "euml": 235, "iacute": 237, "icirc": 238, "igrave": 236, "iuml": 239, "ntilde": 241, "oacute": 243, "ocirc": 244, "ograve": 242, "oslash": 248, "otilde": 245, "ouml": 246, "szlig": 223, "thorn": 254, "uacute": 250, "ucirc": 251, "ugrave": 249, "uuml": 252, "yacute": 253, "yuml": 255, "copy": 169, "reg": 174, "nbsp": 160, "iexcl": 161, "cent": 162, "pound": 163, "curren": 164, "yen": 165, "brvbar": 166, "sect": 167, "uml": 168, "ordf": 170, "laquo": 171, "not": 172, "shy": 173, "macr": 175, "deg": 176, "plusmn": 177, "sup1": 185, "sup2": 178, "sup3": 179, "acute": 180, "micro": 181, "para": 182, "middot": 183, "cedil": 184, "ordm": 186, "raquo": 187, "frac14": 188, "frac12": 189, "frac34": 190, "iquest": 191, "times": 215, "divide": 247, "OElig": 338, "oelig": 339, "Scaron": 352, "scaron": 353, "Yuml": 376, "fnof": 402, "circ": 710, "tilde": 732, "Alpha": 913, "Beta": 914, "Gamma": 915, "Delta": 916, "Epsilon": 917, "Zeta": 918, "Eta": 919, "Theta": 920, "Iota": 921, "Kappa": 922, "Lambda": 923, "Mu": 924, "Nu": 925, "Xi": 926, "Omicron": 927, "Pi": 928, "Rho": 929, "Sigma": 931, "Tau": 932, "Upsilon": 933, "Phi": 934, "Chi": 935, "Psi": 936, "Omega": 937, "alpha": 945, "beta": 946, "gamma": 947, "delta": 948, "epsilon": 949, "zeta": 950, "eta": 951, "theta": 952, "iota": 953, "kappa": 954, "lambda": 955, "mu": 956, "nu": 957, "xi": 958, "omicron": 959, "pi": 960, "rho": 961, "sigmaf": 962, "sigma": 963, "tau": 964, "upsilon": 965, "phi": 966, "chi": 967, "psi": 968, "omega": 969, "thetasym": 977, "upsih": 978, "piv": 982, "ensp": 8194, "emsp": 8195, "thinsp": 8201, "zwnj": 8204, "zwj": 8205, "lrm": 8206, "rlm": 8207, "ndash": 8211, "mdash": 8212, "lsquo": 8216, "rsquo": 8217, "sbquo": 8218, "ldquo": 8220, "rdquo": 8221, "bdquo": 8222, "dagger": 8224, "Dagger": 8225, "bull": 8226, "hellip": 8230, "permil": 8240, "prime": 8242, "Prime": 8243, "lsaquo": 8249, "rsaquo": 8250, "oline": 8254, "frasl": 8260, "euro": 8364, "image": 8465, "weierp": 8472, "real": 8476, "trade": 8482, "alefsym": 8501, "larr": 8592, "uarr": 8593, "rarr": 8594, "darr": 8595, "harr": 8596, "crarr": 8629, "lArr": 8656, "uArr": 8657, "rArr": 8658, "dArr": 8659, "hArr": 8660, "forall": 8704, "part": 8706, "exist": 8707, "empty": 8709, "nabla": 8711, "isin": 8712, "notin": 8713, "ni": 8715, "prod": 8719, "sum": 8721, "minus": 8722, "lowast": 8727, "radic": 8730, "prop": 8733, "infin": 8734, "ang": 8736, "and": 8743, "or": 8744, "cap": 8745, "cup": 8746, "int": 8747, "there4": 8756, "sim": 8764, "cong": 8773, "asymp": 8776, "ne": 8800, "equiv": 8801, "le": 8804, "ge": 8805, "sub": 8834, "sup": 8835, "nsub": 8836, "sube": 8838, "supe": 8839, "oplus": 8853, "otimes": 8855, "perp": 8869, "sdot": 8901, "lceil": 8968, "rceil": 8969, "lfloor": 8970, "rfloor": 8971, "lang": 9001, "rang": 9002, "loz": 9674, "spades": 9824, "clubs": 9827, "hearts": 9829, "diams": 9830 }); +}); +BitVector.SMALL_BLOCK_SIZE = 32; +BitVector.LARGE_BLOCK_SIZE = 256; +BitVector.BLOCK_RATE = 8; +$__jsx_lazy_init(BurrowsWheelerTransform, "END_MARKER", function () { + return String.fromCharCode(0); +}); +var $__jsx_classMap = { + "tool/web/oktavia-english-search.jsx": { + _Main: _Main, + _Main$: _Main$ + }, + "tool/web/oktavia-search.jsx": { + _Result: _Result, + _Result$SSSI: _Result$SSSI, + _Proposal: _Proposal, + _Proposal$SSI: _Proposal$SSI, + OktaviaSearch: OktaviaSearch, + OktaviaSearch$I: OktaviaSearch$I, + _Main: _Main$0, + _Main$: _Main$0$ + }, + "src/oktavia.jsx": { + Oktavia: Oktavia, + Oktavia$: Oktavia$ + }, + "src/binary-util.jsx": { + Binary: Binary, + Binary$: Binary$, + LoadedStringResult: LoadedStringResult, + LoadedStringResult$SI: LoadedStringResult$SI, + LoadedStringListResult: LoadedStringListResult, + LoadedStringListResult$SI: LoadedStringListResult$SI, + LoadedStringListMapResult: LoadedStringListMapResult, + LoadedStringListMapResult$SI: LoadedStringListMapResult$SI, + LoadedNumberListResult: LoadedNumberListResult, + LoadedNumberListResult$SI: LoadedNumberListResult$SI, + CompressionReport: CompressionReport, + CompressionReport$: CompressionReport$ + }, + "src/query.jsx": { + Query: Query, + Query$: Query$ + }, + "src/query-string-parser.jsx": { + QueryStringParser: QueryStringParser, + QueryStringParser$: QueryStringParser$ + }, + "src/search-result.jsx": { + Proposal: Proposal, + Proposal$II: Proposal$II, + Position: Position, + Position$SIB: Position$SIB, + SearchUnit: SearchUnit, + SearchUnit$I: SearchUnit$I, + SingleResult: SingleResult, + SingleResult$: SingleResult$, + SingleResult$SBB: SingleResult$SBB, + SearchSummary: SearchSummary, + SearchSummary$: SearchSummary$, + SearchSummary$LOktavia$: SearchSummary$LOktavia$ + }, + "src/style.jsx": { + Style: Style, + Style$S: Style$S, + _HTMLHandler: _HTMLHandler, + _HTMLHandler$HASB: _HTMLHandler$HASB + }, + "src/stemmer/stemmer.jsx": { + Stemmer: Stemmer, + Stemmer$: Stemmer$ + }, + "src/stemmer/base-stemmer.jsx": { + BaseStemmer: BaseStemmer, + BaseStemmer$: BaseStemmer$ + }, + "src/stemmer/english-stemmer.jsx": { + EnglishStemmer: EnglishStemmer, + EnglishStemmer$: EnglishStemmer$ + }, + "src/stemmer/among.jsx": { + Among: Among, + Among$SII: Among$SII, + Among$SIIF$LBaseStemmer$B$LBaseStemmer$: Among$SIIF$LBaseStemmer$B$LBaseStemmer$ + }, + "src/metadata.jsx": { + Metadata: Metadata, + Metadata$LOktavia$: Metadata$LOktavia$, + Section: Section, + Section$LOktavia$: Section$LOktavia$, + Splitter: Splitter, + Splitter$LOktavia$: Splitter$LOktavia$, + Splitter$LOktavia$S: Splitter$LOktavia$S, + Table: Table, + Table$LOktavia$AS: Table$LOktavia$AS, + Block: Block, + Block$LOktavia$: Block$LOktavia$ + }, + "src/fm-index.jsx": { + FMIndex: FMIndex, + FMIndex$: FMIndex$ + }, + "src/sax.jsx": { + Tag: Tag, + Tag$S: Tag$S, + _Common: _Common, + _Common$: _Common$, + _State: _State, + _State$: _State$, + SAXHandler: SAXHandler, + SAXHandler$: SAXHandler$, + SAXParser: SAXParser, + SAXParser$LSAXHandler$: SAXParser$LSAXHandler$, + SAXParser$LSAXHandler$B: SAXParser$LSAXHandler$B, + Char: Char, + Char$: Char$, + _Entities: _Entities, + _Entities$: _Entities$ + }, + "src/bit-vector.jsx": { + BitVector: BitVector, + BitVector$: BitVector$ + }, + "src/wavelet-matrix.jsx": { + WaveletMatrix: WaveletMatrix, + WaveletMatrix$: WaveletMatrix$ + }, + "src/burrows-wheeler-transform.jsx": { + BurrowsWheelerTransform: BurrowsWheelerTransform, + BurrowsWheelerTransform$: BurrowsWheelerTransform$ + }, + "src/sais.jsx": { + OArray: OArray, + OArray$AI: OArray$AI, + OArray$AII: OArray$AII, + SAIS: SAIS, + SAIS$: SAIS$ + } +}; + + +/** + * launches _Main.main(:string[]):void invoked by jsx --run|--executable + */ +JSX.runMain = function (sourceFile, args) { + var module = JSX.require(sourceFile); + if (! module) { + throw new ReferenceError("entry point module not found in " + sourceFile); + } + if (! module._Main) { + throw new ReferenceError("entry point _Main not found in " + sourceFile); + } + if (! module._Main.main$AS) { + throw new ReferenceError("entry point _Main.main(:string[]):void not found in " + sourceFile); + } + module._Main.main$AS(args); +}; + +/** + * launches _Test#test*():void invoked by jsx --test + */ +JSX.runTests = function (sourceFile, tests) { + var module = JSX.require(sourceFile); + var testClass = module._Test$; + + if (!testClass) return; // skip if there's no test class + + if(tests.length === 0) { + var p = testClass.prototype; + for (var m in p) { + if (p[m] instanceof Function + && /^test.*[$]$/.test(m)) { + tests.push(m); + } + } + } + else { // set as process arguments + tests = tests.map(function (name) { + return name + "$"; // mangle for function test*():void + }); + } + + var testCase = new testClass(); + + if (testCase.beforeClass$AS != null) + testCase.beforeClass$AS(tests); + + for (var i = 0; i < tests.length; ++i) { + (function (method) { + if (method in testCase) { + testCase.run$SF$V$(method, function() { testCase[method](); }); + } + else { + throw new ReferenceError("No such test method: " + method); + } + }(tests[i])); + } + + if (testCase.afterClass$ != null) + testCase.afterClass$(); +}; +/** + * call a function on load/DOMContentLoaded + */ +function $__jsx_onload (event) { + window.removeEventListener("load", $__jsx_onload); + document.removeEventListener("DOMContentLoaded", $__jsx_onload); + JSX.runMain("tool/web/oktavia-english-search.jsx", []) +} + +window.addEventListener("load", $__jsx_onload); +document.addEventListener("DOMContentLoaded", $__jsx_onload); + +})(JSX); -- cgit v1.2.3