porffor 0.0.0-1989c22 → 0.0.0-1b0a5c6

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.
@@ -0,0 +1,59 @@
1
+ import util from 'node:util';
2
+
3
+ import parse from '../parse.js';
4
+
5
+ const tests = {
6
+ 'a': {},
7
+ 'a(b)': {},
8
+ 'a(b(c))': {},
9
+ 'ab': {},
10
+ '[ab]': {},
11
+ '[a-z]': {},
12
+ 'a*': {},
13
+ 'a+': {},
14
+ 'a?': {},
15
+ 'a(b)+': {},
16
+ '[^a]': {},
17
+ '[a^]': {},
18
+ '[^ab]': {},
19
+ '.': {},
20
+
21
+ // not range
22
+ '[-]': {},
23
+ '[0-]': {},
24
+ '[-0]': {},
25
+ '[\\s-\\S]': {},
26
+ '[\\s-.]': {},
27
+
28
+ '[\\S]': {},
29
+
30
+ '\\c': {},
31
+ '\\c0': {},
32
+ '\\cJ': {},
33
+
34
+ '\\x': {},
35
+ '\\x0': {},
36
+ '\\x0g': {},
37
+ '\\x0a': {},
38
+
39
+ '\\u': {},
40
+ '\\u0': {},
41
+ '\\u000': {},
42
+ '\\u000g': {},
43
+ '\\u000a': {},
44
+
45
+ /*
46
+ // email regexes
47
+ '^[a-zA-Z0-9_.+-]+@[a-zA-Z0-9-]+\.[a-zA-Z0-9-.]+$': {},
48
+
49
+ // input type=email from HTML spec
50
+ // https://html.spec.whatwg.org/multipage/input.html#email-state-(type=email)
51
+ // simpler form
52
+ '^[a-zA-Z0-9.!#$%&’*+/=?^_`{|}~-]+@[a-zA-Z0-9-]+(?:\\.[a-zA-Z0-9-]+)*$': {},
53
+ // full/complex form
54
+ '^[a-zA-Z0-9.!#$%&\'*+\\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$': {}*/
55
+ };
56
+
57
+ for (const str in tests) {
58
+ console.log(str, util.inspect(parse(str), false, null, true));
59
+ }
package/runner/index.js CHANGED
@@ -1,35 +1,55 @@
1
- #!/usr/bin/env node
2
-
3
- import compile from '../compiler/wrap.js';
4
- import fs from 'node:fs';
5
-
6
- const file = process.argv.slice(2).find(x => x[0] !== '-');
7
- if (!file) {
8
- // run repl if no file given
9
- await import('./repl.js');
10
-
11
- // do nothing for the rest of this file
12
- await new Promise(() => {});
13
- }
14
-
15
- const source = fs.readFileSync(file, 'utf8');
16
-
17
- let cache = '';
18
- const print = str => {
19
- cache += str;
20
-
21
- if (str === '\n') {
22
- process.stdout.write(cache);
23
- cache = '';
24
- }
25
- };
26
-
27
- try {
28
- const { exports } = await compile(source, process.argv.includes('--module') ? [ 'module' ] : [], {}, print);
29
-
30
- exports.main();
31
- if (cache) process.stdout.write(cache);
32
- } catch (e) {
33
- if (cache) process.stdout.write(cache);
34
- console.error(`${e.constructor.name}: ${e.message}`);
1
+ #!/usr/bin/env node
2
+
3
+ import compile from '../compiler/wrap.js';
4
+ import fs from 'node:fs';
5
+
6
+ if (process.argv.includes('-compile-hints')) {
7
+ const v8 = await import('node:v8');
8
+ v8.setFlagsFromString(`--experimental-wasm-compilation-hints`);
9
+
10
+ // see also these flags:
11
+ // --experimental-wasm-branch-hinting
12
+ // --experimental-wasm-extended-const
13
+ // --experimental-wasm-inlining (?)
14
+ // --experimental-wasm-js-inlining (?)
15
+ // --experimental-wasm-return-call (on by default)
16
+ }
17
+
18
+ const file = process.argv.slice(2).find(x => x[0] !== '-');
19
+ if (!file) {
20
+ if (process.argv.includes('-v')) {
21
+ // just print version
22
+ console.log((await import('./version.js')).default);
23
+ process.exit(0);
24
+ }
25
+
26
+ // run repl if no file given
27
+ await import('./repl.js');
28
+
29
+ // do nothing for the rest of this file
30
+ await new Promise(() => {});
31
+ }
32
+
33
+ const source = fs.readFileSync(file, 'utf8');
34
+
35
+ let cache = '';
36
+ const print = str => {
37
+ /* cache += str;
38
+
39
+ if (str === '\n') {
40
+ process.stdout.write(cache);
41
+ cache = '';
42
+ } */
43
+
44
+ process.stdout.write(str);
45
+ };
46
+
47
+ try {
48
+ const { exports } = await compile(source, process.argv.includes('--module') ? [ 'module' ] : [], {}, print);
49
+
50
+ exports.main();
51
+ if (cache) process.stdout.write(cache);
52
+ } catch (e) {
53
+ if (cache) process.stdout.write(cache);
54
+ console.error(process.argv.includes('-i') ? e : `${e.constructor.name}: ${e.message}`);
35
55
  }
package/runner/info.js CHANGED
@@ -36,7 +36,7 @@ const print = str => {
36
36
  };
37
37
 
38
38
  const t0 = performance.now();
39
- const { wasm, exports } = await compile(source, raw ? [ 'module' ] : [ 'module', 'info' ], {}, print);
39
+ const { wasm, exports, pages } = await compile(source, raw ? [ 'module' ] : [ 'module', 'info' ], {}, print);
40
40
 
41
41
  if (!raw && typeof Deno === 'undefined') fs.writeFileSync('out.wasm', Buffer.from(wasm));
42
42
 
@@ -51,4 +51,39 @@ if (!process.argv.includes('-no-run')) {
51
51
  }
52
52
 
53
53
  if (!raw) console.log(bold(`wasm binary is ${wasm.byteLength} bytes`));
54
- if (!raw) console.log(`total: ${(performance.now() - t0).toFixed(2)}ms`);
54
+ if (!raw) console.log(`total: ${(performance.now() - t0).toFixed(2)}ms`);
55
+
56
+ if (!raw && process.argv.includes('-mem') && exports.$) {
57
+ console.log();
58
+
59
+ let lastMemory, lastPages;
60
+ const PageSize = 65536;
61
+ const memoryToString = mem => {
62
+ let out = '';
63
+ const pages = lastPages.length;
64
+ const wasmPages = mem.buffer.byteLength / PageSize;
65
+
66
+ out += `\x1B[1mallocated ${mem.buffer.byteLength / 1024}KiB\x1B[0m for ${pages} things using ${wasmPages} Wasm page${wasmPages === 1 ? '' : 's'}\n`;
67
+
68
+ const buf = new Uint8Array(mem.buffer);
69
+
70
+ for (let i = 0; i < pages; i++) {
71
+ out += `\x1B[36m${lastPages[i]}\x1B[2m | \x1B[0m`;
72
+
73
+ for (let j = 0; j < 50; j++) {
74
+ const val = buf[i * pageSize + j];
75
+ if (val === 0) out += '\x1B[2m';
76
+ out += val.toString(16).padStart(2, '0');
77
+ if (val === 0) out += '\x1B[0m';
78
+ out += ' ';
79
+ }
80
+ out += '\n';
81
+ }
82
+
83
+ return out;
84
+ };
85
+
86
+ lastPages = [...pages.keys()];
87
+ lastMemory = exports.$;
88
+ console.log(memoryToString(lastMemory));
89
+ }
package/runner/repl.js CHANGED
@@ -1,14 +1,7 @@
1
1
  import compile from '../compiler/wrap.js';
2
+ import rev from './version.js';
2
3
 
3
4
  import repl from 'node:repl';
4
- import fs from 'node:fs';
5
-
6
- let rev = 'unknown';
7
- try {
8
- rev = fs.readFileSync(new URL('../.git/refs/heads/main', import.meta.url), 'utf8').trim().slice(0, 7);
9
- } catch {
10
- rev = JSON.parse(fs.readFileSync(new URL('../package.json', import.meta.url), 'utf8')).version.split('-')[1];
11
- }
12
5
 
13
6
  // process.argv.push('-O0'); // disable opts
14
7
 
@@ -48,13 +41,15 @@ const memoryToString = mem => {
48
41
  return out;
49
42
  };
50
43
 
44
+ const alwaysPrev = process.argv.includes('-prev');
45
+
51
46
  let prev = '';
52
47
  const run = async (source, _context, _filename, callback, run = true) => {
53
48
  let toRun = prev + source.trim();
54
- // prev = toRun + ';\n';
49
+ if (alwaysPrev) prev = toRun + ';\n';
55
50
 
56
51
  const { exports, wasm, pages } = await compile(toRun, []);
57
- fs.writeFileSync('out.wasm', Buffer.from(wasm));
52
+ // fs.writeFileSync('out.wasm', Buffer.from(wasm));
58
53
 
59
54
  if (run && exports.$) {
60
55
  lastMemory = exports.$;
@@ -64,7 +59,7 @@ const run = async (source, _context, _filename, callback, run = true) => {
64
59
  const ret = run ? exports.main() : undefined;
65
60
  callback(null, ret);
66
61
 
67
- if (source.includes(' = ') || source.includes('let ') || source.includes('var ') || source.includes('const ') || source.includes('function ')) prev = toRun + ';\n';
62
+ if (!alwaysPrev && (source.includes(' = ') || source.includes('let ') || source.includes('var ') || source.includes('const ') || source.includes('function '))) prev = toRun + ';\n';
68
63
  // prev = toRun + ';\n';
69
64
  };
70
65
 
@@ -8,7 +8,8 @@ const source = fs.readFileSync(file, 'utf8');
8
8
  const { wasm } = await compile(source);
9
9
 
10
10
  // const out = `(async () => { const print = str => process.stdout.write(str); (await WebAssembly.instantiate(Uint8Array.from([${wasm.toString()}]), {'': { p: i => print(i.toString()), c: i => print(String.fromCharCode(i))}})).instance.exports.m()})()`;
11
- const out = `new WebAssembly.Instance(new WebAssembly.Module(new Uint8Array([${wasm.toString()}])),{'':{p:i=>process.stdout.write(i.toString())}}).exports.m()`;
11
+ // const out = `new WebAssembly.Instance(new WebAssembly.Module(new Uint8Array([${wasm.toString()}])),{'':{p:i=>process.stdout.write(i.toString())}}).exports.m()`;
12
+ const out = `const a=new WebAssembly.Instance(new WebAssembly.Module(new Uint8Array([${wasm.toString()}])));const b=a.exports.m();console.log(Array.from(new Uint16Array(a.exports.$.buffer,b+4,new Int32Array(a.exports.$.buffer,b,1))).map(x=>String.fromCharCode(x)).join(''))`;
12
13
 
13
14
  console.log(out);
14
15
  eval(out);
@@ -0,0 +1,10 @@
1
+ import fs from 'node:fs';
2
+
3
+ let rev = 'unknown';
4
+ try {
5
+ rev = fs.readFileSync(new URL('../.git/refs/heads/main', import.meta.url), 'utf8').trim().slice(0, 7);
6
+ } catch {
7
+ rev = JSON.parse(fs.readFileSync(new URL('../package.json', import.meta.url), 'utf8')).version.split('-')[1].slice(0, 7);
8
+ }
9
+
10
+ export default rev;
package/tmp.c ADDED
@@ -0,0 +1,58 @@
1
+ #ifdef _WIN32
2
+ #include <windows.h>
3
+ #else
4
+ #include <time.h>
5
+ #endif
6
+
7
+ #include <stdio.h>
8
+
9
+ double aux(double n, double acc1, double acc2) {
10
+ if (n == 0e+0) {
11
+ return acc1;
12
+ }
13
+ if (n == 1e+0) {
14
+ return acc2;
15
+ }
16
+ return aux(n - 1e+0, acc2, acc1 + acc2);
17
+ }
18
+
19
+ double fib(double n) {
20
+ return aux(n, 0e+0, 1e+0);
21
+ }
22
+
23
+ double test(double n, double count) {
24
+ double res = 0;
25
+ double i = 0;
26
+
27
+ i = 0e+0;
28
+ while (i < count) {
29
+ res = fib(n);
30
+ i = i + 1e+0;
31
+ }
32
+ return res;
33
+ }
34
+
35
+ double inline __performance_now() {
36
+ double _time_out;
37
+ #ifdef _WIN32
38
+ LARGE_INTEGER _time_freq, _time_t;
39
+ QueryPerformanceFrequency(&_time_freq);
40
+ QueryPerformanceCounter(&_time_t);
41
+ _time_out = ((double)_time_t.QuadPart / _time_freq.QuadPart) * 1000.;
42
+ #else
43
+ struct timespec _time;
44
+ clock_gettime(CLOCK_MONOTONIC, &_time);
45
+ _time_out = _time.tv_nsec / 1000000.;
46
+ #endif
47
+ return _time_out;
48
+ }
49
+
50
+ int main() {
51
+ double t = 0;
52
+
53
+ t = __performance_now();
54
+ // Sleep(1000);
55
+ printf("%f\n", test(4.6e+1, 1e+7));
56
+ printf("%f\n", (__performance_now() - t));
57
+ }
58
+