summaryrefslogtreecommitdiffstats
path: root/debian/vendor-h2o/doc/search/oktavia-english-search.js
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--debian/vendor-h2o/doc/search/oktavia-english-search.js9039
1 files changed, 9039 insertions, 0 deletions
diff --git a/debian/vendor-h2o/doc/search/oktavia-english-search.js b/debian/vendor-h2o/doc/search/oktavia-english-search.js
new file mode 100644
index 0000000..5911991
--- /dev/null
+++ b/debian/vendor-h2o/doc/search/oktavia-english-search.js
@@ -0,0 +1,9039 @@
+// generatedy by JSX compiler 0.9.10 (2013-02-22 10:18:33 +0900; e3a1f2a04656dbfd626086b3c68606d0c9697212)
+var JSX = {};
+(function (JSX) {
+/**
+ * copies the implementations from source interface to target
+ */
+function $__jsx_merge_interface(target, source) {
+ for (var k in source.prototype)
+ if (source.prototype.hasOwnProperty(k))
+ target.prototype[k] = source.prototype[k];
+}
+
+/**
+ * defers the initialization of the property
+ */
+function $__jsx_lazy_init(obj, prop, func) {
+ function reset(obj, prop, value) {
+ delete obj[prop];
+ obj[prop] = value;
+ return value;
+ }
+
+ Object.defineProperty(obj, prop, {
+ get: function () {
+ return reset(obj, prop, func());
+ },
+ set: function (v) {
+ reset(obj, prop, v);
+ },
+ enumerable: true,
+ configurable: true
+ });
+}
+
+/**
+ * sideeffect().a /= b
+ */
+function $__jsx_div_assign(obj, prop, divisor) {
+ return obj[prop] = (obj[prop] / divisor) | 0;
+}
+
+/*
+ * global functions, renamed to avoid conflict with local variable names
+ */
+var $__jsx_parseInt = parseInt;
+var $__jsx_parseFloat = parseFloat;
+var $__jsx_isNaN = isNaN;
+var $__jsx_isFinite = isFinite;
+
+var $__jsx_encodeURIComponent = encodeURIComponent;
+var $__jsx_decodeURIComponent = decodeURIComponent;
+var $__jsx_encodeURI = encodeURI;
+var $__jsx_decodeURI = decodeURI;
+
+var $__jsx_ObjectToString = Object.prototype.toString;
+var $__jsx_ObjectHasOwnProperty = Object.prototype.hasOwnProperty;
+
+/*
+ * profiler object, initialized afterwards
+ */
+function $__jsx_profiler() {
+}
+
+/*
+ * public interface to JSX code
+ */
+JSX.require = function (path) {
+ var m = $__jsx_classMap[path];
+ return m !== undefined ? m : null;
+};
+
+JSX.profilerIsRunning = function () {
+ return $__jsx_profiler.getResults != null;
+};
+
+JSX.getProfileResults = function () {
+ return ($__jsx_profiler.getResults || function () { return {}; })();
+};
+
+JSX.postProfileResults = function (url) {
+ if ($__jsx_profiler.postResults == null)
+ throw new Error("profiler has not been turned on");
+ return $__jsx_profiler.postResults(url);
+};
+
+JSX.resetProfileResults = function () {
+ if ($__jsx_profiler.resetResults == null)
+ throw new Error("profiler has not been turned on");
+ return $__jsx_profiler.resetResults();
+};
+JSX.DEBUG = true;
+/**
+ * class _Main extends Object
+ * @constructor
+ */
+function _Main() {
+}
+
+/**
+ * @constructor
+ */
+function _Main$() {
+};
+
+_Main$.prototype = new _Main;
+
+/**
+ * @param {Array.<undefined|!string>} 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.<undefined|_Result>}
+ */
+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.<undefined|_Result>} */
+ var results;
+ /** @type {!number} */
+ var i;
+ /** @type {SearchUnit} */
+ var unit;
+ /** @type {Array.<undefined|!string>} */
+ var info;
+ /** @type {!number} */
+ var offset;
+ /** @type {!string} */
+ var content;
+ /** @type {Array.<undefined|Position>} */
+ 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('<hit>*</hit>').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('<br/>');
+ } else {
+ text = content.slice(0, end - start) + ' ...<br/>';
+ }
+ text = text.replace(Oktavia.eob, ' ').replace(/(<br\/>)(<br\/>)+/, '<br/><br/>');
+ 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.<undefined|_Proposal>}
+ */
+OktaviaSearch.prototype.getProposals$ = function () {
+ /** @type {Style} */
+ var style;
+ /** @type {Array.<undefined|_Proposal>} */
+ var results;
+ /** @type {!number} */
+ var i;
+ /** @type {Proposal} */
+ var proposal;
+ /** @type {Array.<undefined|!string>} */
+ var label;
+ /** @type {Array.<undefined|!string>} */
+ 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('<hit>' + this._queries[j].toString() + '</hit>'));
+ option.push(this._queries[j].toString());
+ } else {
+ label.push(style.convert$S('<del>' + this._queries[j].toString() + '</del>'));
+ }
+ }
+ results.push(new _Proposal$SSI(option.join(' '), label.join('&nbsp;'), proposal.expect));
+ }
+ }
+ return results;
+};
+
+/**
+ * @param {SearchSummary} summary
+ * @return {Array.<undefined|SearchUnit>}
+ */
+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.<undefined|!string>} 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.<undefined|!string>} 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.<undefined|!string>} */
+ 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.<undefined|!string>} */
+ 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.<undefined|!string>} */
+ 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.<undefined|!string>} */
+ 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.<undefined|!number>}
+ */
+Oktavia.prototype.rawSearch$SB = function (keyword, stemming) {
+ /** @type {Array.<undefined|!number>} */
+ var result;
+ /** @type {!string} */
+ var baseWord;
+ /** @type {Array.<undefined|!string>} */
+ 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.<undefined|Query>} 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.<undefined|!number>} */
+ 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.<undefined|!string>} */
+ 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.<undefined|!string>} */
+ 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.<undefined|!string>} */
+ 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.<undefined|!number>} */
+ var charCodes;
+ /** @type {!number} */
+ var i;
+ /** @type {!number} */
+ var charCode;
+ /** @type {Array.<undefined|!string>} */
+ 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.<undefined|!string>} strList
+ * @return {!string}
+ */
+Binary.dumpStringList$AS = function (strList) {
+ return Binary$dumpStringList$ASLCompressionReport$(strList, null);
+};
+
+var Binary$dumpStringList$AS = Binary.dumpStringList$AS;
+
+/**
+ * @param {Array.<undefined|!string>} strList
+ * @param {CompressionReport} report
+ * @return {!string}
+ */
+Binary.dumpStringList$ASLCompressionReport$ = function (strList, report) {
+ /** @type {Array.<undefined|!string>} */
+ 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.<string, undefined|Array.<undefined|!string>>} strMap
+ * @return {!string}
+ */
+Binary.dumpStringListMap$HAS = function (strMap) {
+ return Binary$dumpStringListMap$HASLCompressionReport$(strMap, null);
+};
+
+var Binary$dumpStringListMap$HAS = Binary.dumpStringListMap$HAS;
+
+/**
+ * @param {Object.<string, undefined|Array.<undefined|!string>>} strMap
+ * @param {CompressionReport} report
+ * @return {!string}
+ */
+Binary.dumpStringListMap$HASLCompressionReport$ = function (strMap, report) {
+ /** @type {Array.<undefined|!string>} */
+ 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.<undefined|!number>} array
+ * @return {!string}
+ */
+Binary.dump32bitNumberList$AN = function (array) {
+ return Binary$dump32bitNumberList$ANLCompressionReport$(array, null);
+};
+
+var Binary$dump32bitNumberList$AN = Binary.dump32bitNumberList$AN;
+
+/**
+ * @param {Array.<undefined|!number>} array
+ * @param {CompressionReport} report
+ * @return {!string}
+ */
+Binary.dump32bitNumberList$ANLCompressionReport$ = function (array, report) {
+ /** @type {Array.<undefined|!string>} */
+ 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.<undefined|!number>} 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.<undefined|!string>} */
+ 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.<undefined|!number>} 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.<undefined|!number>} 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.<undefined|!number>} array
+ * @param {!number} offset
+ * @param {!number} length
+ * @return {!string}
+ */
+Binary._nonZeroBlock$ANII = function (array, offset, length) {
+ /** @type {Array.<undefined|!string>} */
+ 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.<undefined|!number>} array
+ * @param {!number} offset
+ * @return {!string}
+ */
+Binary._createZebraCode$ANI = function (array, offset) {
+ /** @type {!number} */
+ var last;
+ /** @type {!number} */
+ var code;
+ /** @type {Array.<undefined|!string>} */
+ 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.<undefined|!string>} */
+ var out;
+ /** @type {Array.<undefined|!number>} */
+ 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.<undefined|!number>} source
+ * @return {!string}
+ */
+Binary._mergeCharCode$AI = function (source) {
+ /** @type {Array.<undefined|!string>} */
+ 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.<undefined|!number>} */
+ 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.<undefined|!string>} */
+ 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.<undefined|!string>} */
+ 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.<undefined|!number>} */
+ 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.<undefined|!string>} */
+ 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.<undefined|Position>}
+ */
+SearchUnit.prototype.getPositions$ = function () {
+ var $this = this;
+ /** @type {Array.<undefined|Position>} */
+ 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.<undefined|SingleResult>} 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.<undefined|Proposal>}
+ */
+SearchSummary.prototype.getProposal$ = function () {
+ var $this = this;
+ /** @type {Array.<undefined|Proposal>} */
+ var proposals;
+ /** @type {!number} */
+ var i;
+ /** @type {Array.<undefined|SingleResult>} */
+ 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.<undefined|SearchUnit>}
+ */
+SearchSummary.prototype.getSortedResult$ = function () {
+ var $this = this;
+ /** @type {Array.<undefined|SearchUnit>} */
+ 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.<undefined|!number>} 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.<undefined|!number>} 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.<undefined|!number>} 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.<undefined|!number>} 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.<undefined|Among>} 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.<undefined|Among>} 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.<undefined|!string>} words
+ * @return {Array.<undefined|!string>}
+ */
+BaseStemmer.prototype.stemWords$AS = function (words) {
+ /** @type {Array.<undefined|!string>} */
+ 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.<undefined|!number>} 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.<undefined|!number>} 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.<undefined|!number>} 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.<undefined|!string>} 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.<undefined|!number>}
+ */
+Table.prototype.getCell$I = function (position) {
+ /** @type {!number} */
+ var row;
+ /** @type {!number} */
+ var currentColumn;
+ /** @type {!number} */
+ var lastRowColumn;
+ /** @type {!number} */
+ var startPosition;
+ /** @type {Array.<undefined|!number>} */
+ 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.<string, undefined|!string>}
+ */
+Table.prototype.getRowContent$I = function (rowIndex) {
+ /** @type {!string} */
+ var content;
+ /** @type {Array.<undefined|!string>} */
+ var values;
+ /** @type {Object.<string, undefined|!string>} */
+ 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.<undefined|!number>} 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.<undefined|!number>} 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.<undefined|!number>} */
+ var pos;
+ pos = [ ];
+ return this.getRows$SAI(key, pos);
+};
+
+/**
+ * @param {!string} key
+ * @param {Array.<undefined|!number>} 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.<undefined|!number>}
+ */
+FMIndex.prototype.search$S = function (keyword) {
+ /** @type {Object.<string, undefined|!number>} */
+ var result_map;
+ /** @type {Array.<undefined|!number>} */
+ var result;
+ /** @type {Array.<undefined|!number>} */
+ 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.<undefined|!string>} */
+ 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.<string, undefined|!string>} 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.<string, undefined|Array.<undefined|!string>>} 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, "<br/>").replace(/&/g, "&amp;").replace(/"/g, "&quot;").replace(/</g, "&lt;").replace(/>/g, "&gt;");
+};
+
+var _HTMLHandler$escapeHTML$S = _HTMLHandler.escapeHTML$S;
+
+/**
+ * @param {!string} tagname
+ * @param {Object.<string, undefined|!string>} 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 += "</" + c;
+ this.state = (_State.SCRIPT | 0);
+ } else {
+ this.strictFail$S("Invalid tagname in closing tag.");
+ }
+ } else {
+ this.tagName = c;
+ }
+ }
+ } else {
+ if (c === ">") {
+ this.closeTag$();
+ } else {
+ if (_.is$LRegExp$S(_.nameBody, c)) {
+ this.tagName += c;
+ } else {
+ if (this.script) {
+ this.script += "</" + this.tagName;
+ this.tagName = "";
+ this.state = (_State.SCRIPT | 0);
+ } else {
+ if (_.not$HBS(_.whitespace, c)) {
+ this.strictFail$S("Invalid tagname in closing tag");
+ }
+ this.state = (_State.CLOSE_TAG_SAW_WHITE | 0);
+ }
+ }
+ }
+ }
+ continue;
+ case _State.CLOSE_TAG_SAW_WHITE:
+ if (_.is$HBS(_.whitespace, c)) {
+ continue;
+ }
+ if (c === ">") {
+ 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.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.tagName + ">";
+ 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.<string, undefined|!boolean>}
+ */
+Char.prototype._charClass$S = function (str) {
+ /** @type {Object.<string, undefined|!boolean>} */
+ 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.<string, undefined|!boolean>} 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.<string, undefined|!boolean>} 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.<string, undefined|!string>}
+ */
+_Entities.entity_list$ = function () {
+ /** @type {Object.<string, undefined|!string>} */
+ 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.<undefined|!string>} */
+ 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.<undefined|!string>} */
+ 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.<string, undefined|!number>} */
+ var range_tmp;
+ /** @type {!number} */
+ var code;
+ /** @type {!boolean} */
+ var bit;
+ /** @type {!number} */
+ var key;
+ /** @type {Object.<string, undefined|!number>} */
+ 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.<undefined|!string>} */
+ var contents;
+ /** @type {!number} */
+ var i;
+ /** @type {Array.<undefined|!string>} */
+ 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.<undefined|!string>} */
+ var contents;
+ /** @type {!number} */
+ var i;
+ /** @type {Array.<undefined|!string>} */
+ 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.<string, undefined|!number>} input
+ * @return {Object.<string, undefined|!number>}
+ */
+WaveletMatrix._shallow_copy$HI = function (input) {
+ /** @type {Object.<string, undefined|!number>} */
+ 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.<undefined|!string>} */
+ 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.<undefined|!number>} array
+ */
+function OArray$AI(array) {
+ this.array = array;
+ this.offset = 0;
+};
+
+OArray$AI.prototype = new OArray;
+
+/**
+ * @constructor
+ * @param {Array.<undefined|!number>} 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.<undefined|!number>} 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.<undefined|!number>} SA
+ * @param {OArray} s
+ * @param {Array.<undefined|!number>} 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.<undefined|!number>} SA
+ * @param {OArray} s
+ * @param {Array.<undefined|!number>} 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.<undefined|!number>}
+ */
+SAIS.make$S = function (source) {
+ /** @type {Array.<undefined|!number>} */
+ var charCodes;
+ /** @type {!number} */
+ var maxCode;
+ /** @type {!number} */
+ var i;
+ /** @type {!number} */
+ var code;
+ /** @type {Array.<undefined|!number>} */
+ 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.<undefined|!number>} 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.<undefined|!number>} */
+ 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.<undefined|!number>} */
+ 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': [ '<span class="title">', '</span>' ], 'url': [ '<span class="url">', '</span>' ], 'hit': [ '<span class="hit">', '</span>' ], 'del': [ '<del>', '</del>' ], 'summary': [ '<span class="reuslt">', '</span>' ] });
+});
+$__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);