js-beautify 1.7.0 → 1.7.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (50) hide show
  1. package/CHANGELOG.md +27 -0
  2. package/CONTRIBUTING.md +3 -3
  3. package/README.md +15 -12
  4. package/js/bin/css-beautify.js +4 -0
  5. package/js/bin/html-beautify.js +4 -0
  6. package/js/bin/js-beautify.js +4 -0
  7. package/js/config/defaults.json +18 -0
  8. package/js/lib/beautify-css.js +1046 -0
  9. package/js/lib/beautify-html.js +1387 -0
  10. package/js/lib/beautify.js +2820 -0
  11. package/js/lib/cli.js +623 -0
  12. package/js/lib/unpackers/javascriptobfuscator_unpacker.js +103 -0
  13. package/js/lib/unpackers/myobfuscate_unpacker.js +90 -0
  14. package/js/lib/unpackers/p_a_c_k_e_r_unpacker.js +83 -0
  15. package/js/lib/unpackers/urlencode_unpacker.js +73 -0
  16. package/js/src/core/acorn.js +63 -0
  17. package/js/src/core/inputscanner.js +95 -0
  18. package/js/src/core/options.js +48 -0
  19. package/js/src/core/output.js +234 -0
  20. package/js/src/core/token.js +49 -0
  21. package/js/src/css/beautifier.js +477 -0
  22. package/js/src/css/index.js +36 -0
  23. package/js/src/html/beautifier.js +1035 -0
  24. package/js/src/html/index.js +36 -0
  25. package/js/src/index.js +27 -0
  26. package/js/src/javascript/beautifier.js +1449 -0
  27. package/js/src/javascript/index.js +36 -0
  28. package/js/src/javascript/tokenizer.js +620 -0
  29. package/js/test/amd-beautify-tests.js +62 -0
  30. package/js/test/generated/beautify-css-tests.js +1393 -0
  31. package/js/test/generated/beautify-html-tests.js +3212 -0
  32. package/js/test/generated/beautify-javascript-tests.js +5896 -0
  33. package/js/test/node-beautify-html-perf-tests.js +51 -0
  34. package/js/test/node-beautify-perf-tests.js +50 -0
  35. package/js/test/node-beautify-tests.js +45 -0
  36. package/js/test/requirejs-html-beautify.html +58 -0
  37. package/js/test/resources/configerror/.jsbeautifyrc +6 -0
  38. package/js/test/resources/configerror/subDir1/subDir2/empty.txt +0 -0
  39. package/js/test/resources/editorconfig/.editorconfig +6 -0
  40. package/js/test/resources/editorconfig/cr/.editorconfig +3 -0
  41. package/js/test/resources/editorconfig/crlf/.editorconfig +3 -0
  42. package/js/test/resources/editorconfig/error/.editorconfig +1 -0
  43. package/js/test/resources/editorconfig/example-base.js +3 -0
  44. package/js/test/resources/example1.js +3 -0
  45. package/js/test/resources/indent11chars/.jsbeautifyrc +6 -0
  46. package/js/test/resources/indent11chars/subDir1/subDir2/empty.txt +0 -0
  47. package/js/test/run-tests +17 -0
  48. package/js/test/sanitytest.js +144 -0
  49. package/js/test/shell-smoke-test.sh +383 -0
  50. package/package.json +1 -1
@@ -0,0 +1,103 @@
1
+ //
2
+ // simple unpacker/deobfuscator for scripts messed up with javascriptobfuscator.com
3
+ // written by Einar Lielmanis <einar@jsbeautifier.org>
4
+ //
5
+ // usage:
6
+ //
7
+ // if (JavascriptObfuscator.detect(some_string)) {
8
+ // var unpacked = JavascriptObfuscator.unpack(some_string);
9
+ // }
10
+ //
11
+ //
12
+
13
+ var JavascriptObfuscator = {
14
+ detect: function(str) {
15
+ return /^var _0x[a-f0-9]+ ?\= ?\[/.test(str);
16
+ },
17
+
18
+ unpack: function(str) {
19
+ if (JavascriptObfuscator.detect(str)) {
20
+ var matches = /var (_0x[a-f\d]+) ?\= ?\[(.*?)\];/.exec(str);
21
+ if (matches) {
22
+ var var_name = matches[1];
23
+ var strings = JavascriptObfuscator._smart_split(matches[2]);
24
+ str = str.substring(matches[0].length);
25
+ for (var k in strings) {
26
+ str = str.replace(new RegExp(var_name + '\\[' + k + '\\]', 'g'),
27
+ JavascriptObfuscator._fix_quotes(JavascriptObfuscator._unescape(strings[k])));
28
+ }
29
+ }
30
+ }
31
+ return str;
32
+ },
33
+
34
+ _fix_quotes: function(str) {
35
+ var matches = /^"(.*)"$/.exec(str);
36
+ if (matches) {
37
+ str = matches[1];
38
+ str = "'" + str.replace(/'/g, "\\'") + "'";
39
+ }
40
+ return str;
41
+ },
42
+
43
+ _smart_split: function(str) {
44
+ var strings = [];
45
+ var pos = 0;
46
+ while (pos < str.length) {
47
+ if (str.charAt(pos) === '"') {
48
+ // new word
49
+ var word = '';
50
+ pos += 1;
51
+ while (pos < str.length) {
52
+ if (str.charAt(pos) === '"') {
53
+ break;
54
+ }
55
+ if (str.charAt(pos) === '\\') {
56
+ word += '\\';
57
+ pos++;
58
+ }
59
+ word += str.charAt(pos);
60
+ pos++;
61
+ }
62
+ strings.push('"' + word + '"');
63
+ }
64
+ pos += 1;
65
+ }
66
+ return strings;
67
+ },
68
+
69
+
70
+ _unescape: function(str) {
71
+ // inefficient if used repeatedly or on small strings, but wonderful on single large chunk of text
72
+ for (var i = 32; i < 128; i++) {
73
+ str = str.replace(new RegExp('\\\\x' + i.toString(16), 'ig'), String.fromCharCode(i));
74
+ }
75
+ str = str.replace(/\\x09/g, "\t");
76
+ return str;
77
+ },
78
+
79
+ run_tests: function(sanity_test) {
80
+ var t = sanity_test || new SanityTest();
81
+
82
+ t.test_function(JavascriptObfuscator._smart_split, "JavascriptObfuscator._smart_split");
83
+ t.expect('', []);
84
+ t.expect('"a", "b"', ['"a"', '"b"']);
85
+ t.expect('"aaa","bbbb"', ['"aaa"', '"bbbb"']);
86
+ t.expect('"a", "b\\\""', ['"a"', '"b\\\""']);
87
+ t.test_function(JavascriptObfuscator._unescape, 'JavascriptObfuscator._unescape');
88
+ t.expect('\\x40', '@');
89
+ t.expect('\\x10', '\\x10');
90
+ t.expect('\\x1', '\\x1');
91
+ t.expect("\\x61\\x62\\x22\\x63\\x64", 'ab"cd');
92
+ t.test_function(JavascriptObfuscator.detect, 'JavascriptObfuscator.detect');
93
+ t.expect('', false);
94
+ t.expect('abcd', false);
95
+ t.expect('var _0xaaaa', false);
96
+ t.expect('var _0xaaaa = ["a", "b"]', true);
97
+ t.expect('var _0xaaaa=["a", "b"]', true);
98
+ t.expect('var _0x1234=["a","b"]', true);
99
+ return t;
100
+ }
101
+
102
+
103
+ };
@@ -0,0 +1,90 @@
1
+ //
2
+ // simple unpacker/deobfuscator for scripts messed up with myobfuscate.com
3
+ // You really don't want to obfuscate your scripts there: they're tracking
4
+ // your unpackings, your script gets turned into something like this,
5
+ // as of 2011-04-25:
6
+ /*
7
+
8
+ var _escape = 'your_script_escaped';
9
+ var _111 = document.createElement('script');
10
+ _111.src = 'http://api.www.myobfuscate.com/?getsrc=ok' +
11
+ '&ref=' + encodeURIComponent(document.referrer) +
12
+ '&url=' + encodeURIComponent(document.URL);
13
+ var 000 = document.getElementsByTagName('head')[0];
14
+ 000.appendChild(_111);
15
+ document.write(unescape(_escape));
16
+
17
+ */
18
+ //
19
+ // written by Einar Lielmanis <einar@jsbeautifier.org>
20
+ //
21
+ // usage:
22
+ //
23
+ // if (MyObfuscate.detect(some_string)) {
24
+ // var unpacked = MyObfuscate.unpack(some_string);
25
+ // }
26
+ //
27
+ //
28
+
29
+ var MyObfuscate = {
30
+ detect: function(str) {
31
+ if (/^var _?[0O1lI]{3}\=('|\[).*\)\)\);/.test(str)) {
32
+ return true;
33
+ }
34
+ if (/^function _?[0O1lI]{3}\(_/.test(str) && /eval\(/.test(str)) {
35
+ return true;
36
+ }
37
+ return false;
38
+ },
39
+
40
+ unpack: function(str) {
41
+ if (MyObfuscate.detect(str)) {
42
+ var __eval = eval;
43
+ try {
44
+ eval = function(unpacked) { // jshint ignore:line
45
+ if (MyObfuscate.starts_with(unpacked, 'var _escape')) {
46
+ // fetch the urlencoded stuff from the script,
47
+ var matches = /'([^']*)'/.exec(unpacked);
48
+ var unescaped = unescape(matches[1]);
49
+ if (MyObfuscate.starts_with(unescaped, '<script>')) {
50
+ unescaped = unescaped.substr(8, unescaped.length - 8);
51
+ }
52
+ if (MyObfuscate.ends_with(unescaped, '</script>')) {
53
+ unescaped = unescaped.substr(0, unescaped.length - 9);
54
+ }
55
+ unpacked = unescaped;
56
+ }
57
+ // throw to terminate the script
58
+ unpacked = "// Unpacker warning: be careful when using myobfuscate.com for your projects:\n" +
59
+ "// scripts obfuscated by the free online version may call back home.\n" +
60
+ "\n//\n" + unpacked;
61
+ throw unpacked;
62
+ }; // jshint ignore:line
63
+ __eval(str); // should throw
64
+ } catch (e) {
65
+ // well, it failed. we'll just return the original, instead of crashing on user.
66
+ if (typeof e === "string") {
67
+ str = e;
68
+ }
69
+ }
70
+ eval = __eval; // jshint ignore:line
71
+ }
72
+ return str;
73
+ },
74
+
75
+ starts_with: function(str, what) {
76
+ return str.substr(0, what.length) === what;
77
+ },
78
+
79
+ ends_with: function(str, what) {
80
+ return str.substr(str.length - what.length, what.length) === what;
81
+ },
82
+
83
+ run_tests: function(sanity_test) {
84
+ var t = sanity_test || new SanityTest();
85
+
86
+ return t;
87
+ }
88
+
89
+
90
+ };
@@ -0,0 +1,83 @@
1
+ //
2
+ // Unpacker for Dean Edward's p.a.c.k.e.r, a part of javascript beautifier
3
+ // written by Einar Lielmanis <einar@jsbeautifier.org>
4
+ //
5
+ // Coincidentally, it can defeat a couple of other eval-based compressors.
6
+ //
7
+ // usage:
8
+ //
9
+ // if (P_A_C_K_E_R.detect(some_string)) {
10
+ // var unpacked = P_A_C_K_E_R.unpack(some_string);
11
+ // }
12
+ //
13
+ //
14
+
15
+ var P_A_C_K_E_R = {
16
+ detect: function(str) {
17
+ return (P_A_C_K_E_R.get_chunks(str).length > 0);
18
+ },
19
+
20
+ get_chunks: function(str) {
21
+ var chunks = str.match(/eval\(\(?function\(.*?(,0,\{\}\)\)|split\('\|'\)\)\))($|\n)/g);
22
+ return chunks ? chunks : [];
23
+ },
24
+
25
+ unpack: function(str) {
26
+ var chunks = P_A_C_K_E_R.get_chunks(str),
27
+ chunk;
28
+ for (var i = 0; i < chunks.length; i++) {
29
+ chunk = chunks[i].replace(/\n$/, '');
30
+ str = str.split(chunk).join(P_A_C_K_E_R.unpack_chunk(chunk));
31
+ }
32
+ return str;
33
+ },
34
+
35
+ unpack_chunk: function(str) {
36
+ var unpacked_source = '';
37
+ var __eval = eval;
38
+ if (P_A_C_K_E_R.detect(str)) {
39
+ try {
40
+ eval = function(s) { // jshint ignore:line
41
+ unpacked_source += s;
42
+ return unpacked_source;
43
+ }; // jshint ignore:line
44
+ __eval(str);
45
+ if (typeof unpacked_source === 'string' && unpacked_source) {
46
+ str = unpacked_source;
47
+ }
48
+ } catch (e) {
49
+ // well, it failed. we'll just return the original, instead of crashing on user.
50
+ }
51
+ }
52
+ eval = __eval; // jshint ignore:line
53
+ return str;
54
+ },
55
+
56
+ run_tests: function(sanity_test) {
57
+ var t = sanity_test || new SanityTest();
58
+
59
+ var pk1 = "eval(function(p,a,c,k,e,r){e=String;if(!''.replace(/^/,String)){while(c--)r[c]=k[c]||c;k=[function(e){return r[e]}];e=function(){return'\\\\w+'};c=1};while(c--)if(k[c])p=p.replace(new RegExp('\\\\b'+e(c)+'\\\\b','g'),k[c]);return p}('0 2=1',3,3,'var||a'.split('|'),0,{}))";
60
+ var unpk1 = 'var a=1';
61
+ var pk2 = "eval(function(p,a,c,k,e,r){e=String;if(!''.replace(/^/,String)){while(c--)r[c]=k[c]||c;k=[function(e){return r[e]}];e=function(){return'\\\\w+'};c=1};while(c--)if(k[c])p=p.replace(new RegExp('\\\\b'+e(c)+'\\\\b','g'),k[c]);return p}('0 2=1',3,3,'foo||b'.split('|'),0,{}))";
62
+ var unpk2 = 'foo b=1';
63
+ var pk_broken = "eval(function(p,a,c,k,e,r){BORKBORK;if(!''.replace(/^/,String)){while(c--)r[c]=k[c]||c;k=[function(e){return r[e]}];e=function(){return'\\\\w+'};c=1};while(c--)if(k[c])p=p.replace(new RegExp('\\\\b'+e(c)+'\\\\b','g'),k[c]);return p}('0 2=1',3,3,'var||a'.split('|'),0,{}))";
64
+ var pk3 = "eval(function(p,a,c,k,e,r){e=String;if(!''.replace(/^/,String)){while(c--)r[c]=k[c]||c;k=[function(e){return r[e]}];e=function(){return'\\\\w+'};c=1};while(c--)if(k[c])p=p.replace(new RegExp('\\\\b'+e(c)+'\\\\b','g'),k[c]);return p}('0 2=1{}))',3,3,'var||a'.split('|'),0,{}))";
65
+ var unpk3 = 'var a=1{}))';
66
+
67
+ t.test_function(P_A_C_K_E_R.detect, "P_A_C_K_E_R.detect");
68
+ t.expect('', false);
69
+ t.expect('var a = b', false);
70
+ t.test_function(P_A_C_K_E_R.unpack, "P_A_C_K_E_R.unpack");
71
+ t.expect(pk_broken, pk_broken);
72
+ t.expect(pk1, unpk1);
73
+ t.expect(pk2, unpk2);
74
+ t.expect(pk3, unpk3);
75
+
76
+ var filler = '\nfiller\n';
77
+ t.expect(filler + pk1 + "\n" + pk_broken + filler + pk2 + filler, filler + unpk1 + "\n" + pk_broken + filler + unpk2 + filler);
78
+
79
+ return t;
80
+ }
81
+
82
+
83
+ };
@@ -0,0 +1,73 @@
1
+ /*global unescape */
2
+ /*jshint curly: false, scripturl: true */
3
+ //
4
+ // trivial bookmarklet/escaped script detector for the javascript beautifier
5
+ // written by Einar Lielmanis <einar@jsbeautifier.org>
6
+ //
7
+ // usage:
8
+ //
9
+ // if (Urlencoded.detect(some_string)) {
10
+ // var unpacked = Urlencoded.unpack(some_string);
11
+ // }
12
+ //
13
+ //
14
+
15
+ var isNode = (typeof module !== 'undefined' && module.exports);
16
+ if (isNode) {
17
+ var SanityTest = require(__dirname + '/../../test/sanitytest');
18
+ }
19
+
20
+ var Urlencoded = {
21
+ detect: function(str) {
22
+ // the fact that script doesn't contain any space, but has %20 instead
23
+ // should be sufficient check for now.
24
+ if (str.indexOf(' ') === -1) {
25
+ if (str.indexOf('%2') !== -1) return true;
26
+ if (str.replace(/[^%]+/g, '').length > 3) return true;
27
+ }
28
+ return false;
29
+ },
30
+
31
+ unpack: function(str) {
32
+ if (Urlencoded.detect(str)) {
33
+ if (str.indexOf('%2B') !== -1 || str.indexOf('%2b') !== -1) {
34
+ // "+" escaped as "%2B"
35
+ return unescape(str.replace(/\+/g, '%20'));
36
+ } else {
37
+ return unescape(str);
38
+ }
39
+ }
40
+ return str;
41
+ },
42
+
43
+
44
+
45
+ run_tests: function(sanity_test) {
46
+ var t = sanity_test || new SanityTest();
47
+ t.test_function(Urlencoded.detect, "Urlencoded.detect");
48
+ t.expect('', false);
49
+ t.expect('var a = b', false);
50
+ t.expect('var%20a+=+b', true);
51
+ t.expect('var%20a=b', true);
52
+ t.expect('var%20%21%22', true);
53
+ t.expect('javascript:(function(){var%20whatever={init:function(){alert(%22a%22+%22b%22)}};whatever.init()})();', true);
54
+ t.test_function(Urlencoded.unpack, 'Urlencoded.unpack');
55
+
56
+ t.expect('javascript:(function(){var%20whatever={init:function(){alert(%22a%22+%22b%22)}};whatever.init()})();',
57
+ 'javascript:(function(){var whatever={init:function(){alert("a"+"b")}};whatever.init()})();'
58
+ );
59
+ t.expect('', '');
60
+ t.expect('abcd', 'abcd');
61
+ t.expect('var a = b', 'var a = b');
62
+ t.expect('var%20a=b', 'var a=b');
63
+ t.expect('var%20a=b+1', 'var a=b+1');
64
+ t.expect('var%20a=b%2b1', 'var a=b+1');
65
+ return t;
66
+ }
67
+
68
+
69
+ };
70
+
71
+ if (isNode) {
72
+ module.exports = Urlencoded;
73
+ }
@@ -0,0 +1,63 @@
1
+ /* jshint curly: false */
2
+ // This section of code is taken from acorn.
3
+ //
4
+ // Acorn was written by Marijn Haverbeke and released under an MIT
5
+ // license. The Unicode regexps (for identifiers and whitespace) were
6
+ // taken from [Esprima](http://esprima.org) by Ariya Hidayat.
7
+ //
8
+ // Git repositories for Acorn are available at
9
+ //
10
+ // http://marijnhaverbeke.nl/git/acorn
11
+ // https://github.com/marijnh/acorn.git
12
+
13
+ // ## Character categories
14
+
15
+ // Big ugly regular expressions that match characters in the
16
+ // whitespace, identifier, and identifier-start categories. These
17
+ // are only applied when a character is found to actually have a
18
+ // code point above 128.
19
+
20
+ var nonASCIIwhitespace = /[\u1680\u180e\u2000-\u200a\u202f\u205f\u3000\ufeff]/; // jshint ignore:line
21
+ var nonASCIIidentifierStartChars = "\xaa\xb5\xba\xc0-\xd6\xd8-\xf6\xf8-\u02c1\u02c6-\u02d1\u02e0-\u02e4\u02ec\u02ee\u0370-\u0374\u0376\u0377\u037a-\u037d\u0386\u0388-\u038a\u038c\u038e-\u03a1\u03a3-\u03f5\u03f7-\u0481\u048a-\u0527\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\u08a2-\u08ac\u0904-\u0939\u093d\u0950\u0958-\u0961\u0971-\u0977\u0979-\u097f\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\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-\u0c33\u0c35-\u0c39\u0c3d\u0c58\u0c59\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\u0d60\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-\u13f4\u1401-\u166c\u166f-\u167f\u1681-\u169a\u16a0-\u16ea\u16ee-\u16f0\u1700-\u170c\u170e-\u1711\u1720-\u1731\u1740-\u1751\u1760-\u176c\u176e-\u1770\u1780-\u17b3\u17d7\u17dc\u1820-\u1877\u1880-\u18a8\u18aa\u18b0-\u18f5\u1900-\u191c\u1950-\u196d\u1970-\u1974\u1980-\u19ab\u19c1-\u19c7\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\u2119-\u211d\u2124\u2126\u2128\u212a-\u212d\u212f-\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\u2e2f\u3005-\u3007\u3021-\u3029\u3031-\u3035\u3038-\u303c\u3041-\u3096\u309d-\u309f\u30a1-\u30fa\u30fc-\u30ff\u3105-\u312d\u3131-\u318e\u31a0-\u31ba\u31f0-\u31ff\u3400-\u4db5\u4e00-\u9fcc\ua000-\ua48c\ua4d0-\ua4fd\ua500-\ua60c\ua610-\ua61f\ua62a\ua62b\ua640-\ua66e\ua67f-\ua697\ua6a0-\ua6ef\ua717-\ua71f\ua722-\ua788\ua78b-\ua78e\ua790-\ua793\ua7a0-\ua7aa\ua7f8-\ua801\ua803-\ua805\ua807-\ua80a\ua80c-\ua822\ua840-\ua873\ua882-\ua8b3\ua8f2-\ua8f7\ua8fb\ua90a-\ua925\ua930-\ua946\ua960-\ua97c\ua984-\ua9b2\ua9cf\uaa00-\uaa28\uaa40-\uaa42\uaa44-\uaa4b\uaa60-\uaa76\uaa7a\uaa80-\uaaaf\uaab1\uaab5\uaab6\uaab9-\uaabd\uaac0\uaac2\uaadb-\uaadd\uaae0-\uaaea\uaaf2-\uaaf4\uab01-\uab06\uab09-\uab0e\uab11-\uab16\uab20-\uab26\uab28-\uab2e\uabc0-\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";
22
+ var nonASCIIidentifierChars = "\u0300-\u036f\u0483-\u0487\u0591-\u05bd\u05bf\u05c1\u05c2\u05c4\u05c5\u05c7\u0610-\u061a\u0620-\u0649\u0672-\u06d3\u06e7-\u06e8\u06fb-\u06fc\u0730-\u074a\u0800-\u0814\u081b-\u0823\u0825-\u0827\u0829-\u082d\u0840-\u0857\u08e4-\u08fe\u0900-\u0903\u093a-\u093c\u093e-\u094f\u0951-\u0957\u0962-\u0963\u0966-\u096f\u0981-\u0983\u09bc\u09be-\u09c4\u09c7\u09c8\u09d7\u09df-\u09e0\u0a01-\u0a03\u0a3c\u0a3e-\u0a42\u0a47\u0a48\u0a4b-\u0a4d\u0a51\u0a66-\u0a71\u0a75\u0a81-\u0a83\u0abc\u0abe-\u0ac5\u0ac7-\u0ac9\u0acb-\u0acd\u0ae2-\u0ae3\u0ae6-\u0aef\u0b01-\u0b03\u0b3c\u0b3e-\u0b44\u0b47\u0b48\u0b4b-\u0b4d\u0b56\u0b57\u0b5f-\u0b60\u0b66-\u0b6f\u0b82\u0bbe-\u0bc2\u0bc6-\u0bc8\u0bca-\u0bcd\u0bd7\u0be6-\u0bef\u0c01-\u0c03\u0c46-\u0c48\u0c4a-\u0c4d\u0c55\u0c56\u0c62-\u0c63\u0c66-\u0c6f\u0c82\u0c83\u0cbc\u0cbe-\u0cc4\u0cc6-\u0cc8\u0cca-\u0ccd\u0cd5\u0cd6\u0ce2-\u0ce3\u0ce6-\u0cef\u0d02\u0d03\u0d46-\u0d48\u0d57\u0d62-\u0d63\u0d66-\u0d6f\u0d82\u0d83\u0dca\u0dcf-\u0dd4\u0dd6\u0dd8-\u0ddf\u0df2\u0df3\u0e34-\u0e3a\u0e40-\u0e45\u0e50-\u0e59\u0eb4-\u0eb9\u0ec8-\u0ecd\u0ed0-\u0ed9\u0f18\u0f19\u0f20-\u0f29\u0f35\u0f37\u0f39\u0f41-\u0f47\u0f71-\u0f84\u0f86-\u0f87\u0f8d-\u0f97\u0f99-\u0fbc\u0fc6\u1000-\u1029\u1040-\u1049\u1067-\u106d\u1071-\u1074\u1082-\u108d\u108f-\u109d\u135d-\u135f\u170e-\u1710\u1720-\u1730\u1740-\u1750\u1772\u1773\u1780-\u17b2\u17dd\u17e0-\u17e9\u180b-\u180d\u1810-\u1819\u1920-\u192b\u1930-\u193b\u1951-\u196d\u19b0-\u19c0\u19c8-\u19c9\u19d0-\u19d9\u1a00-\u1a15\u1a20-\u1a53\u1a60-\u1a7c\u1a7f-\u1a89\u1a90-\u1a99\u1b46-\u1b4b\u1b50-\u1b59\u1b6b-\u1b73\u1bb0-\u1bb9\u1be6-\u1bf3\u1c00-\u1c22\u1c40-\u1c49\u1c5b-\u1c7d\u1cd0-\u1cd2\u1d00-\u1dbe\u1e01-\u1f15\u200c\u200d\u203f\u2040\u2054\u20d0-\u20dc\u20e1\u20e5-\u20f0\u2d81-\u2d96\u2de0-\u2dff\u3021-\u3028\u3099\u309a\ua640-\ua66d\ua674-\ua67d\ua69f\ua6f0-\ua6f1\ua7f8-\ua800\ua806\ua80b\ua823-\ua827\ua880-\ua881\ua8b4-\ua8c4\ua8d0-\ua8d9\ua8f3-\ua8f7\ua900-\ua909\ua926-\ua92d\ua930-\ua945\ua980-\ua983\ua9b3-\ua9c0\uaa00-\uaa27\uaa40-\uaa41\uaa4c-\uaa4d\uaa50-\uaa59\uaa7b\uaae0-\uaae9\uaaf2-\uaaf3\uabc0-\uabe1\uabec\uabed\uabf0-\uabf9\ufb20-\ufb28\ufe00-\ufe0f\ufe20-\ufe26\ufe33\ufe34\ufe4d-\ufe4f\uff10-\uff19\uff3f";
23
+ var nonASCIIidentifierStart = new RegExp("[" + nonASCIIidentifierStartChars + "]");
24
+ var nonASCIIidentifier = new RegExp("[" + nonASCIIidentifierStartChars + nonASCIIidentifierChars + "]");
25
+
26
+ // Whether a single character denotes a newline.
27
+
28
+ exports.newline = /[\n\r\u2028\u2029]/;
29
+
30
+ // Matches a whole line break (where CRLF is considered a single
31
+ // line break). Used to count lines.
32
+
33
+ // in javascript, these two differ
34
+ // in python they are the same, different methods are called on them
35
+ exports.lineBreak = new RegExp('\r\n|' + exports.newline.source);
36
+ exports.allLineBreaks = new RegExp(exports.lineBreak.source, 'g');
37
+
38
+
39
+ // Test whether a given character code starts an identifier.
40
+
41
+ exports.isIdentifierStart = function(code) {
42
+ // permit $ (36) and @ (64). @ is used in ES7 decorators.
43
+ if (code < 65) return code === 36 || code === 64;
44
+ // 65 through 91 are uppercase letters.
45
+ if (code < 91) return true;
46
+ // permit _ (95).
47
+ if (code < 97) return code === 95;
48
+ // 97 through 123 are lowercase letters.
49
+ if (code < 123) return true;
50
+ return code >= 0xaa && nonASCIIidentifierStart.test(String.fromCharCode(code));
51
+ };
52
+
53
+ // Test whether a given character is part of an identifier.
54
+
55
+ exports.isIdentifierChar = function(code) {
56
+ if (code < 48) return code === 36;
57
+ if (code < 58) return true;
58
+ if (code < 65) return false;
59
+ if (code < 91) return true;
60
+ if (code < 97) return code === 95;
61
+ if (code < 123) return true;
62
+ return code >= 0xaa && nonASCIIidentifier.test(String.fromCharCode(code));
63
+ };
@@ -0,0 +1,95 @@
1
+ /*jshint curly:true, eqeqeq:true, laxbreak:true, noempty:false */
2
+ /*
3
+
4
+ The MIT License (MIT)
5
+
6
+ Copyright (c) 2007-2017 Einar Lielmanis, Liam Newman, and contributors.
7
+
8
+ Permission is hereby granted, free of charge, to any person
9
+ obtaining a copy of this software and associated documentation files
10
+ (the "Software"), to deal in the Software without restriction,
11
+ including without limitation the rights to use, copy, modify, merge,
12
+ publish, distribute, sublicense, and/or sell copies of the Software,
13
+ and to permit persons to whom the Software is furnished to do so,
14
+ subject to the following conditions:
15
+
16
+ The above copyright notice and this permission notice shall be
17
+ included in all copies or substantial portions of the Software.
18
+
19
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
20
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
21
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
22
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
23
+ BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
24
+ ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
25
+ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
26
+ SOFTWARE.
27
+ */
28
+
29
+ function InputScanner(input) {
30
+ var _input = input;
31
+ var _input_length = _input.length;
32
+ var _position = 0;
33
+
34
+ this.back = function() {
35
+ _position -= 1;
36
+ };
37
+
38
+ this.hasNext = function() {
39
+ return _position < _input_length;
40
+ };
41
+
42
+ this.next = function() {
43
+ var val = null;
44
+ if (this.hasNext()) {
45
+ val = _input.charAt(_position);
46
+ _position += 1;
47
+ }
48
+ return val;
49
+ };
50
+
51
+ this.peek = function(index) {
52
+ var val = null;
53
+ index = index || 0;
54
+ index += _position;
55
+ if (index >= 0 && index < _input_length) {
56
+ val = _input.charAt(index);
57
+ }
58
+ return val;
59
+ };
60
+
61
+ this.peekCharCode = function(index) {
62
+ var val = 0;
63
+ index = index || 0;
64
+ index += _position;
65
+ if (index >= 0 && index < _input_length) {
66
+ val = _input.charCodeAt(index);
67
+ }
68
+ return val;
69
+ };
70
+
71
+ this.test = function(pattern, index) {
72
+ index = index || 0;
73
+ pattern.lastIndex = _position + index;
74
+ return pattern.test(_input);
75
+ };
76
+
77
+ this.testChar = function(pattern, index) {
78
+ var val = this.peek(index);
79
+ return val !== null && pattern.test(val);
80
+ };
81
+
82
+ this.match = function(pattern) {
83
+ pattern.lastIndex = _position;
84
+ var pattern_match = pattern.exec(_input);
85
+ if (pattern_match && pattern_match.index === _position) {
86
+ _position += pattern_match[0].length;
87
+ } else {
88
+ pattern_match = null;
89
+ }
90
+ return pattern_match;
91
+ };
92
+ }
93
+
94
+
95
+ module.exports.InputScanner = InputScanner;
@@ -0,0 +1,48 @@
1
+ /*jshint curly:true, eqeqeq:true, laxbreak:true, noempty:false */
2
+ /*
3
+
4
+ The MIT License (MIT)
5
+
6
+ Copyright (c) 2007-2017 Einar Lielmanis, Liam Newman, and contributors.
7
+
8
+ Permission is hereby granted, free of charge, to any person
9
+ obtaining a copy of this software and associated documentation files
10
+ (the "Software"), to deal in the Software without restriction,
11
+ including without limitation the rights to use, copy, modify, merge,
12
+ publish, distribute, sublicense, and/or sell copies of the Software,
13
+ and to permit persons to whom the Software is furnished to do so,
14
+ subject to the following conditions:
15
+
16
+ The above copyright notice and this permission notice shall be
17
+ included in all copies or substantial portions of the Software.
18
+
19
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
20
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
21
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
22
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
23
+ BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
24
+ ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
25
+ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
26
+ SOFTWARE.
27
+ */
28
+
29
+ function mergeOpts(allOptions, targetType) {
30
+ var finalOpts = {};
31
+ var name;
32
+
33
+ for (name in allOptions) {
34
+ if (name !== targetType) {
35
+ finalOpts[name] = allOptions[name];
36
+ }
37
+ }
38
+
39
+ //merge in the per type settings for the targetType
40
+ if (targetType in allOptions) {
41
+ for (name in allOptions[targetType]) {
42
+ finalOpts[name] = allOptions[targetType][name];
43
+ }
44
+ }
45
+ return finalOpts;
46
+ }
47
+
48
+ module.exports.mergeOpts = mergeOpts;