Skip to content

Instantly share code, notes, and snippets.

@cevek
Last active October 19, 2016 07:40
Show Gist options
  • Save cevek/1489482a35203731c7bb800907368db2 to your computer and use it in GitHub Desktop.
Save cevek/1489482a35203731c7bb800907368db2 to your computer and use it in GitHub Desktop.
const esprima = require('esprima');
const recast = require('recast');
const fs = require('fs');
var acorn = require("acorn");
var escodegen = require("escodegen");
var babylon = require("babylon");
var cst = require("cst");
var browserify = require('browserify');
var b = browserify();
const code = fs.readFileSync('ang.js', 'utf8');
const code2 = fs.readFileSync('ang.js');
const testCode = 'const a=1; let b="" && 1 || 0 & 2 | 7 % 10 * 10 + (1 < 4 - 1 > 3); var c=u ? (``, 1) : 2; for(let i=0; i<--g; i++){d.a()} while(a-- == d && f === d); const f = ()=>null; const {d,ds = 2} = dsf; d = d => ({d}); function x(a){}';
function abc() {
const str = 'abc;/*a*///b\n/a/';
for (let i = 0; i < 1000; i++) {
// esprima.parse(testCode, {range: true});
// esprima.tokenize(testCode);
parseStr(str, isRequere);
extractRequere([])
}
console.time('perf');
// parse();
// parseRecast();
// parseBabylon()
// parseCst();
// parseBrowserify();
// parseAcorn();
for (let i = 0; i < 10; i++) {
var r = parseStr(code, isRequere);
}
// parseBuffer()
console.timeEnd('perf');
// console.log(r);
extractRequere(r);
console.log(r.length / 3);
}
function prettyPrintParseResult(code, r) {
for (let i = 0; i < r.length; i += 3) {
const s = code.substring(r[i + 1], r[i + 2]);
if (r[i] === 1) {
console.log('id', s);
}
if (r[i] === 2) {
console.log('st', s);
}
if (r[i] === 5) {
console.log('lc', s);
}
if (r[i] === 6) {
console.log('bc', s);
}
if (r[i] === 8) {
console.log('re', s);
}
}
}
function isRequere(code, start, size, startSymbolCode) {
if (size === 7 && startSymbolCode === 114/*r*/ && code.substr(start, size) === 'require') {
return true;
}
return false;
}
function extractRequere(r) {
const len = r.length;
var start = 0;
var end = 0;
for (var i = 0; i < len; i += 3) {
if (r[i] === 1 /*identifier*/) {
start = r[i + 1];
end = r[i + 2];
if (end - start === 7 && code[start] === 'r' && code.substring(start, end) === 'require' && code[end] == '(' && code[start - 1] !== '.' && r[i + 3] === 2 /*string*/) {
console.log(code.substring(r[i + 4], r[i + 5]));
}
}
}
}
function patternAllMatcher() {
return true;
}
function parseRecast() {
return recast.parse(code);
}
function parseAcorn() {
return escodegen.generate(acorn.parse(code, {ranges: true}));
}
function parseBabylon() {
return babylon.parse(code);
}
function parseCst() {
return new cst.Parser().parse(code);
}
function parseBuffer() {
"use strict";
let x = 0;
for (let i = 0; i < code2.length; i++) {
x = code2[i];
}
return x;
}
function parseBrowserify() {
"use strict";
b.add('./ang.js');
b.bundle().pipe(process.stdout);
}
function boom() {
"use strict";
//
/**/
42
//hello
/*
* My names is boy
* // deep comment
*/
/*continue*/
const abc = 2;
/*//comment in comment
* */
var x = 'Ya\'p';
var d = "Hello \\";
var e = "Hello \\\" world";
var x1 = /\/*/;
var y1 = /\//;
var y1 = /\\\//;
var z1 = /\\///comment
var zz = /[/]/;
var zz = /[\/]/;
var zz = /[\]//]/;
var zr = /[/*]/;
var zr = /\\[/*]/
var zr = /\\[\]/*]/
var zr = /\\[\\\]/*]/
var zr = /'/;
var zr = /`/;
x /= 1;
var y = x / 1;
x
/ 1;
a / /ra/
a(/ru/)
a % /rb/
a ^ /rc/
a & /rd/
a - /re/
a + /rf/
var f = /rg/
a[/rh/]
[a] / a
a;
/rj/
a : /rk/
a , /rl/
a * /rm/
a < /rn/
a == /rp/
a ? /rr/ : 1
a | /rs/
a || /rt/
var h = `Man in the sky
and fif around // to be or not to be
/* not a comment */
escape \` or not escape \\\`
${ literalInTheMiddle + `string in${we + `need to go deeper`}the middle` }
`;
return /ret/
}
const tests = [['st', '"use strict"'],
['lc', '//\n'],
['bc', '/**/'],
['lc', '//hello\n'],
['bc',
'/*\n * My names is boy\n * // deep comment\n */'],
['bc', '/*continue*/'],
['bc', '/*//comment in comment\n * */'],
['st', '\'Ya\\\'p\''],
['st', '"Hello \\\\"'],
['st', '"Hello \\\\\\" world"'],
['re', '/\\/*/'],
['re', '/\\//'],
['re', '/\\\\\\//'],
['re', '/\\\\/'],
['re', '/comment\n var zz = /'],
['re', '/]/'],
['re', '/[\\/]/'],
['re', '/[\\]//]/'],
['re', '/[/*]/'],
['re', '/\\\\[/*]/'],
['re', '/\\\\[\\]/*]/'],
['re', '/\\\\[\\\\\\]/*]/'],
['re', '/\'/'],
['re', '/`/'],
['re', '/ru/'],
['re', '/rb/'],
['re', '/rc/'],
['re', '/rd/'],
['re', '/re/'],
['re', '/rf/'],
['re', '/rg/'],
['re', '/rh/'],
['re', '/rk/'],
['re', '/rl/'],
['re', '/rm/'],
['re', '/rn/'],
['re', '/rp/'],
['re', '/rr/'],
['re', '/rs/'],
['re', '/rt/'],
['st',
'`Man in the sky\nand fif around // to be or not to be \n/* not a comment */\nescape \\` or not escape \\\\\\` \n\n`']]
// parseStr('/1//2//3')
const parseStr = require('./parser');
const testCode2 = boom.toString();
prettyPrintParseResult(testCode2, parseStr(testCode2, patternAllMatcher));
// parseStr('/1///comment\n"boom"');
const x = 'hello; //23;';
function parse() {
"use strict";
escodegen.generate(esprima.parse(code, {range: true}));
// esprima.parse(code);
}
/*
function scanRegExpBody(codeD, i) {
let ch = codeD[i];
i++;
let classMarker = false;
let terminated = false;
while (i < len) {
ch = source[i++];
if (ch === '\\') {
ch = source[i++];
} else if (classMarker) {
if (ch === ']') {
classMarker = false;
}
} else {
if (ch === '/') {
terminated = true;
break;
} else if (ch === '[') {
classMarker = true;
}
}
}
};
function scanRegExpFlags() {
let str = '';
let flags = '';
while (!this.eof()) {
let ch = this.source[this.index];
if (!Character.isIdentifierPart(ch.charCodeAt(0))) {
break;
}
++this.index;
if (ch === '\\' && !this.eof()) {
ch = this.source[this.index];
if (ch === 'u') {
++this.index;
let restore = this.index;
ch = this.scanHexEscape('u');
if (ch) {
flags += ch;
for (str += '\\u'; restore < this.index; ++restore) {
str += this.source[restore];
}
} else {
this.index = restore;
flags += 'u';
str += '\\u';
}
this.tolerateUnexpectedToken();
} else {
str += '\\';
this.tolerateUnexpectedToken();
}
} else {
flags += ch;
str += ch;
}
}
return {
value: flags,
literal: str
};
};
*/
abc();
let Regex = {
// Unicode v8.0.0 NonAsciiIdentifierStart:
NonAsciiIdentifierStart: /[\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u05D0-\u05EA\u05F0-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u08A0-\u08B4\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0AF9\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58-\u0C5A\u0C60\u0C61\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D5F-\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1711\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u1820-\u1877\u1880-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u1A00-\u1A16\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1CE9-\u1CEC\u1CEE-\u1CF1\u1CF5\u1CF6\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2118-\u211D\u2124\u2126\u2128\u212A-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u3005-\u3007\u3021-\u3029\u3031-\u3035\u3038-\u303C\u3041-\u3096\u309B-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312D\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FD5\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6EF\uA717-\uA71F\uA722-\uA788\uA78B-\uA7AD\uA7B0-\uA7B7\uA7F7-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA8FD\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uA9E0-\uA9E4\uA9E6-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB65\uAB70-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDD40-\uDD74\uDE80-\uDE9C\uDEA0-\uDED0\uDF00-\uDF1F\uDF30-\uDF4A\uDF50-\uDF75\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF\uDFD1-\uDFD5]|\uD801[\uDC00-\uDC9D\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDCE0-\uDCF2\uDCF4\uDCF5\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00\uDE10-\uDE13\uDE15-\uDE17\uDE19-\uDE33\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE4\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48\uDC80-\uDCB2\uDCC0-\uDCF2]|\uD804[\uDC03-\uDC37\uDC83-\uDCAF\uDCD0-\uDCE8\uDD03-\uDD26\uDD50-\uDD72\uDD76\uDD83-\uDDB2\uDDC1-\uDDC4\uDDDA\uDDDC\uDE00-\uDE11\uDE13-\uDE2B\uDE80-\uDE86\uDE88\uDE8A-\uDE8D\uDE8F-\uDE9D\uDE9F-\uDEA8\uDEB0-\uDEDE\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3D\uDF50\uDF5D-\uDF61]|\uD805[\uDC80-\uDCAF\uDCC4\uDCC5\uDCC7\uDD80-\uDDAE\uDDD8-\uDDDB\uDE00-\uDE2F\uDE44\uDE80-\uDEAA\uDF00-\uDF19]|\uD806[\uDCA0-\uDCDF\uDCFF\uDEC0-\uDEF8]|\uD808[\uDC00-\uDF99]|\uD809[\uDC00-\uDC6E\uDC80-\uDD43]|[\uD80C\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD811[\uDC00-\uDE46]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDED0-\uDEED\uDF00-\uDF2F\uDF40-\uDF43\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDF00-\uDF44\uDF50\uDF93-\uDF9F]|\uD82C[\uDC00\uDC01]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB]|\uD83A[\uDC00-\uDCC4]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1]|\uD87E[\uDC00-\uDE1D]/,
// Unicode v8.0.0 NonAsciiIdentifierPart:
NonAsciiIdentifierPart: /[\xAA\xB5\xB7\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0300-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u0483-\u0487\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u0591-\u05BD\u05BF\u05C1\u05C2\u05C4\u05C5\u05C7\u05D0-\u05EA\u05F0-\u05F2\u0610-\u061A\u0620-\u0669\u066E-\u06D3\u06D5-\u06DC\u06DF-\u06E8\u06EA-\u06FC\u06FF\u0710-\u074A\u074D-\u07B1\u07C0-\u07F5\u07FA\u0800-\u082D\u0840-\u085B\u08A0-\u08B4\u08E3-\u0963\u0966-\u096F\u0971-\u0983\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BC-\u09C4\u09C7\u09C8\u09CB-\u09CE\u09D7\u09DC\u09DD\u09DF-\u09E3\u09E6-\u09F1\u0A01-\u0A03\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A3C\u0A3E-\u0A42\u0A47\u0A48\u0A4B-\u0A4D\u0A51\u0A59-\u0A5C\u0A5E\u0A66-\u0A75\u0A81-\u0A83\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABC-\u0AC5\u0AC7-\u0AC9\u0ACB-\u0ACD\u0AD0\u0AE0-\u0AE3\u0AE6-\u0AEF\u0AF9\u0B01-\u0B03\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3C-\u0B44\u0B47\u0B48\u0B4B-\u0B4D\u0B56\u0B57\u0B5C\u0B5D\u0B5F-\u0B63\u0B66-\u0B6F\u0B71\u0B82\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BBE-\u0BC2\u0BC6-\u0BC8\u0BCA-\u0BCD\u0BD0\u0BD7\u0BE6-\u0BEF\u0C00-\u0C03\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D-\u0C44\u0C46-\u0C48\u0C4A-\u0C4D\u0C55\u0C56\u0C58-\u0C5A\u0C60-\u0C63\u0C66-\u0C6F\u0C81-\u0C83\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBC-\u0CC4\u0CC6-\u0CC8\u0CCA-\u0CCD\u0CD5\u0CD6\u0CDE\u0CE0-\u0CE3\u0CE6-\u0CEF\u0CF1\u0CF2\u0D01-\u0D03\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D-\u0D44\u0D46-\u0D48\u0D4A-\u0D4E\u0D57\u0D5F-\u0D63\u0D66-\u0D6F\u0D7A-\u0D7F\u0D82\u0D83\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0DCA\u0DCF-\u0DD4\u0DD6\u0DD8-\u0DDF\u0DE6-\u0DEF\u0DF2\u0DF3\u0E01-\u0E3A\u0E40-\u0E4E\u0E50-\u0E59\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB9\u0EBB-\u0EBD\u0EC0-\u0EC4\u0EC6\u0EC8-\u0ECD\u0ED0-\u0ED9\u0EDC-\u0EDF\u0F00\u0F18\u0F19\u0F20-\u0F29\u0F35\u0F37\u0F39\u0F3E-\u0F47\u0F49-\u0F6C\u0F71-\u0F84\u0F86-\u0F97\u0F99-\u0FBC\u0FC6\u1000-\u1049\u1050-\u109D\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u135D-\u135F\u1369-\u1371\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1714\u1720-\u1734\u1740-\u1753\u1760-\u176C\u176E-\u1770\u1772\u1773\u1780-\u17D3\u17D7\u17DC\u17DD\u17E0-\u17E9\u180B-\u180D\u1810-\u1819\u1820-\u1877\u1880-\u18AA\u18B0-\u18F5\u1900-\u191E\u1920-\u192B\u1930-\u193B\u1946-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u19D0-\u19DA\u1A00-\u1A1B\u1A20-\u1A5E\u1A60-\u1A7C\u1A7F-\u1A89\u1A90-\u1A99\u1AA7\u1AB0-\u1ABD\u1B00-\u1B4B\u1B50-\u1B59\u1B6B-\u1B73\u1B80-\u1BF3\u1C00-\u1C37\u1C40-\u1C49\u1C4D-\u1C7D\u1CD0-\u1CD2\u1CD4-\u1CF6\u1CF8\u1CF9\u1D00-\u1DF5\u1DFC-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u200C\u200D\u203F\u2040\u2054\u2071\u207F\u2090-\u209C\u20D0-\u20DC\u20E1\u20E5-\u20F0\u2102\u2107\u210A-\u2113\u2115\u2118-\u211D\u2124\u2126\u2128\u212A-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D7F-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2DE0-\u2DFF\u3005-\u3007\u3021-\u302F\u3031-\u3035\u3038-\u303C\u3041-\u3096\u3099-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312D\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FD5\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA62B\uA640-\uA66F\uA674-\uA67D\uA67F-\uA6F1\uA717-\uA71F\uA722-\uA788\uA78B-\uA7AD\uA7B0-\uA7B7\uA7F7-\uA827\uA840-\uA873\uA880-\uA8C4\uA8D0-\uA8D9\uA8E0-\uA8F7\uA8FB\uA8FD\uA900-\uA92D\uA930-\uA953\uA960-\uA97C\uA980-\uA9C0\uA9CF-\uA9D9\uA9E0-\uA9FE\uAA00-\uAA36\uAA40-\uAA4D\uAA50-\uAA59\uAA60-\uAA76\uAA7A-\uAAC2\uAADB-\uAADD\uAAE0-\uAAEF\uAAF2-\uAAF6\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB65\uAB70-\uABEA\uABEC\uABED\uABF0-\uABF9\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE00-\uFE0F\uFE20-\uFE2F\uFE33\uFE34\uFE4D-\uFE4F\uFE70-\uFE74\uFE76-\uFEFC\uFF10-\uFF19\uFF21-\uFF3A\uFF3F\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDD40-\uDD74\uDDFD\uDE80-\uDE9C\uDEA0-\uDED0\uDEE0\uDF00-\uDF1F\uDF30-\uDF4A\uDF50-\uDF7A\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF\uDFD1-\uDFD5]|\uD801[\uDC00-\uDC9D\uDCA0-\uDCA9\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDCE0-\uDCF2\uDCF4\uDCF5\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00-\uDE03\uDE05\uDE06\uDE0C-\uDE13\uDE15-\uDE17\uDE19-\uDE33\uDE38-\uDE3A\uDE3F\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE6\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48\uDC80-\uDCB2\uDCC0-\uDCF2]|\uD804[\uDC00-\uDC46\uDC66-\uDC6F\uDC7F-\uDCBA\uDCD0-\uDCE8\uDCF0-\uDCF9\uDD00-\uDD34\uDD36-\uDD3F\uDD50-\uDD73\uDD76\uDD80-\uDDC4\uDDCA-\uDDCC\uDDD0-\uDDDA\uDDDC\uDE00-\uDE11\uDE13-\uDE37\uDE80-\uDE86\uDE88\uDE8A-\uDE8D\uDE8F-\uDE9D\uDE9F-\uDEA8\uDEB0-\uDEEA\uDEF0-\uDEF9\uDF00-\uDF03\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3C-\uDF44\uDF47\uDF48\uDF4B-\uDF4D\uDF50\uDF57\uDF5D-\uDF63\uDF66-\uDF6C\uDF70-\uDF74]|\uD805[\uDC80-\uDCC5\uDCC7\uDCD0-\uDCD9\uDD80-\uDDB5\uDDB8-\uDDC0\uDDD8-\uDDDD\uDE00-\uDE40\uDE44\uDE50-\uDE59\uDE80-\uDEB7\uDEC0-\uDEC9\uDF00-\uDF19\uDF1D-\uDF2B\uDF30-\uDF39]|\uD806[\uDCA0-\uDCE9\uDCFF\uDEC0-\uDEF8]|\uD808[\uDC00-\uDF99]|\uD809[\uDC00-\uDC6E\uDC80-\uDD43]|[\uD80C\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD811[\uDC00-\uDE46]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDE60-\uDE69\uDED0-\uDEED\uDEF0-\uDEF4\uDF00-\uDF36\uDF40-\uDF43\uDF50-\uDF59\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDF00-\uDF44\uDF50-\uDF7E\uDF8F-\uDF9F]|\uD82C[\uDC00\uDC01]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99\uDC9D\uDC9E]|\uD834[\uDD65-\uDD69\uDD6D-\uDD72\uDD7B-\uDD82\uDD85-\uDD8B\uDDAA-\uDDAD\uDE42-\uDE44]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB\uDFCE-\uDFFF]|\uD836[\uDE00-\uDE36\uDE3B-\uDE6C\uDE75\uDE84\uDE9B-\uDE9F\uDEA1-\uDEAF]|\uD83A[\uDC00-\uDCC4\uDCD0-\uDCD6]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1]|\uD87E[\uDC00-\uDE1D]|\uDB40[\uDD00-\uDDEF]/
};
function isWhiteSpace(cp) {
return (cp === 0x20) || (cp === 0x09) || (cp === 0x0B) || (cp === 0x0C) || (cp === 0xA0) ||
(cp >= 0x1680 && [0x1680, 0x2000, 0x2001, 0x2002, 0x2003, 0x2004, 0x2005, 0x2006, 0x2007, 0x2008, 0x2009, 0x200A, 0x202F, 0x205F, 0x3000, 0xFEFF].indexOf(cp) >= 0);
}
function isLineTerminator(cp) {
return (cp === 0x0A) || (cp === 0x0D) || (cp === 0x2028) || (cp === 0x2029);
}
function isIdentifierStart(cp) {
return (cp === 0x24) || (cp === 0x5F) || // $ (dollar) and _ (underscore)
(cp >= 0x41 && cp <= 0x5A) || // A..Z
(cp >= 0x61 && cp <= 0x7A) || // a..z
(cp === 0x5C) || // \ (backslash)
((cp >= 0x80) && Regex.NonAsciiIdentifierStart.test(fromCodePoint(cp)));
}
function fromCodePoint(cp) {
return (cp < 0x10000) ? String.fromCharCode(cp) :
String.fromCharCode(0xD800 + ((cp - 0x10000) >> 10)) +
String.fromCharCode(0xDC00 + ((cp - 0x10000) & 1023));
}
function isIdentifierPart(cp) {
return (cp === 0x24) || (cp === 0x5F) || // $ (dollar) and _ (underscore)
(cp >= 0x41 && cp <= 0x5A) || // A..Z
(cp >= 0x61 && cp <= 0x7A) || // a..z
(cp >= 0x30 && cp <= 0x39) || // 0..9
(cp === 0x5C) || // \ (backslash)
((cp >= 0x80) && Regex.NonAsciiIdentifierPart.test(fromCodePoint(cp)));
}
// const globMap = new Uint8Array(256 * 256);
const globMap = new Array(256 * 256).fill(0);
// 2 - string
// 5 - white space
// 10 - nextExpression
// 15 - line terminator
// 20 - identifier_start
// 21 - identifier_part
const nextNewExpressionStartSymbols = [];
'~%^&*/-+([;:?,<>=|'.split('').forEach(ch => {
nextNewExpressionStartSymbols[ch.charCodeAt(0)] = true;
});
function isNextStartExpression(i) {
return nextNewExpressionStartSymbols[i];
}
for (let i = 0; i < globMap.length; i++) {
if (isWhiteSpace(i)) {
globMap[i] = 5;
}
if (isNextStartExpression(i)) {
globMap[i] = 10;
}
if (isLineTerminator(i)) {
globMap[i] = 15;
}
if (isIdentifierPart(i)) {
globMap[i] = 255; // part
}
/* if (isIdentifierStart(i)) {
globMap[i] = 127; // start
}*/
}
// strings
globMap[34] = 2;
/*'*/
globMap[39] = 2;
/*"*/
// globMap[96] = 2;
/*`*/
function parseStr(code, patternMatcher) {
// "use strict";
let i = -1;
let nextExpressionStart = true;
let x = 0;
let startS = 0;
let type = 0;
const len = code.length;
const stokens = [];
let strSym = 0;
let nextX = 0;
let prevWasAst = false;
let classMarker = false;
let scanCurly = false;
// let curlyStack = 0;
let f = 0;
const curlyStack = [];
let curlyPos = 0;
let curlyType = 0;
let size = 0;
let startIdentSym = 0;
main: while (++i < len) {
x = code.charCodeAt(i);
type = globMap[x];
// f = type >> 1 & 1;
if ((type === 255/* ident part */)) {
nextExpressionStart = false;
startS = i;
startIdentSym = x;
/*
do {
x = code.charCodeAt(++i);
type = globMap[x];
} while (type === 255);
*/
// stokens.push(1, startS, i);
while (++i < len) {
x = code.charCodeAt(i);
type = globMap[x];
if (type !== 255 /* ident start */) {
size = i - startS;
if (patternMatcher(code, startS, size, startIdentSym)) {
stokens.push(1, startS, i);
}
if (size === 6 && startIdentSym === 114 /*r*/ && code.substr(startS, size) === 'return') {
nextExpressionStart = true;
}
break;
}
}
}
if (x === 123 /*{*/) {
curlyStack[curlyPos++] = 1;
}
else if (x === 125 /*}*/) {
// continue template string after "}"
if (curlyStack[--curlyPos] === 2) {
startS = i;
nextExpressionStart = false;
while (++i < len) {
x = code.charCodeAt(i);
if (x === 92 /*\*/) {
i++;
continue;
}
if (x === 96 /*`*/) {
stokens.push(2, startS + 1, i);
continue main;
}
}
}
}
// string " '
if (type === 2 /*string*/) {
strSym = x;
startS = i;
nextExpressionStart = false;
while (++i < len) {
x = code.charCodeAt(i);
if (x === 92 /*\*/) {
i++;
continue;
}
if (x === strSym) {
stokens.push(2, startS + 1, i);
continue main;
}
}
}
// template string
else if (x === 96 /*`*/) {
startS = i;
while (++i < len) {
x = code.charCodeAt(i);
if (x === 92 /*\*/) {
i++;
continue;
}
if (x === 36 /*$*/ && code.charCodeAt(i + 1) === 123 /*{*/) {
i++;
curlyStack[curlyPos++] = 2; // dollar curly
stokens.push(2, startS + 1, i - 1);
continue main;
}
if (x === 96 /*`*/) {
stokens.push(2, startS + 1, i);
continue main;
}
}
}
// /
else if (x === 47 /*/*/) {
nextX = code.charCodeAt(i + 1);
// line comment //
if (nextX === 47/*/*/) {
startS = i;
i++;
while (++i < len && globMap[code.charCodeAt(i)] !== 15/*line terminator*/);
// ret && tokens.push(["lc", code.substring(startS, i + 1)]);
stokens.push(5, startS, i);
continue;
}
// block comment /*
if (nextX === 42/* * */) {
startS = i;
i++;
prevWasAst = false;
while (++i < len) {
x = code.charCodeAt(i);
if (x === 42/* * */) {
prevWasAst = true;
continue;
}
if (prevWasAst) {
if (x === 47/*/*/) {
// ret && tokens.push(["bc", code.substring(startS, i + 1)]);
stokens.push(6, startS, i + 1);
continue main;
}
prevWasAst = false;
}
}
}
// start regexp
if (nextExpressionStart) {
nextExpressionStart = false;
startS = i;
classMarker = false;
while (++i < len) {
// let sym = codeD[i];
x = code.charCodeAt(i);
if (x === 92 /*\*/) {
x = code[i++];
} else if (classMarker) {
if (x === 93/*]*/) {
classMarker = false;
}
} else {
if (x === 47 /*/*/) {
// todo: flags
// ret && tokens.push(["re", code.substring(startS, i + 1)]);
stokens.push(8 /*re*/, startS, i + 1);
continue main;
} else if (x === 91 /*[*/) {
classMarker = true;
}
}
}
}
}
// if next expression start
else if (type === 10 /* next exrp */) {
nextExpressionStart = true;
}
// non white space
else if (type !== 5 /* space */) {
nextExpressionStart = false;
}
}
/*
for (let i = 0; i < code.length; i++) {
x = code.charCodeAt(i);
}
*/
// tokens.map(t => console.log(t[0], '"' + t[1] + '"'));
// console.log(tokens.map(t => t[0] + ' "' + t[1].substr(0, 100) + '"').join('\n'));
// console.log(tokens);
// for (i = 0; i < stokens.length; i += 3) {
// stokens[i];
// }
return stokens;
}
function test() {
//abc
/**/
/1/
}
function patternMatcher() {
return true;
}
parseStr('//a\n"b"', patternMatcher);
parseStr('return /1/', patternMatcher);
parseStr('yield /1/', patternMatcher);
parseStr('yield* /1/', patternMatcher);
parseStr('if (1)/1/', patternMatcher); // useless
parseStr('while(1)/1/', patternMatcher); // useless
parseStr('for(1)/1/', patternMatcher); // useless
parseStr('with(1)/1/', patternMatcher); // useless
parseStr('function(){} /42', patternMatcher); // useless
parseStr('function f(){} /42/', patternMatcher); // useless
parseStr('in/1/', patternMatcher); // useless
parseStr('typeof/1/', patternMatcher); // useless
parseStr('instanceof/1/', patternMatcher); // useless
parseStr('new/1/', patternMatcher); // useless
parseStr('case /1/', patternMatcher); // useless
parseStr('delete /1/', patternMatcher); // useless
parseStr('throw /1/', patternMatcher); // useless
parseStr('void /1/', patternMatcher); // useless
function beforeFunctionExpression(t) {
return ['(', '{', '[', 'in', 'typeof', 'instanceof', 'new',
'return', 'case', 'delete', 'throw', 'void',
// assignment operators
'=', '+=', '-=', '*=', '**=', '/=', '%=', '<<=', '>>=', '>>>=',
'&=', '|=', '^=', ',',
// binary/unary operators
'+', '-', '*', '**', '/', '%', '++', '--', '<<', '>>', '>>>', '&',
'|', '^', '!', '~', '&&', '||', '?', ':', '===', '==', '>=',
'<=', '<', '>', '!=', '!=='].indexOf(t) >= 0;
};
if (typeof module == 'object') {
module.exports = parseStr;
}
function x() {
"use strict";
console.profile('prof');
for (let i = 0; i < 300; i++) {
parseStr('//flow\n/*1*/"1"`1`,/[\\1]/');
}
console.profileEnd('prof');
}
var charToInteger = {};
var integerToChar = {};
'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/='.split('').forEach(function (char, i) {
charToInteger[char/*.codePointAt(0)*/] = i;
integerToChar[i] = char/*.codePointAt(0)*/;
});
const fs = require('fs');
const folder = './esprima/';
const files = fs.readdirSync(folder).filter(f => f.substr(-3) == '.js').map(f => ({
source: fs.readFileSync(folder + f, 'utf8'),
sourceFile: folder + f,
mapFile: folder + f + '.map',
mapSource: JSON.parse(fs.readFileSync(folder + f + '.map', 'utf8')),
}));
function sourcemapDiffCalc(str) {
var len = str.length,
i,
hasContinuationBit,
shift = 0,
value = 0,
integer,
sym,
shouldNegate,
fieldN = 0,
genLine = 0,
genCol = 0,
filePos = 0,
line = 0,
col = 0,
named = 0,
segments = 1
for (i = 0; i < len; i++) {
sym = str[i];
if (sym === ';' || sym === ',') {
segments++;
shift = 0;
value = 0;
fieldN = 0;
if (sym === ';') {
genLine++;
genCol = 0;
}
continue;
}
integer = charToInteger[str[i]];
hasContinuationBit = integer & 32;
integer &= 31;
value += integer << shift;
if (hasContinuationBit) {
shift += 5;
} else {
shouldNegate = value & 1;
value >>= 1;
value = shouldNegate ? -value : value;
switch (fieldN) {
case 0:
genCol += value;
break;
case 1:
filePos += value;
break;
case 2:
line += value;
break;
case 3:
col += value;
break;
case 4:
named += value;
break;
}
fieldN++;
// reset
value = shift = 0;
}
}
return {genLine, genCol, filePos, line, col, named, segments};
}
function encode(value) {
var result, i;
if (typeof value === 'number') {
result = encodeInteger(value);
} else {
result = '';
for (i = 0; i < value.length; i += 1) {
result += encodeInteger(value[i]);
}
}
return result;
}
function encodeInteger(num) {
var result = '', clamped;
if (num < 0) {
num = ( -num << 1 ) | 1;
} else {
num <<= 1;
}
do {
clamped = num & 31;
num >>= 5;
if (num > 0) {
clamped |= 32;
}
result += integerToChar[clamped];
} while (num > 0);
return result;
}
let bulkSource = '';
let sourcemap = {
"version": 3,
"file": "bundle_.xjs",
"sourceRoot": "",
names: [],
sources: [],
mappings: '',
};
let prevDiff;
let header = (id) => '\n__packer("' + id + '", function(module, exports, require) {\n';
let footer = '\n}\n';
for (let i = 0; i < files.length; i++) {
const file = files[i];
let content = header(file.sourceFile) + file.source.replace(/^\/\/[#@]\s+sourceMappingURL=.*$/mg, '') + footer;
const map = file.mapSource;
let mapping = map.mappings;
if (prevDiff) {
mapping = encode([0, 1, -prevDiff.line, -prevDiff.col]) + ';;' + mapping + ';;;';
} else {
mapping = ';;' + mapping + ';;;';
}
prevDiff = sourcemapDiffCalc(map.mappings);
sourcemap.mappings += mapping;
bulkSource += content;
sourcemap.sources.push(...map.sources);
}
bulkSource += '\n//# sourceMappingURL=bundle_.xjs.map';
fs.writeFileSync('esprima/bundle_.xjs', bulkSource);
fs.writeFileSync('esprima/bundle_.xjs.map', JSON.stringify(sourcemap));
const file = files[2].mapSource;
let test = '';
for (let i = 0; i < 10000; i++) {
test += ';' + file.mappings;
}
test = new Buffer(test).toString();
console.time('perf');
const res = sourcemapDiffCalc(test);
console.timeEnd('perf');
console.log(res);
'use strict';
var convert = require('convert-source-map');
var combine = require('combine-source-map');
const fs = require('fs');
const folder = './esprima/';
const files = fs.readdirSync(folder).filter(f => f.substr(-3) == '.js').map(f => ({
source: fs.readFileSync(folder + f, 'utf8'),
sourceFile: folder + f,
mapFile: folder + f + '.map',
mapSource: JSON.parse(fs.readFileSync(folder + f + '.map', 'utf8')),
}));
// console.log(files);
/*
var fooComment = '//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9vLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiZm9vLmNvZmZlZSJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Q0FBQTtDQUFBLENBQUEsQ0FBQSxJQUFPLEdBQUs7Q0FBWiIsInNvdXJjZXNDb250ZW50IjpbImNvbnNvbGUubG9nKHJlcXVpcmUgJy4vYmFyLmpzJylcbiJdfQ==';
var barComment = '//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYmFyLmNvZmZlZSJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Q0FBQTtDQUFBLENBQUEsQ0FBQSxJQUFPLEdBQUs7Q0FBWiIsInNvdXJjZXNDb250ZW50IjpbImNvbnNvbGUubG9nKGFsZXJ0ICdhbGVydHMgc3VjaycpXG4iXX0=';
var fooFile = {
source: '(function() {\n\n console.log(require(\'./bar.js\'));\n\n}).call(this);\n' + '\n' + fooComment
, sourceFile: 'foo.js'
};
var barFile = {
source: '(function() {\n\n console.log(alert(\'alerts suck\'));\n\n}).call(this);\n' + '\n' + barComment
, sourceFile: 'bar.js'
};
*/
const vlq = require('vlq');
var charToInteger = new Array(300);
var integerToChar = [];
'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/='.split('').forEach(function (char, i) {
charToInteger[char.codePointAt(0)] = i;
integerToChar[i] = char.codePointAt(0);
});
function decode(string) {
var result,// = [],
len = string.length,
i = 0,
hasContinuationBit,
shift = 0,
value = 0,
integer,
shouldNegate, fieldN = 0;
for (i = 0; i < len; i++) {
integer = charToInteger[string[i]];
if (integer === undefined) {
throw new Error('Invalid character (' + string[i] + ')');
}
hasContinuationBit = integer & 32;
integer &= 31;
value += integer << shift;
if (hasContinuationBit) {
shift += 5;
} else {
shouldNegate = value & 1;
value >>= 1;
if (fieldN++ == 1) {
return shouldNegate ? -value : value;
}
// result.push( shouldNegate ? -value : value );
// reset
value = shift = 0;
}
}
}
function encode(value) {
var result, i;
if (typeof value === 'number') {
result = encodeInteger(value);
} else {
result = '';
for (i = 0; i < value.length; i += 1) {
result += encodeInteger(value[i]);
}
}
return result;
}
function encodeInteger(num) {
var clamped;
num <<= 1;
do {
clamped = num & 31;
num >>= 5;
if (num > 0) {
clamped |= 32;
}
// result += integerToChar[ clamped ];
} while (num > 0);
return num;
}
const file = files[0];
console.time('perf');
const buff = new Buffer(file.mapSource.mappings);
const newBuffer = new Buffer(buff.length * 2).fill(0);
// shiftFileNumber(buff, newBuffer);
const testMAP = JSON.parse(fs.readFileSync('test/_assert.js.map', 'utf-8'));
const result = new Buffer(testMAP.mappings.length * 2).fill(32);
shiftFileNumber(new Buffer(testMAP.mappings), result, 0);
testMAP.mappings = result.toString().trim();
testMAP.sources.unshift("flow.ts");
fs.writeFileSync('test/assert.js.map', JSON.stringify(testMAP));
// console.log(result.toString());
//;;;;AAAA,0DAA0D;AAC1D,2EAA2E;AAC3E,2EAA2E;AAC3E,oEAAoE;;AAEpE,gBAAuB,SAAkB,EAAE,OAAe;IACtD,wBAAwB;IACxB,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;QACb,MAAM,IAAI,KAAK,CAAC,UAAU,GAAG,OAAO,CAAC,CAAC;IAC1C,CAAC;AACL,CAAC;AALD,wBAKC
//;;;;ACAA,0DCA0D;ACC1D,2ECA2E;ACC3E,2ECA2E;ACC3E,oECAoE;;ACEpE,gBCAuB,SCAkB,ECAE,OCAe;ICCtD,wBCAwB;ICCxB,ECAE,CCAC,CCAC,CCAC,SCAS,CCAC,CCAC,CCAC;QCCb,MCAM,ICAI,KCAK,CCAC,UCAU,GCAG,OCAO,CCAC,CCAC;ICC1C,CCAC;ACCL,CCAC;ACLD,wBCKC
let bulkSource = '';
let sourcemap = {
"version": 3,
"file": "bundle_.xjs",
"sourceRoot": "",
names: [],
sources: [],
mappings: '',
};
for (let i = 0; i < files.length; i++) {
const file = files[i];
bulkSource += '\n' + file.source.replace(/^\/\/[#@]\s+sourceMappingURL=.*$/mg, '');
const map = file.mapSource;
const ff = (i == 0) ? map.mappings : map.mappings.replace(/^(;*)AA/, "$1AC");
const fixedMapping = ';' + ff + ';';
// i === 0 && console.log('First', map.mappings, fixedMapping);
sourcemap.mappings += fixedMapping;
sourcemap.sources.push(...map.sources);
}
bulkSource += '\n//# sourceMappingURL=bundle_.xjs.map';
console.log(sourcemap);
fs.writeFileSync('esprima/bundle_.xjs', bulkSource);
fs.writeFileSync('esprima/bundle_.xjs.map', JSON.stringify(sourcemap));
let r;
for (let i = 0; i < 1000000; i++) {
// shiftFileNumber(testBuff, result, 16);
// r = decode(buff)
// r = encodeInteger(3234)
}
console.log(r);
console.timeEnd('perf')
function shiftFileNumber(buffer, newBuffer, shiftN) {
var len = buffer.length,
i,
hasContinuationBit,
shift = 0,
value = 0,
integer,
sym,
bufferShift = 0,
fieldStart = 0,
newFieldSize = 0,
skipToNextField = false,
newI = 0,
fieldN = 0, clamped;
for (i = 0; i < len; i++) {
sym = buffer[i];
newBuffer[i + bufferShift] = sym;
if (sym === 59 /*;*/ || sym === 44 /*,*/) {
shift = 0;
value = 0;
fieldN = 0;
skipToNextField = false;
fieldStart = i + 1;
continue;
}
if (skipToNextField) continue;
integer = charToInteger[buffer[i]];
hasContinuationBit = integer & 32;
integer &= 31;
value += integer << shift;
if (hasContinuationBit) {
shift += 5;
} else {
value >>= 1;
if (fieldN++ == 1) {
value += shiftN;
value <<= 1;
newFieldSize = 0;
newI = i;
do {
clamped = value & 31;
value >>= 5;
if (value > 0) {
clamped |= 32;
}
// bufferShift = fieldStart;
// newFieldSize++;
newBuffer[bufferShift + newI] = integerToChar[clamped];
// result += integerToChar[ clamped ];
newI++;
} while (value > 0);
bufferShift += newI - i - 1;
skipToNextField = true;
}
// result.push( shouldNegate ? -value : value );
// reset
value = shift = 0;
}
}
}
function sourcemapDiffCalc(buffer, newBuffer, shiftN) {
var len = buffer.length,
i,
hasContinuationBit,
shift = 0,
value = 0,
integer,
sym,
bufferShift = 0,
fieldStart = 0,
newFieldSize = 0,
skipToNextField = false,
newI = 0,
fieldN = 0, clamped;
for (i = 0; i < len; i++) {
sym = buffer[i];
newBuffer[i + bufferShift] = sym;
if (sym === 59 /*;*/ || sym === 44 /*,*/) {
shift = 0;
value = 0;
fieldN = 0;
skipToNextField = false;
fieldStart = i + 1;
continue;
}
if (skipToNextField) continue;
integer = charToInteger[buffer[i]];
hasContinuationBit = integer & 32;
integer &= 31;
value += integer << shift;
if (hasContinuationBit) {
shift += 5;
} else {
value >>= 1;
if (fieldN++ == 1) {
value += shiftN;
value <<= 1;
newFieldSize = 0;
newI = i;
do {
clamped = value & 31;
value >>= 5;
if (value > 0) {
clamped |= 32;
}
// bufferShift = fieldStart;
// newFieldSize++;
newBuffer[bufferShift + newI] = integerToChar[clamped];
// result += integerToChar[ clamped ];
newI++;
} while (value > 0);
bufferShift += newI - i - 1;
skipToNextField = true;
}
// result.push( shouldNegate ? -value : value );
// reset
value = shift = 0;
}
}
}
// console.log();
function abc() {
var offset = {line: 2};
let sm = combine.create('bundle.js');
files.forEach(f => {
sm.addFile(f, offset)
});
console.log(sm);
// return convert.fromBase64(sm.base64()).toObject();
}
// const x = convert.fromJSON(file.mapSource);
// console.log(x);
/*
console.time('perf')
for (let i = 0; i < 1; i++) {
var smo = abc();
}
console.timeEnd('perf')
console.log(smo);
*/
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment