From 91275eb478ceb58083426099b6da3f4c7e189f19 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Thu, 30 May 2024 04:50:01 +0200 Subject: Merging debian version 1.9.4-1. Signed-off-by: Daniel Baumann --- .../doc/search/oktavia-english-search.js | 9039 -------------------- 1 file changed, 9039 deletions(-) delete mode 100644 debian/vendor-h2o/doc/search/oktavia-english-search.js (limited to 'debian/vendor-h2o/doc/search/oktavia-english-search.js') diff --git a/debian/vendor-h2o/doc/search/oktavia-english-search.js b/debian/vendor-h2o/doc/search/oktavia-english-search.js deleted file mode 100644 index 5911991..0000000 --- a/debian/vendor-h2o/doc/search/oktavia-english-search.js +++ /dev/null @@ -1,9039 +0,0 @@ -// 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