lava-oushudb-dt-sql-parser/core/comment.js

1072 lines
30 KiB
JavaScript
Raw Normal View History

2018-07-05 11:16:30 +08:00
module.exports = (function(){
/*
* Generated by PEG.js 0.7.0.
*
* http://pegjs.majda.cz/
*/
function quote(s) {
/*
* ECMA-262, 5th ed., 7.8.4: All characters may appear literally in a
* string literal except for the closing quote character, backslash,
* carriage return, line separator, paragraph separator, and line feed.
* Any character may appear in the form of an escape sequence.
*
* For portability, we also escape escape all control and non-ASCII
* characters. Note that "\0" and "\v" escape sequences are not used
* because JSHint does not like the first and IE the second.
*/
return '"' + s
.replace(/\\/g, '\\\\') // backslash
.replace(/"/g, '\\"') // closing quote character
.replace(/\x08/g, '\\b') // backspace
.replace(/\t/g, '\\t') // horizontal tab
.replace(/\n/g, '\\n') // line feed
.replace(/\f/g, '\\f') // form feed
.replace(/\r/g, '\\r') // carriage return
.replace(/[\x00-\x07\x0B\x0E-\x1F\x80-\uFFFF]/g, escape)
+ '"';
}
var result = {
/*
* Parses the input with a generated parser. If the parsing is successfull,
* returns a value explicitly or implicitly specified by the grammar from
* which the parser was generated (see |PEG.buildParser|). If the parsing is
* unsuccessful, throws |PEG.parser.SyntaxError| describing the error.
*/
parse: function(input, startRule) {
var parseFunctions = {
"start": parse_start,
"union_stmt": parse_union_stmt,
"comment": parse_comment,
"singleLine": parse_singleLine,
"multiLine": parse_multiLine,
"quote": parse_quote,
"kw_start": parse_kw_start,
"KW_SINGLE_LINE_START": parse_KW_SINGLE_LINE_START,
"KW_SINGLE_LINE_END": parse_KW_SINGLE_LINE_END,
"KW_MULTI_LINE_START": parse_KW_MULTI_LINE_START,
"KW_MULTI_LINE_END": parse_KW_MULTI_LINE_END,
"__": parse___,
"whitespace": parse_whitespace
};
if (startRule !== undefined) {
if (parseFunctions[startRule] === undefined) {
throw new Error("Invalid rule name: " + quote(startRule) + ".");
}
} else {
startRule = "start";
}
var pos = 0;
var reportFailures = 0;
var rightmostFailuresPos = 0;
var rightmostFailuresExpected = [];
function padLeft(input, padding, length) {
var result = input;
var padLength = length - input.length;
for (var i = 0; i < padLength; i++) {
result = padding + result;
}
return result;
}
function escape(ch) {
var charCode = ch.charCodeAt(0);
var escapeChar;
var length;
if (charCode <= 0xFF) {
escapeChar = 'x';
length = 2;
} else {
escapeChar = 'u';
length = 4;
}
return '\\' + escapeChar + padLeft(charCode.toString(16).toUpperCase(), '0', length);
}
function matchFailed(failure) {
if (pos < rightmostFailuresPos) {
return;
}
if (pos > rightmostFailuresPos) {
rightmostFailuresPos = pos;
rightmostFailuresExpected = [];
}
rightmostFailuresExpected.push(failure);
}
function parse_start() {
var result0;
var pos0;
pos0 = pos;
result0 = parse_union_stmt();
if (result0 !== null) {
result0 = (function(offset, union_stmt) {
2018-07-06 16:22:57 +08:00
return {lines,text:union_stmt};
2018-07-05 11:16:30 +08:00
})(pos0, result0);
}
if (result0 === null) {
pos = pos0;
}
return result0;
}
function parse_union_stmt() {
var result0, result1, result2, result3;
var pos0, pos1, pos2, pos3, pos4, pos5, pos6;
pos0 = pos;
pos1 = pos;
result0 = [];
pos2 = pos;
pos3 = pos;
result1 = [];
pos4 = pos;
pos5 = pos;
pos6 = pos;
reportFailures++;
result2 = parse_kw_start();
reportFailures--;
if (result2 === null) {
result2 = "";
} else {
result2 = null;
pos = pos6;
}
if (result2 !== null) {
if (input.length > pos) {
result3 = input.charAt(pos);
pos++;
} else {
result3 = null;
if (reportFailures === 0) {
matchFailed("any character");
}
}
if (result3 !== null) {
result2 = [result2, result3];
} else {
result2 = null;
pos = pos5;
}
} else {
result2 = null;
pos = pos5;
}
if (result2 !== null) {
result2 = (function(offset, word) {return word})(pos4, result2[1]);
}
if (result2 === null) {
pos = pos4;
}
while (result2 !== null) {
result1.push(result2);
pos4 = pos;
pos5 = pos;
pos6 = pos;
reportFailures++;
result2 = parse_kw_start();
reportFailures--;
if (result2 === null) {
result2 = "";
} else {
result2 = null;
pos = pos6;
}
if (result2 !== null) {
if (input.length > pos) {
result3 = input.charAt(pos);
pos++;
} else {
result3 = null;
if (reportFailures === 0) {
matchFailed("any character");
}
}
if (result3 !== null) {
result2 = [result2, result3];
} else {
result2 = null;
pos = pos5;
}
} else {
result2 = null;
pos = pos5;
}
if (result2 !== null) {
result2 = (function(offset, word) {return word})(pos4, result2[1]);
}
if (result2 === null) {
pos = pos4;
}
}
if (result1 !== null) {
pos4 = pos;
result2 = parse_comment();
if (result2 !== null) {
result2 = (function(offset, comment) {return ''})(pos4, result2);
}
if (result2 === null) {
pos = pos4;
}
if (result2 === null) {
pos4 = pos;
result2 = parse_quote();
if (result2 !== null) {
result2 = (function(offset, quote) {return quote})(pos4, result2);
}
if (result2 === null) {
pos = pos4;
}
2018-07-06 16:22:57 +08:00
if (result2 === null) {
pos4 = pos;
if (input.charCodeAt(pos) === 59) {
result2 = ";";
pos++;
} else {
result2 = null;
if (reportFailures === 0) {
matchFailed("\";\"");
}
}
if (result2 !== null) {
result2 = (function(offset) {isSplit=true;return ";"})(pos4);
}
if (result2 === null) {
pos = pos4;
}
}
2018-07-05 11:16:30 +08:00
}
if (result2 !== null) {
result1 = [result1, result2];
} else {
result1 = null;
pos = pos3;
}
} else {
result1 = null;
pos = pos3;
}
if (result1 !== null) {
2018-07-06 16:22:57 +08:00
result1 = (function(offset, words, stmt) {
const text=words.join("")+stmt;
let index=Math.max(lines.length-1,0);
lines[index]=(lines[index]||'')+text;
if(isSplit){
isSplit=false;
lines.push('');
}
return text;
})(pos2, result1[0], result1[1]);
2018-07-05 11:16:30 +08:00
}
if (result1 === null) {
pos = pos2;
}
while (result1 !== null) {
result0.push(result1);
pos2 = pos;
pos3 = pos;
result1 = [];
pos4 = pos;
pos5 = pos;
pos6 = pos;
reportFailures++;
result2 = parse_kw_start();
reportFailures--;
if (result2 === null) {
result2 = "";
} else {
result2 = null;
pos = pos6;
}
if (result2 !== null) {
if (input.length > pos) {
result3 = input.charAt(pos);
pos++;
} else {
result3 = null;
if (reportFailures === 0) {
matchFailed("any character");
}
}
if (result3 !== null) {
result2 = [result2, result3];
} else {
result2 = null;
pos = pos5;
}
} else {
result2 = null;
pos = pos5;
}
if (result2 !== null) {
result2 = (function(offset, word) {return word})(pos4, result2[1]);
}
if (result2 === null) {
pos = pos4;
}
while (result2 !== null) {
result1.push(result2);
pos4 = pos;
pos5 = pos;
pos6 = pos;
reportFailures++;
result2 = parse_kw_start();
reportFailures--;
if (result2 === null) {
result2 = "";
} else {
result2 = null;
pos = pos6;
}
if (result2 !== null) {
if (input.length > pos) {
result3 = input.charAt(pos);
pos++;
} else {
result3 = null;
if (reportFailures === 0) {
matchFailed("any character");
}
}
if (result3 !== null) {
result2 = [result2, result3];
} else {
result2 = null;
pos = pos5;
}
} else {
result2 = null;
pos = pos5;
}
if (result2 !== null) {
result2 = (function(offset, word) {return word})(pos4, result2[1]);
}
if (result2 === null) {
pos = pos4;
}
}
if (result1 !== null) {
pos4 = pos;
result2 = parse_comment();
if (result2 !== null) {
result2 = (function(offset, comment) {return ''})(pos4, result2);
}
if (result2 === null) {
pos = pos4;
}
if (result2 === null) {
pos4 = pos;
result2 = parse_quote();
if (result2 !== null) {
result2 = (function(offset, quote) {return quote})(pos4, result2);
}
if (result2 === null) {
pos = pos4;
}
2018-07-06 16:22:57 +08:00
if (result2 === null) {
pos4 = pos;
if (input.charCodeAt(pos) === 59) {
result2 = ";";
pos++;
} else {
result2 = null;
if (reportFailures === 0) {
matchFailed("\";\"");
}
}
if (result2 !== null) {
result2 = (function(offset) {isSplit=true;return ";"})(pos4);
}
if (result2 === null) {
pos = pos4;
}
}
2018-07-05 11:16:30 +08:00
}
if (result2 !== null) {
result1 = [result1, result2];
} else {
result1 = null;
pos = pos3;
}
} else {
result1 = null;
pos = pos3;
}
if (result1 !== null) {
2018-07-06 16:22:57 +08:00
result1 = (function(offset, words, stmt) {
const text=words.join("")+stmt;
let index=Math.max(lines.length-1,0);
lines[index]=(lines[index]||'')+text;
if(isSplit){
isSplit=false;
lines.push('');
}
return text;
})(pos2, result1[0], result1[1]);
2018-07-05 11:16:30 +08:00
}
if (result1 === null) {
pos = pos2;
}
}
if (result0 !== null) {
result1 = [];
if (input.length > pos) {
result2 = input.charAt(pos);
pos++;
} else {
result2 = null;
if (reportFailures === 0) {
matchFailed("any character");
}
}
while (result2 !== null) {
result1.push(result2);
if (input.length > pos) {
result2 = input.charAt(pos);
pos++;
} else {
result2 = null;
if (reportFailures === 0) {
matchFailed("any character");
}
}
}
if (result1 !== null) {
result0 = [result0, result1];
} else {
result0 = null;
pos = pos1;
}
} else {
result0 = null;
pos = pos1;
}
if (result0 !== null) {
2018-07-06 16:22:57 +08:00
result0 = (function(offset, stmt, other) {
const text=stmt.join("")+other.join("")
let index=Math.max(lines.length-1,0);
lines[index]=lines[index]+other.join("");
return text;
})(pos0, result0[0], result0[1]);
2018-07-05 11:16:30 +08:00
}
if (result0 === null) {
pos = pos0;
}
return result0;
}
function parse_comment() {
var result0;
var pos0;
pos0 = pos;
result0 = parse_multiLine();
if (result0 === null) {
result0 = parse_singleLine();
}
if (result0 !== null) {
result0 = (function(offset, comment) {
return comment;
})(pos0, result0);
}
if (result0 === null) {
pos = pos0;
}
return result0;
}
function parse_singleLine() {
var result0, result1, result2;
var pos0, pos1;
pos0 = pos;
pos1 = pos;
result0 = parse_KW_SINGLE_LINE_START();
if (result0 !== null) {
result1 = [];
if (/^[^\r\n]/.test(input.charAt(pos))) {
result2 = input.charAt(pos);
pos++;
} else {
result2 = null;
if (reportFailures === 0) {
matchFailed("[^\\r\\n]");
}
}
while (result2 !== null) {
result1.push(result2);
if (/^[^\r\n]/.test(input.charAt(pos))) {
result2 = input.charAt(pos);
pos++;
} else {
result2 = null;
if (reportFailures === 0) {
matchFailed("[^\\r\\n]");
}
}
}
if (result1 !== null) {
result0 = [result0, result1];
} else {
result0 = null;
pos = pos1;
}
} else {
result0 = null;
pos = pos1;
}
if (result0 !== null) {
result0 = (function(offset, start, words) {
return start+words.join("")
})(pos0, result0[0], result0[1]);
}
if (result0 === null) {
pos = pos0;
}
return result0;
}
function parse_multiLine() {
var result0, result1, result2, result3;
var pos0, pos1, pos2, pos3, pos4;
pos0 = pos;
pos1 = pos;
result0 = parse_KW_MULTI_LINE_START();
if (result0 !== null) {
result1 = [];
pos2 = pos;
pos3 = pos;
pos4 = pos;
reportFailures++;
if (input.substr(pos, 2) === "*/") {
result2 = "*/";
pos += 2;
} else {
result2 = null;
if (reportFailures === 0) {
matchFailed("\"*/\"");
}
}
reportFailures--;
if (result2 === null) {
result2 = "";
} else {
result2 = null;
pos = pos4;
}
if (result2 !== null) {
if (input.length > pos) {
result3 = input.charAt(pos);
pos++;
} else {
result3 = null;
if (reportFailures === 0) {
matchFailed("any character");
}
}
if (result3 !== null) {
result2 = [result2, result3];
} else {
result2 = null;
pos = pos3;
}
} else {
result2 = null;
pos = pos3;
}
if (result2 !== null) {
result2 = (function(offset, word) {return word })(pos2, result2[1]);
}
if (result2 === null) {
pos = pos2;
}
while (result2 !== null) {
result1.push(result2);
pos2 = pos;
pos3 = pos;
pos4 = pos;
reportFailures++;
if (input.substr(pos, 2) === "*/") {
result2 = "*/";
pos += 2;
} else {
result2 = null;
if (reportFailures === 0) {
matchFailed("\"*/\"");
}
}
reportFailures--;
if (result2 === null) {
result2 = "";
} else {
result2 = null;
pos = pos4;
}
if (result2 !== null) {
if (input.length > pos) {
result3 = input.charAt(pos);
pos++;
} else {
result3 = null;
if (reportFailures === 0) {
matchFailed("any character");
}
}
if (result3 !== null) {
result2 = [result2, result3];
} else {
result2 = null;
pos = pos3;
}
} else {
result2 = null;
pos = pos3;
}
if (result2 !== null) {
result2 = (function(offset, word) {return word })(pos2, result2[1]);
}
if (result2 === null) {
pos = pos2;
}
}
if (result1 !== null) {
result2 = parse_KW_MULTI_LINE_END();
if (result2 !== null) {
result0 = [result0, result1, result2];
} else {
result0 = null;
pos = pos1;
}
} else {
result0 = null;
pos = pos1;
}
} else {
result0 = null;
pos = pos1;
}
if (result0 !== null) {
result0 = (function(offset, start, words, end) {return start+words.join("")+end })(pos0, result0[0], result0[1], result0[2]);
}
if (result0 === null) {
pos = pos0;
}
return result0;
}
function parse_quote() {
var result0, result1, result2;
var pos0, pos1;
pos0 = pos;
pos1 = pos;
if (input.charCodeAt(pos) === 34) {
result0 = "\"";
pos++;
} else {
result0 = null;
if (reportFailures === 0) {
matchFailed("\"\\\"\"");
}
}
if (result0 !== null) {
result1 = [];
if (/^[^"]/.test(input.charAt(pos))) {
result2 = input.charAt(pos);
pos++;
} else {
result2 = null;
if (reportFailures === 0) {
matchFailed("[^\"]");
}
}
while (result2 !== null) {
result1.push(result2);
if (/^[^"]/.test(input.charAt(pos))) {
result2 = input.charAt(pos);
pos++;
} else {
result2 = null;
if (reportFailures === 0) {
matchFailed("[^\"]");
}
}
}
if (result1 !== null) {
if (input.charCodeAt(pos) === 34) {
result2 = "\"";
pos++;
} else {
result2 = null;
if (reportFailures === 0) {
matchFailed("\"\\\"\"");
}
}
if (result2 !== null) {
result0 = [result0, result1, result2];
} else {
result0 = null;
pos = pos1;
}
} else {
result0 = null;
pos = pos1;
}
} else {
result0 = null;
pos = pos1;
}
if (result0 !== null) {
result0 = (function(offset, start, words, end) {return start+words.join("")+end;})(pos0, result0[0], result0[1], result0[2]);
}
if (result0 === null) {
pos = pos0;
}
if (result0 === null) {
pos0 = pos;
pos1 = pos;
if (input.charCodeAt(pos) === 39) {
result0 = "'";
pos++;
} else {
result0 = null;
if (reportFailures === 0) {
matchFailed("\"'\"");
}
}
if (result0 !== null) {
result1 = [];
if (/^[^']/.test(input.charAt(pos))) {
result2 = input.charAt(pos);
pos++;
} else {
result2 = null;
if (reportFailures === 0) {
matchFailed("[^']");
}
}
while (result2 !== null) {
result1.push(result2);
if (/^[^']/.test(input.charAt(pos))) {
result2 = input.charAt(pos);
pos++;
} else {
result2 = null;
if (reportFailures === 0) {
matchFailed("[^']");
}
}
}
if (result1 !== null) {
if (input.charCodeAt(pos) === 39) {
result2 = "'";
pos++;
} else {
result2 = null;
if (reportFailures === 0) {
matchFailed("\"'\"");
}
}
if (result2 !== null) {
result0 = [result0, result1, result2];
} else {
result0 = null;
pos = pos1;
}
} else {
result0 = null;
pos = pos1;
}
} else {
result0 = null;
pos = pos1;
}
if (result0 !== null) {
result0 = (function(offset, start, words, end) {return start+words.join("")+end;})(pos0, result0[0], result0[1], result0[2]);
}
if (result0 === null) {
pos = pos0;
}
}
return result0;
}
function parse_kw_start() {
var result0;
result0 = parse_KW_SINGLE_LINE_START();
if (result0 === null) {
result0 = parse_KW_MULTI_LINE_START();
if (result0 === null) {
if (input.charCodeAt(pos) === 34) {
result0 = "\"";
pos++;
} else {
result0 = null;
if (reportFailures === 0) {
matchFailed("\"\\\"\"");
}
}
if (result0 === null) {
if (input.charCodeAt(pos) === 39) {
result0 = "'";
pos++;
} else {
result0 = null;
if (reportFailures === 0) {
matchFailed("\"'\"");
}
}
2018-07-06 16:22:57 +08:00
if (result0 === null) {
if (input.charCodeAt(pos) === 59) {
result0 = ";";
pos++;
} else {
result0 = null;
if (reportFailures === 0) {
matchFailed("\";\"");
}
}
}
2018-07-05 11:16:30 +08:00
}
}
}
return result0;
}
function parse_KW_SINGLE_LINE_START() {
var result0;
if (input.substr(pos, 2) === "--") {
result0 = "--";
pos += 2;
} else {
result0 = null;
if (reportFailures === 0) {
matchFailed("\"--\"");
}
}
return result0;
}
function parse_KW_SINGLE_LINE_END() {
var result0;
if (/^[\r\n]/.test(input.charAt(pos))) {
result0 = input.charAt(pos);
pos++;
} else {
result0 = null;
if (reportFailures === 0) {
matchFailed("[\\r\\n]");
}
}
return result0;
}
function parse_KW_MULTI_LINE_START() {
var result0;
if (input.substr(pos, 2) === "/*") {
result0 = "/*";
pos += 2;
} else {
result0 = null;
if (reportFailures === 0) {
matchFailed("\"/*\"");
}
}
return result0;
}
function parse_KW_MULTI_LINE_END() {
var result0;
if (input.substr(pos, 2) === "*/") {
result0 = "*/";
pos += 2;
} else {
result0 = null;
if (reportFailures === 0) {
matchFailed("\"*/\"");
}
}
return result0;
}
function parse___() {
var result0, result1;
result0 = [];
result1 = parse_whitespace();
while (result1 !== null) {
result0.push(result1);
result1 = parse_whitespace();
}
return result0;
}
function parse_whitespace() {
var result0;
if (/^[ \t\r\n]/.test(input.charAt(pos))) {
result0 = input.charAt(pos);
pos++;
} else {
result0 = null;
if (reportFailures === 0) {
matchFailed("[ \\t\\r\\n]");
}
}
return result0;
}
function cleanupExpected(expected) {
expected.sort();
var lastExpected = null;
var cleanExpected = [];
for (var i = 0; i < expected.length; i++) {
if (expected[i] !== lastExpected) {
cleanExpected.push(expected[i]);
lastExpected = expected[i];
}
}
return cleanExpected;
}
function computeErrorPosition() {
/*
* The first idea was to use |String.split| to break the input up to the
* error position along newlines and derive the line and column from
* there. However IE's |split| implementation is so broken that it was
* enough to prevent it.
*/
var line = 1;
var column = 1;
var seenCR = false;
for (var i = 0; i < Math.max(pos, rightmostFailuresPos); i++) {
var ch = input.charAt(i);
if (ch === "\n") {
if (!seenCR) { line++; }
column = 1;
seenCR = false;
} else if (ch === "\r" || ch === "\u2028" || ch === "\u2029") {
line++;
column = 1;
seenCR = true;
} else {
column++;
seenCR = false;
}
}
return { line: line, column: column };
}
2018-07-06 16:22:57 +08:00
let lines=[];
let isSplit=false;
2018-07-05 11:16:30 +08:00
var result = parseFunctions[startRule]();
/*
* The parser is now in one of the following three states:
*
* 1. The parser successfully parsed the whole input.
*
* - |result !== null|
* - |pos === input.length|
* - |rightmostFailuresExpected| may or may not contain something
*
* 2. The parser successfully parsed only a part of the input.
*
* - |result !== null|
* - |pos < input.length|
* - |rightmostFailuresExpected| may or may not contain something
*
* 3. The parser did not successfully parse any part of the input.
*
* - |result === null|
* - |pos === 0|
* - |rightmostFailuresExpected| contains at least one failure
*
* All code following this comment (including called functions) must
* handle these states.
*/
if (result === null || pos !== input.length) {
var offset = Math.max(pos, rightmostFailuresPos);
var found = offset < input.length ? input.charAt(offset) : null;
var errorPosition = computeErrorPosition();
throw new this.SyntaxError(
cleanupExpected(rightmostFailuresExpected),
found,
offset,
errorPosition.line,
errorPosition.column
);
}
return result;
},
/* Returns the parser source code. */
toSource: function() { return this._source; }
};
/* Thrown when a parser encounters a syntax error. */
result.SyntaxError = function(expected, found, offset, line, column) {
function buildMessage(expected, found) {
var expectedHumanized, foundHumanized;
switch (expected.length) {
case 0:
expectedHumanized = "end of input";
break;
case 1:
expectedHumanized = expected[0];
break;
default:
expectedHumanized = expected.slice(0, expected.length - 1).join(", ")
+ " or "
+ expected[expected.length - 1];
}
foundHumanized = found ? quote(found) : "end of input";
return "Expected " + expectedHumanized + " but " + foundHumanized + " found.";
}
this.name = "SyntaxError";
this.expected = expected;
this.found = found;
this.message = buildMessage(expected, found);
this.offset = offset;
this.line = line;
this.column = column;
};
result.SyntaxError.prototype = Error.prototype;
return result;
})();