@hpcc-js/wasm 1.19.0 → 1.20.0
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.
- package/bin/sfx-wasm.mjs +14 -6
- package/bin/sfx-wasm.mjs.map +1 -1
- package/dist/graphviz.es6.js +3 -0
- package/dist/graphviz.es6.js.map +1 -1
- package/dist/graphviz.js +3 -0
- package/dist/graphviz.js.map +1 -1
- package/dist/graphvizlib.wasm +0 -0
- package/dist/index.es6.js +5 -680
- package/dist/index.es6.js.map +1 -1
- package/dist/index.js +4 -680
- package/dist/index.js.map +1 -1
- package/dist/index.min.js +1 -1
- package/dist/index.min.js.map +1 -1
- package/dist/index.node.es6.mjs +4 -679
- package/dist/index.node.es6.mjs.map +1 -1
- package/dist/index.node.js +3 -679
- package/dist/index.node.js.map +1 -1
- package/dist/sfx-graphviz.esm.js +890 -0
- package/dist/sfx-graphviz.esm.js.map +1 -0
- package/dist/sfx-graphviz.js +904 -0
- package/dist/sfx-graphviz.js.map +1 -0
- package/dist/sfx-graphviz.min.js +1 -0
- package/dist/sfx-graphviz.min.js.map +1 -0
- package/package.json +13 -3
- package/types/__tests__/browser-tests.d.ts +2 -0
- package/types/__tests__/browser-tests.d.ts.map +1 -0
- package/types/__tests__/index-common.d.ts +5 -0
- package/types/__tests__/index-common.d.ts.map +1 -0
- package/types/__tests__/index-node.d.ts +3 -0
- package/types/__tests__/index-node.d.ts.map +1 -0
- package/types/__tests__/index.d.ts +2 -4
- package/types/__tests__/index.d.ts.map +1 -1
- package/types/__tests__/node-tests.d.ts +2 -0
- package/types/__tests__/node-tests.d.ts.map +1 -0
- package/types/__tests__/worker-browser.d.ts +2 -0
- package/types/__tests__/worker-browser.d.ts.map +1 -0
- package/types/__tests__/worker-node.d.ts +2 -0
- package/types/__tests__/worker-node.d.ts.map +1 -0
- package/types/extract.d.ts.map +1 -1
- package/types/graphviz.d.ts.map +1 -1
- package/types/index-common.d.ts +0 -1
- package/types/index-common.d.ts.map +1 -1
- package/types/sfx-graphviz.d.ts +59 -0
- package/types/sfx-graphviz.d.ts.map +1 -0
- package/dist/extract.es6.js +0 -680
- package/dist/extract.es6.js.map +0 -1
- package/dist/extract.js +0 -690
- package/dist/extract.js.map +0 -1
package/dist/index.node.es6.mjs
CHANGED
|
@@ -250,684 +250,6 @@ function parse(xml, callback, wasmFolder, wasmBinary) {
|
|
|
250
250
|
});
|
|
251
251
|
}
|
|
252
252
|
|
|
253
|
-
// Some numerical data is initialized as -1 even when it doesn't need initialization to help the JIT infer types
|
|
254
|
-
// aliases for shorter compressed code (most minifers don't do this)
|
|
255
|
-
var ab = ArrayBuffer, u8 = Uint8Array, u16 = Uint16Array, i16 = Int16Array, i32 = Int32Array;
|
|
256
|
-
var slc = function (v, s, e) {
|
|
257
|
-
if (u8.prototype.slice)
|
|
258
|
-
return u8.prototype.slice.call(v, s, e);
|
|
259
|
-
if (s == null || s < 0)
|
|
260
|
-
s = 0;
|
|
261
|
-
if (e == null || e > v.length)
|
|
262
|
-
e = v.length;
|
|
263
|
-
var n = new u8(e - s);
|
|
264
|
-
n.set(v.subarray(s, e));
|
|
265
|
-
return n;
|
|
266
|
-
};
|
|
267
|
-
var fill = function (v, n, s, e) {
|
|
268
|
-
if (u8.prototype.fill)
|
|
269
|
-
return u8.prototype.fill.call(v, n, s, e);
|
|
270
|
-
if (s == null || s < 0)
|
|
271
|
-
s = 0;
|
|
272
|
-
if (e == null || e > v.length)
|
|
273
|
-
e = v.length;
|
|
274
|
-
for (; s < e; ++s)
|
|
275
|
-
v[s] = n;
|
|
276
|
-
return v;
|
|
277
|
-
};
|
|
278
|
-
var cpw = function (v, t, s, e) {
|
|
279
|
-
if (u8.prototype.copyWithin)
|
|
280
|
-
return u8.prototype.copyWithin.call(v, t, s, e);
|
|
281
|
-
if (s == null || s < 0)
|
|
282
|
-
s = 0;
|
|
283
|
-
if (e == null || e > v.length)
|
|
284
|
-
e = v.length;
|
|
285
|
-
while (s < e) {
|
|
286
|
-
v[t++] = v[s++];
|
|
287
|
-
}
|
|
288
|
-
};
|
|
289
|
-
// error codes
|
|
290
|
-
var ec = [
|
|
291
|
-
'invalid zstd data',
|
|
292
|
-
'window size too large (>2046MB)',
|
|
293
|
-
'invalid block type',
|
|
294
|
-
'FSE accuracy too high',
|
|
295
|
-
'match distance too far back',
|
|
296
|
-
'unexpected EOF'
|
|
297
|
-
];
|
|
298
|
-
var err = function (ind, msg, nt) {
|
|
299
|
-
var e = new Error(msg || ec[ind]);
|
|
300
|
-
e.code = ind;
|
|
301
|
-
if (Error.captureStackTrace)
|
|
302
|
-
Error.captureStackTrace(e, err);
|
|
303
|
-
if (!nt)
|
|
304
|
-
throw e;
|
|
305
|
-
return e;
|
|
306
|
-
};
|
|
307
|
-
var rb = function (d, b, n) {
|
|
308
|
-
var i = 0, o = 0;
|
|
309
|
-
for (; i < n; ++i)
|
|
310
|
-
o |= d[b++] << (i << 3);
|
|
311
|
-
return o;
|
|
312
|
-
};
|
|
313
|
-
var b4 = function (d, b) { return (d[b] | (d[b + 1] << 8) | (d[b + 2] << 16) | (d[b + 3] << 24)) >>> 0; };
|
|
314
|
-
// read Zstandard frame header
|
|
315
|
-
var rzfh = function (dat, w) {
|
|
316
|
-
var n3 = dat[0] | (dat[1] << 8) | (dat[2] << 16);
|
|
317
|
-
if (n3 == 0x2FB528 && dat[3] == 253) {
|
|
318
|
-
// Zstandard
|
|
319
|
-
var flg = dat[4];
|
|
320
|
-
// single segment checksum dict flag frame content flag
|
|
321
|
-
var ss = (flg >> 5) & 1, cc = (flg >> 2) & 1, df = flg & 3, fcf = flg >> 6;
|
|
322
|
-
if (flg & 8)
|
|
323
|
-
err(0);
|
|
324
|
-
// byte
|
|
325
|
-
var bt = 6 - ss;
|
|
326
|
-
// dict bytes
|
|
327
|
-
var db = df == 3 ? 4 : df;
|
|
328
|
-
// dictionary id
|
|
329
|
-
var di = rb(dat, bt, db);
|
|
330
|
-
bt += db;
|
|
331
|
-
// frame size bytes
|
|
332
|
-
var fsb = fcf ? (1 << fcf) : ss;
|
|
333
|
-
// frame source size
|
|
334
|
-
var fss = rb(dat, bt, fsb) + ((fcf == 1) && 256);
|
|
335
|
-
// window size
|
|
336
|
-
var ws = fss;
|
|
337
|
-
if (!ss) {
|
|
338
|
-
// window descriptor
|
|
339
|
-
var wb = 1 << (10 + (dat[5] >> 3));
|
|
340
|
-
ws = wb + (wb >> 3) * (dat[5] & 7);
|
|
341
|
-
}
|
|
342
|
-
if (ws > 2145386496)
|
|
343
|
-
err(1);
|
|
344
|
-
var buf = new u8((w == 1 ? (fss || ws) : w ? 0 : ws) + 12);
|
|
345
|
-
buf[0] = 1, buf[4] = 4, buf[8] = 8;
|
|
346
|
-
return {
|
|
347
|
-
b: bt + fsb,
|
|
348
|
-
y: 0,
|
|
349
|
-
l: 0,
|
|
350
|
-
d: di,
|
|
351
|
-
w: (w && w != 1) ? w : buf.subarray(12),
|
|
352
|
-
e: ws,
|
|
353
|
-
o: new i32(buf.buffer, 0, 3),
|
|
354
|
-
u: fss,
|
|
355
|
-
c: cc,
|
|
356
|
-
m: Math.min(131072, ws)
|
|
357
|
-
};
|
|
358
|
-
}
|
|
359
|
-
else if (((n3 >> 4) | (dat[3] << 20)) == 0x184D2A5) {
|
|
360
|
-
// skippable
|
|
361
|
-
return b4(dat, 4) + 8;
|
|
362
|
-
}
|
|
363
|
-
err(0);
|
|
364
|
-
};
|
|
365
|
-
// most significant bit for nonzero
|
|
366
|
-
var msb = function (val) {
|
|
367
|
-
var bits = 0;
|
|
368
|
-
for (; (1 << bits) <= val; ++bits)
|
|
369
|
-
;
|
|
370
|
-
return bits - 1;
|
|
371
|
-
};
|
|
372
|
-
// read finite state entropy
|
|
373
|
-
var rfse = function (dat, bt, mal) {
|
|
374
|
-
// table pos
|
|
375
|
-
var tpos = (bt << 3) + 4;
|
|
376
|
-
// accuracy log
|
|
377
|
-
var al = (dat[bt] & 15) + 5;
|
|
378
|
-
if (al > mal)
|
|
379
|
-
err(3);
|
|
380
|
-
// size
|
|
381
|
-
var sz = 1 << al;
|
|
382
|
-
// probabilities symbols repeat index high threshold
|
|
383
|
-
var probs = sz, sym = -1, re = -1, i = -1, ht = sz;
|
|
384
|
-
// optimization: single allocation is much faster
|
|
385
|
-
var buf = new ab(512 + (sz << 2));
|
|
386
|
-
var freq = new i16(buf, 0, 256);
|
|
387
|
-
// same view as freq
|
|
388
|
-
var dstate = new u16(buf, 0, 256);
|
|
389
|
-
var nstate = new u16(buf, 512, sz);
|
|
390
|
-
var bb1 = 512 + (sz << 1);
|
|
391
|
-
var syms = new u8(buf, bb1, sz);
|
|
392
|
-
var nbits = new u8(buf, bb1 + sz);
|
|
393
|
-
while (sym < 255 && probs > 0) {
|
|
394
|
-
var bits = msb(probs + 1);
|
|
395
|
-
var cbt = tpos >> 3;
|
|
396
|
-
// mask
|
|
397
|
-
var msk = (1 << (bits + 1)) - 1;
|
|
398
|
-
var val = ((dat[cbt] | (dat[cbt + 1] << 8) | (dat[cbt + 2] << 16)) >> (tpos & 7)) & msk;
|
|
399
|
-
// mask (1 fewer bit)
|
|
400
|
-
var msk1fb = (1 << bits) - 1;
|
|
401
|
-
// max small value
|
|
402
|
-
var msv = msk - probs - 1;
|
|
403
|
-
// small value
|
|
404
|
-
var sval = val & msk1fb;
|
|
405
|
-
if (sval < msv)
|
|
406
|
-
tpos += bits, val = sval;
|
|
407
|
-
else {
|
|
408
|
-
tpos += bits + 1;
|
|
409
|
-
if (val > msk1fb)
|
|
410
|
-
val -= msv;
|
|
411
|
-
}
|
|
412
|
-
freq[++sym] = --val;
|
|
413
|
-
if (val == -1) {
|
|
414
|
-
probs += val;
|
|
415
|
-
syms[--ht] = sym;
|
|
416
|
-
}
|
|
417
|
-
else
|
|
418
|
-
probs -= val;
|
|
419
|
-
if (!val) {
|
|
420
|
-
do {
|
|
421
|
-
// repeat byte
|
|
422
|
-
var rbt = tpos >> 3;
|
|
423
|
-
re = ((dat[rbt] | (dat[rbt + 1] << 8)) >> (tpos & 7)) & 3;
|
|
424
|
-
tpos += 2;
|
|
425
|
-
sym += re;
|
|
426
|
-
} while (re == 3);
|
|
427
|
-
}
|
|
428
|
-
}
|
|
429
|
-
if (sym > 255 || probs)
|
|
430
|
-
err(0);
|
|
431
|
-
var sympos = 0;
|
|
432
|
-
// sym step (coprime with sz - formula from zstd source)
|
|
433
|
-
var sstep = (sz >> 1) + (sz >> 3) + 3;
|
|
434
|
-
// sym mask
|
|
435
|
-
var smask = sz - 1;
|
|
436
|
-
for (var s = 0; s <= sym; ++s) {
|
|
437
|
-
var sf = freq[s];
|
|
438
|
-
if (sf < 1) {
|
|
439
|
-
dstate[s] = -sf;
|
|
440
|
-
continue;
|
|
441
|
-
}
|
|
442
|
-
// This is split into two loops in zstd to avoid branching, but as JS is higher-level that is unnecessary
|
|
443
|
-
for (i = 0; i < sf; ++i) {
|
|
444
|
-
syms[sympos] = s;
|
|
445
|
-
do {
|
|
446
|
-
sympos = (sympos + sstep) & smask;
|
|
447
|
-
} while (sympos >= ht);
|
|
448
|
-
}
|
|
449
|
-
}
|
|
450
|
-
// After spreading symbols, should be zero again
|
|
451
|
-
if (sympos)
|
|
452
|
-
err(0);
|
|
453
|
-
for (i = 0; i < sz; ++i) {
|
|
454
|
-
// next state
|
|
455
|
-
var ns = dstate[syms[i]]++;
|
|
456
|
-
// num bits
|
|
457
|
-
var nb = nbits[i] = al - msb(ns);
|
|
458
|
-
nstate[i] = (ns << nb) - sz;
|
|
459
|
-
}
|
|
460
|
-
return [(tpos + 7) >> 3, {
|
|
461
|
-
b: al,
|
|
462
|
-
s: syms,
|
|
463
|
-
n: nbits,
|
|
464
|
-
t: nstate
|
|
465
|
-
}];
|
|
466
|
-
};
|
|
467
|
-
// read huffman
|
|
468
|
-
var rhu = function (dat, bt) {
|
|
469
|
-
// index weight count
|
|
470
|
-
var i = 0, wc = -1;
|
|
471
|
-
// buffer header byte
|
|
472
|
-
var buf = new u8(292), hb = dat[bt];
|
|
473
|
-
// huffman weights
|
|
474
|
-
var hw = buf.subarray(0, 256);
|
|
475
|
-
// rank count
|
|
476
|
-
var rc = buf.subarray(256, 268);
|
|
477
|
-
// rank index
|
|
478
|
-
var ri = new u16(buf.buffer, 268);
|
|
479
|
-
// NOTE: at this point bt is 1 less than expected
|
|
480
|
-
if (hb < 128) {
|
|
481
|
-
// end byte, fse decode table
|
|
482
|
-
var _a = rfse(dat, bt + 1, 6), ebt = _a[0], fdt = _a[1];
|
|
483
|
-
bt += hb;
|
|
484
|
-
var epos = ebt << 3;
|
|
485
|
-
// last byte
|
|
486
|
-
var lb = dat[bt];
|
|
487
|
-
if (!lb)
|
|
488
|
-
err(0);
|
|
489
|
-
// state1 state2 state1 bits state2 bits
|
|
490
|
-
var st1 = 0, st2 = 0, btr1 = fdt.b, btr2 = btr1;
|
|
491
|
-
// fse pos
|
|
492
|
-
// pre-increment to account for original deficit of 1
|
|
493
|
-
var fpos = (++bt << 3) - 8 + msb(lb);
|
|
494
|
-
for (;;) {
|
|
495
|
-
fpos -= btr1;
|
|
496
|
-
if (fpos < epos)
|
|
497
|
-
break;
|
|
498
|
-
var cbt = fpos >> 3;
|
|
499
|
-
st1 += ((dat[cbt] | (dat[cbt + 1] << 8)) >> (fpos & 7)) & ((1 << btr1) - 1);
|
|
500
|
-
hw[++wc] = fdt.s[st1];
|
|
501
|
-
fpos -= btr2;
|
|
502
|
-
if (fpos < epos)
|
|
503
|
-
break;
|
|
504
|
-
cbt = fpos >> 3;
|
|
505
|
-
st2 += ((dat[cbt] | (dat[cbt + 1] << 8)) >> (fpos & 7)) & ((1 << btr2) - 1);
|
|
506
|
-
hw[++wc] = fdt.s[st2];
|
|
507
|
-
btr1 = fdt.n[st1];
|
|
508
|
-
st1 = fdt.t[st1];
|
|
509
|
-
btr2 = fdt.n[st2];
|
|
510
|
-
st2 = fdt.t[st2];
|
|
511
|
-
}
|
|
512
|
-
if (++wc > 255)
|
|
513
|
-
err(0);
|
|
514
|
-
}
|
|
515
|
-
else {
|
|
516
|
-
wc = hb - 127;
|
|
517
|
-
for (; i < wc; i += 2) {
|
|
518
|
-
var byte = dat[++bt];
|
|
519
|
-
hw[i] = byte >> 4;
|
|
520
|
-
hw[i + 1] = byte & 15;
|
|
521
|
-
}
|
|
522
|
-
++bt;
|
|
523
|
-
}
|
|
524
|
-
// weight exponential sum
|
|
525
|
-
var wes = 0;
|
|
526
|
-
for (i = 0; i < wc; ++i) {
|
|
527
|
-
var wt = hw[i];
|
|
528
|
-
// bits must be at most 11, same as weight
|
|
529
|
-
if (wt > 11)
|
|
530
|
-
err(0);
|
|
531
|
-
wes += wt && (1 << (wt - 1));
|
|
532
|
-
}
|
|
533
|
-
// max bits
|
|
534
|
-
var mb = msb(wes) + 1;
|
|
535
|
-
// table size
|
|
536
|
-
var ts = 1 << mb;
|
|
537
|
-
// remaining sum
|
|
538
|
-
var rem = ts - wes;
|
|
539
|
-
// must be power of 2
|
|
540
|
-
if (rem & (rem - 1))
|
|
541
|
-
err(0);
|
|
542
|
-
hw[wc++] = msb(rem) + 1;
|
|
543
|
-
for (i = 0; i < wc; ++i) {
|
|
544
|
-
var wt = hw[i];
|
|
545
|
-
++rc[hw[i] = wt && (mb + 1 - wt)];
|
|
546
|
-
}
|
|
547
|
-
// huf buf
|
|
548
|
-
var hbuf = new u8(ts << 1);
|
|
549
|
-
// symbols num bits
|
|
550
|
-
var syms = hbuf.subarray(0, ts), nb = hbuf.subarray(ts);
|
|
551
|
-
ri[mb] = 0;
|
|
552
|
-
for (i = mb; i > 0; --i) {
|
|
553
|
-
var pv = ri[i];
|
|
554
|
-
fill(nb, i, pv, ri[i - 1] = pv + rc[i] * (1 << (mb - i)));
|
|
555
|
-
}
|
|
556
|
-
if (ri[0] != ts)
|
|
557
|
-
err(0);
|
|
558
|
-
for (i = 0; i < wc; ++i) {
|
|
559
|
-
var bits = hw[i];
|
|
560
|
-
if (bits) {
|
|
561
|
-
var code = ri[bits];
|
|
562
|
-
fill(syms, i, code, ri[bits] = code + (1 << (mb - bits)));
|
|
563
|
-
}
|
|
564
|
-
}
|
|
565
|
-
return [bt, {
|
|
566
|
-
n: nb,
|
|
567
|
-
b: mb,
|
|
568
|
-
s: syms
|
|
569
|
-
}];
|
|
570
|
-
};
|
|
571
|
-
// Tables generated using this:
|
|
572
|
-
// https://gist.github.com/101arrowz/a979452d4355992cbf8f257cbffc9edd
|
|
573
|
-
// default literal length table
|
|
574
|
-
var dllt = rfse(/*#__PURE__*/ new u8([
|
|
575
|
-
81, 16, 99, 140, 49, 198, 24, 99, 12, 33, 196, 24, 99, 102, 102, 134, 70, 146, 4
|
|
576
|
-
]), 0, 6)[1];
|
|
577
|
-
// default match length table
|
|
578
|
-
var dmlt = rfse(/*#__PURE__*/ new u8([
|
|
579
|
-
33, 20, 196, 24, 99, 140, 33, 132, 16, 66, 8, 33, 132, 16, 66, 8, 33, 68, 68, 68, 68, 68, 68, 68, 68, 36, 9
|
|
580
|
-
]), 0, 6)[1];
|
|
581
|
-
// default offset code table
|
|
582
|
-
var doct = rfse(/*#__PURE__*/ new u8([
|
|
583
|
-
32, 132, 16, 66, 102, 70, 68, 68, 68, 68, 36, 73, 2
|
|
584
|
-
]), 0, 5)[1];
|
|
585
|
-
// bits to baseline
|
|
586
|
-
var b2bl = function (b, s) {
|
|
587
|
-
var len = b.length, bl = new i32(len);
|
|
588
|
-
for (var i = 0; i < len; ++i) {
|
|
589
|
-
bl[i] = s;
|
|
590
|
-
s += 1 << b[i];
|
|
591
|
-
}
|
|
592
|
-
return bl;
|
|
593
|
-
};
|
|
594
|
-
// literal length bits
|
|
595
|
-
var llb = /*#__PURE__ */ new u8(( /*#__PURE__ */new i32([
|
|
596
|
-
0, 0, 0, 0, 16843009, 50528770, 134678020, 202050057, 269422093
|
|
597
|
-
])).buffer, 0, 36);
|
|
598
|
-
// literal length baseline
|
|
599
|
-
var llbl = /*#__PURE__ */ b2bl(llb, 0);
|
|
600
|
-
// match length bits
|
|
601
|
-
var mlb = /*#__PURE__ */ new u8(( /*#__PURE__ */new i32([
|
|
602
|
-
0, 0, 0, 0, 0, 0, 0, 0, 16843009, 50528770, 117769220, 185207048, 252579084, 16
|
|
603
|
-
])).buffer, 0, 53);
|
|
604
|
-
// match length baseline
|
|
605
|
-
var mlbl = /*#__PURE__ */ b2bl(mlb, 3);
|
|
606
|
-
// decode huffman stream
|
|
607
|
-
var dhu = function (dat, out, hu) {
|
|
608
|
-
var len = dat.length, ss = out.length, lb = dat[len - 1], msk = (1 << hu.b) - 1, eb = -hu.b;
|
|
609
|
-
if (!lb)
|
|
610
|
-
err(0);
|
|
611
|
-
var st = 0, btr = hu.b, pos = (len << 3) - 8 + msb(lb) - btr, i = -1;
|
|
612
|
-
for (; pos > eb && i < ss;) {
|
|
613
|
-
var cbt = pos >> 3;
|
|
614
|
-
var val = (dat[cbt] | (dat[cbt + 1] << 8) | (dat[cbt + 2] << 16)) >> (pos & 7);
|
|
615
|
-
st = ((st << btr) | val) & msk;
|
|
616
|
-
out[++i] = hu.s[st];
|
|
617
|
-
pos -= (btr = hu.n[st]);
|
|
618
|
-
}
|
|
619
|
-
if (pos != eb || i + 1 != ss)
|
|
620
|
-
err(0);
|
|
621
|
-
};
|
|
622
|
-
// decode huffman stream 4x
|
|
623
|
-
// TODO: use workers to parallelize
|
|
624
|
-
var dhu4 = function (dat, out, hu) {
|
|
625
|
-
var bt = 6;
|
|
626
|
-
var ss = out.length, sz1 = (ss + 3) >> 2, sz2 = sz1 << 1, sz3 = sz1 + sz2;
|
|
627
|
-
dhu(dat.subarray(bt, bt += dat[0] | (dat[1] << 8)), out.subarray(0, sz1), hu);
|
|
628
|
-
dhu(dat.subarray(bt, bt += dat[2] | (dat[3] << 8)), out.subarray(sz1, sz2), hu);
|
|
629
|
-
dhu(dat.subarray(bt, bt += dat[4] | (dat[5] << 8)), out.subarray(sz2, sz3), hu);
|
|
630
|
-
dhu(dat.subarray(bt), out.subarray(sz3), hu);
|
|
631
|
-
};
|
|
632
|
-
// read Zstandard block
|
|
633
|
-
var rzb = function (dat, st, out) {
|
|
634
|
-
var _a;
|
|
635
|
-
var bt = st.b;
|
|
636
|
-
// byte 0 block type
|
|
637
|
-
var b0 = dat[bt], btype = (b0 >> 1) & 3;
|
|
638
|
-
st.l = b0 & 1;
|
|
639
|
-
var sz = (b0 >> 3) | (dat[bt + 1] << 5) | (dat[bt + 2] << 13);
|
|
640
|
-
// end byte for block
|
|
641
|
-
var ebt = (bt += 3) + sz;
|
|
642
|
-
if (btype == 1) {
|
|
643
|
-
if (bt >= dat.length)
|
|
644
|
-
return;
|
|
645
|
-
st.b = bt + 1;
|
|
646
|
-
if (out) {
|
|
647
|
-
fill(out, dat[bt], st.y, st.y += sz);
|
|
648
|
-
return out;
|
|
649
|
-
}
|
|
650
|
-
return fill(new u8(sz), dat[bt]);
|
|
651
|
-
}
|
|
652
|
-
if (ebt > dat.length)
|
|
653
|
-
return;
|
|
654
|
-
if (btype == 0) {
|
|
655
|
-
st.b = ebt;
|
|
656
|
-
if (out) {
|
|
657
|
-
out.set(dat.subarray(bt, ebt), st.y);
|
|
658
|
-
st.y += sz;
|
|
659
|
-
return out;
|
|
660
|
-
}
|
|
661
|
-
return slc(dat, bt, ebt);
|
|
662
|
-
}
|
|
663
|
-
if (btype == 2) {
|
|
664
|
-
// byte 3 lit btype size format
|
|
665
|
-
var b3 = dat[bt], lbt = b3 & 3, sf = (b3 >> 2) & 3;
|
|
666
|
-
// lit src size lit cmp sz 4 streams
|
|
667
|
-
var lss = b3 >> 4, lcs = 0, s4 = 0;
|
|
668
|
-
if (lbt < 2) {
|
|
669
|
-
if (sf & 1)
|
|
670
|
-
lss |= (dat[++bt] << 4) | ((sf & 2) && (dat[++bt] << 12));
|
|
671
|
-
else
|
|
672
|
-
lss = b3 >> 3;
|
|
673
|
-
}
|
|
674
|
-
else {
|
|
675
|
-
s4 = sf;
|
|
676
|
-
if (sf < 2)
|
|
677
|
-
lss |= ((dat[++bt] & 63) << 4), lcs = (dat[bt] >> 6) | (dat[++bt] << 2);
|
|
678
|
-
else if (sf == 2)
|
|
679
|
-
lss |= (dat[++bt] << 4) | ((dat[++bt] & 3) << 12), lcs = (dat[bt] >> 2) | (dat[++bt] << 6);
|
|
680
|
-
else
|
|
681
|
-
lss |= (dat[++bt] << 4) | ((dat[++bt] & 63) << 12), lcs = (dat[bt] >> 6) | (dat[++bt] << 2) | (dat[++bt] << 10);
|
|
682
|
-
}
|
|
683
|
-
++bt;
|
|
684
|
-
// add literals to end - can never overlap with backreferences because unused literals always appended
|
|
685
|
-
var buf = out ? out.subarray(st.y, st.y + st.m) : new u8(st.m);
|
|
686
|
-
// starting point for literals
|
|
687
|
-
var spl = buf.length - lss;
|
|
688
|
-
if (lbt == 0)
|
|
689
|
-
buf.set(dat.subarray(bt, bt += lss), spl);
|
|
690
|
-
else if (lbt == 1)
|
|
691
|
-
fill(buf, dat[bt++], spl);
|
|
692
|
-
else {
|
|
693
|
-
// huffman table
|
|
694
|
-
var hu = st.h;
|
|
695
|
-
if (lbt == 2) {
|
|
696
|
-
var hud = rhu(dat, bt);
|
|
697
|
-
// subtract description length
|
|
698
|
-
lcs += bt - (bt = hud[0]);
|
|
699
|
-
st.h = hu = hud[1];
|
|
700
|
-
}
|
|
701
|
-
else if (!hu)
|
|
702
|
-
err(0);
|
|
703
|
-
(s4 ? dhu4 : dhu)(dat.subarray(bt, bt += lcs), buf.subarray(spl), hu);
|
|
704
|
-
}
|
|
705
|
-
// num sequences
|
|
706
|
-
var ns = dat[bt++];
|
|
707
|
-
if (ns) {
|
|
708
|
-
if (ns == 255)
|
|
709
|
-
ns = (dat[bt++] | (dat[bt++] << 8)) + 0x7F00;
|
|
710
|
-
else if (ns > 127)
|
|
711
|
-
ns = ((ns - 128) << 8) | dat[bt++];
|
|
712
|
-
// symbol compression modes
|
|
713
|
-
var scm = dat[bt++];
|
|
714
|
-
if (scm & 3)
|
|
715
|
-
err(0);
|
|
716
|
-
var dts = [dmlt, doct, dllt];
|
|
717
|
-
for (var i = 2; i > -1; --i) {
|
|
718
|
-
var md = (scm >> ((i << 1) + 2)) & 3;
|
|
719
|
-
if (md == 1) {
|
|
720
|
-
// rle buf
|
|
721
|
-
var rbuf = new u8([0, 0, dat[bt++]]);
|
|
722
|
-
dts[i] = {
|
|
723
|
-
s: rbuf.subarray(2, 3),
|
|
724
|
-
n: rbuf.subarray(0, 1),
|
|
725
|
-
t: new u16(rbuf.buffer, 0, 1),
|
|
726
|
-
b: 0
|
|
727
|
-
};
|
|
728
|
-
}
|
|
729
|
-
else if (md == 2) {
|
|
730
|
-
// accuracy log 8 for offsets, 9 for others
|
|
731
|
-
_a = rfse(dat, bt, 9 - (i & 1)), bt = _a[0], dts[i] = _a[1];
|
|
732
|
-
}
|
|
733
|
-
else if (md == 3) {
|
|
734
|
-
if (!st.t)
|
|
735
|
-
err(0);
|
|
736
|
-
dts[i] = st.t[i];
|
|
737
|
-
}
|
|
738
|
-
}
|
|
739
|
-
var _b = st.t = dts, mlt = _b[0], oct = _b[1], llt = _b[2];
|
|
740
|
-
var lb = dat[ebt - 1];
|
|
741
|
-
if (!lb)
|
|
742
|
-
err(0);
|
|
743
|
-
var spos = (ebt << 3) - 8 + msb(lb) - llt.b, cbt = spos >> 3, oubt = 0;
|
|
744
|
-
var lst = ((dat[cbt] | (dat[cbt + 1] << 8)) >> (spos & 7)) & ((1 << llt.b) - 1);
|
|
745
|
-
cbt = (spos -= oct.b) >> 3;
|
|
746
|
-
var ost = ((dat[cbt] | (dat[cbt + 1] << 8)) >> (spos & 7)) & ((1 << oct.b) - 1);
|
|
747
|
-
cbt = (spos -= mlt.b) >> 3;
|
|
748
|
-
var mst = ((dat[cbt] | (dat[cbt + 1] << 8)) >> (spos & 7)) & ((1 << mlt.b) - 1);
|
|
749
|
-
for (++ns; --ns;) {
|
|
750
|
-
var llc = llt.s[lst];
|
|
751
|
-
var lbtr = llt.n[lst];
|
|
752
|
-
var mlc = mlt.s[mst];
|
|
753
|
-
var mbtr = mlt.n[mst];
|
|
754
|
-
var ofc = oct.s[ost];
|
|
755
|
-
var obtr = oct.n[ost];
|
|
756
|
-
cbt = (spos -= ofc) >> 3;
|
|
757
|
-
var ofp = 1 << ofc;
|
|
758
|
-
var off = ofp + (((dat[cbt] | (dat[cbt + 1] << 8) | (dat[cbt + 2] << 16) | (dat[cbt + 3] << 24)) >>> (spos & 7)) & (ofp - 1));
|
|
759
|
-
cbt = (spos -= mlb[mlc]) >> 3;
|
|
760
|
-
var ml = mlbl[mlc] + (((dat[cbt] | (dat[cbt + 1] << 8) | (dat[cbt + 2] << 16)) >> (spos & 7)) & ((1 << mlb[mlc]) - 1));
|
|
761
|
-
cbt = (spos -= llb[llc]) >> 3;
|
|
762
|
-
var ll = llbl[llc] + (((dat[cbt] | (dat[cbt + 1] << 8) | (dat[cbt + 2] << 16)) >> (spos & 7)) & ((1 << llb[llc]) - 1));
|
|
763
|
-
cbt = (spos -= lbtr) >> 3;
|
|
764
|
-
lst = llt.t[lst] + (((dat[cbt] | (dat[cbt + 1] << 8)) >> (spos & 7)) & ((1 << lbtr) - 1));
|
|
765
|
-
cbt = (spos -= mbtr) >> 3;
|
|
766
|
-
mst = mlt.t[mst] + (((dat[cbt] | (dat[cbt + 1] << 8)) >> (spos & 7)) & ((1 << mbtr) - 1));
|
|
767
|
-
cbt = (spos -= obtr) >> 3;
|
|
768
|
-
ost = oct.t[ost] + (((dat[cbt] | (dat[cbt + 1] << 8)) >> (spos & 7)) & ((1 << obtr) - 1));
|
|
769
|
-
if (off > 3) {
|
|
770
|
-
st.o[2] = st.o[1];
|
|
771
|
-
st.o[1] = st.o[0];
|
|
772
|
-
st.o[0] = off -= 3;
|
|
773
|
-
}
|
|
774
|
-
else {
|
|
775
|
-
var idx = off - (ll != 0);
|
|
776
|
-
if (idx) {
|
|
777
|
-
off = idx == 3 ? st.o[0] - 1 : st.o[idx];
|
|
778
|
-
if (idx > 1)
|
|
779
|
-
st.o[2] = st.o[1];
|
|
780
|
-
st.o[1] = st.o[0];
|
|
781
|
-
st.o[0] = off;
|
|
782
|
-
}
|
|
783
|
-
else
|
|
784
|
-
off = st.o[0];
|
|
785
|
-
}
|
|
786
|
-
for (var i = 0; i < ll; ++i) {
|
|
787
|
-
buf[oubt + i] = buf[spl + i];
|
|
788
|
-
}
|
|
789
|
-
oubt += ll, spl += ll;
|
|
790
|
-
var stin = oubt - off;
|
|
791
|
-
if (stin < 0) {
|
|
792
|
-
var len = -stin;
|
|
793
|
-
var bs = st.e + stin;
|
|
794
|
-
if (len > ml)
|
|
795
|
-
len = ml;
|
|
796
|
-
for (var i = 0; i < len; ++i) {
|
|
797
|
-
buf[oubt + i] = st.w[bs + i];
|
|
798
|
-
}
|
|
799
|
-
oubt += len, ml -= len, stin = 0;
|
|
800
|
-
}
|
|
801
|
-
for (var i = 0; i < ml; ++i) {
|
|
802
|
-
buf[oubt + i] = buf[stin + i];
|
|
803
|
-
}
|
|
804
|
-
oubt += ml;
|
|
805
|
-
}
|
|
806
|
-
if (oubt != spl) {
|
|
807
|
-
while (spl < buf.length) {
|
|
808
|
-
buf[oubt++] = buf[spl++];
|
|
809
|
-
}
|
|
810
|
-
}
|
|
811
|
-
else
|
|
812
|
-
oubt = buf.length;
|
|
813
|
-
if (out)
|
|
814
|
-
st.y += oubt;
|
|
815
|
-
else
|
|
816
|
-
buf = slc(buf, 0, oubt);
|
|
817
|
-
}
|
|
818
|
-
else {
|
|
819
|
-
if (out) {
|
|
820
|
-
st.y += lss;
|
|
821
|
-
if (spl) {
|
|
822
|
-
for (var i = 0; i < lss; ++i) {
|
|
823
|
-
buf[i] = buf[spl + i];
|
|
824
|
-
}
|
|
825
|
-
}
|
|
826
|
-
}
|
|
827
|
-
else if (spl)
|
|
828
|
-
buf = slc(buf, spl);
|
|
829
|
-
}
|
|
830
|
-
st.b = ebt;
|
|
831
|
-
return buf;
|
|
832
|
-
}
|
|
833
|
-
err(2);
|
|
834
|
-
};
|
|
835
|
-
// concat
|
|
836
|
-
var cct = function (bufs, ol) {
|
|
837
|
-
if (bufs.length == 1)
|
|
838
|
-
return bufs[0];
|
|
839
|
-
var buf = new u8(ol);
|
|
840
|
-
for (var i = 0, b = 0; i < bufs.length; ++i) {
|
|
841
|
-
var chk = bufs[i];
|
|
842
|
-
buf.set(chk, b);
|
|
843
|
-
b += chk.length;
|
|
844
|
-
}
|
|
845
|
-
return buf;
|
|
846
|
-
};
|
|
847
|
-
/**
|
|
848
|
-
* Decompresses Zstandard data
|
|
849
|
-
* @param dat The input data
|
|
850
|
-
* @param buf The output buffer. If unspecified, the function will allocate
|
|
851
|
-
* exactly enough memory to fit the decompressed data. If your
|
|
852
|
-
* data has multiple frames and you know the output size, specifying
|
|
853
|
-
* it will yield better performance.
|
|
854
|
-
* @returns The decompressed data
|
|
855
|
-
*/
|
|
856
|
-
function decompress(dat, buf) {
|
|
857
|
-
var bt = 0, bufs = [], nb = +!buf, ol = 0;
|
|
858
|
-
for (; dat.length;) {
|
|
859
|
-
var st = rzfh(dat, nb || buf);
|
|
860
|
-
if (typeof st == 'object') {
|
|
861
|
-
if (nb) {
|
|
862
|
-
buf = null;
|
|
863
|
-
if (st.w.length == st.u) {
|
|
864
|
-
bufs.push(buf = st.w);
|
|
865
|
-
ol += st.u;
|
|
866
|
-
}
|
|
867
|
-
}
|
|
868
|
-
else {
|
|
869
|
-
bufs.push(buf);
|
|
870
|
-
st.e = 0;
|
|
871
|
-
}
|
|
872
|
-
for (; !st.l;) {
|
|
873
|
-
var blk = rzb(dat, st, buf);
|
|
874
|
-
if (!blk)
|
|
875
|
-
err(5);
|
|
876
|
-
if (buf)
|
|
877
|
-
st.e = st.y;
|
|
878
|
-
else {
|
|
879
|
-
bufs.push(blk);
|
|
880
|
-
ol += blk.length;
|
|
881
|
-
cpw(st.w, 0, blk.length);
|
|
882
|
-
st.w.set(blk, st.w.length - blk.length);
|
|
883
|
-
}
|
|
884
|
-
}
|
|
885
|
-
bt = st.b + (st.c * 4);
|
|
886
|
-
}
|
|
887
|
-
else
|
|
888
|
-
bt = st;
|
|
889
|
-
dat = dat.subarray(bt);
|
|
890
|
-
}
|
|
891
|
-
return cct(bufs, ol);
|
|
892
|
-
}
|
|
893
|
-
|
|
894
|
-
// See: https://github.com/Equim-chan/base91
|
|
895
|
-
const table = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789!#$%&()*+,./:;<=>?@[]^_`{|}~"';
|
|
896
|
-
function decode(raw) {
|
|
897
|
-
const len = raw.length;
|
|
898
|
-
const ret = [];
|
|
899
|
-
let b = 0;
|
|
900
|
-
let n = 0;
|
|
901
|
-
let v = -1;
|
|
902
|
-
for (let i = 0; i < len; i++) {
|
|
903
|
-
const p = table.indexOf(raw[i]);
|
|
904
|
-
if (p === -1)
|
|
905
|
-
continue;
|
|
906
|
-
if (v < 0) {
|
|
907
|
-
v = p;
|
|
908
|
-
}
|
|
909
|
-
else {
|
|
910
|
-
v += p * 91;
|
|
911
|
-
b |= v << n;
|
|
912
|
-
n += (v & 8191) > 88 ? 13 : 14;
|
|
913
|
-
do {
|
|
914
|
-
ret.push(b & 0xff);
|
|
915
|
-
b >>= 8;
|
|
916
|
-
n -= 8;
|
|
917
|
-
} while (n > 7);
|
|
918
|
-
v = -1;
|
|
919
|
-
}
|
|
920
|
-
}
|
|
921
|
-
if (v > -1) {
|
|
922
|
-
ret.push((b | v << n) & 0xff);
|
|
923
|
-
}
|
|
924
|
-
return new Uint8Array(ret);
|
|
925
|
-
}
|
|
926
|
-
function extract(raw) {
|
|
927
|
-
const compressed = decode(raw);
|
|
928
|
-
return decompress(compressed);
|
|
929
|
-
}
|
|
930
|
-
|
|
931
253
|
var cpp$1 = (() => {
|
|
932
254
|
typeof document !== 'undefined' && document.currentScript ? document.currentScript.src : undefined;
|
|
933
255
|
|
|
@@ -969,12 +291,14 @@ function createFiles(graphviz, _ext) {
|
|
|
969
291
|
[...ext.files, ...imagesToFiles(ext.images)].forEach(file => graphviz.createFile(file.path, file.data));
|
|
970
292
|
}
|
|
971
293
|
function graphvizVersion(wasmFolder, wasmBinary) {
|
|
294
|
+
console.warn("Deprecation Warning: 'graphvizVersion' will be refactored into 'Graphviz' in 2.0.0");
|
|
972
295
|
return loadWasm(graphvizlib, "graphvizlib", wasmFolder, wasmBinary).then(module => {
|
|
973
296
|
return module.Graphviz.prototype.version();
|
|
974
297
|
});
|
|
975
298
|
}
|
|
976
299
|
const graphviz = {
|
|
977
300
|
layout(dotSource, outputFormat = "svg", layoutEngine = "dot", ext) {
|
|
301
|
+
console.warn("Deprecation Warning: 'graphviz' will be replaced with 'Graphviz' in 2.0.0");
|
|
978
302
|
if (!dotSource)
|
|
979
303
|
return Promise.resolve("");
|
|
980
304
|
return loadWasm(graphvizlib, "graphvizlib", ext?.wasmFolder, ext?.wasmBinary).then(module => {
|
|
@@ -1025,6 +349,7 @@ class GraphvizSync {
|
|
|
1025
349
|
this._wasm = _wasm;
|
|
1026
350
|
}
|
|
1027
351
|
layout(dotSource, outputFormat = "svg", layoutEngine = "dot", ext) {
|
|
352
|
+
console.warn("Deprecation Warning: 'GraphvizSync' will be replaced with 'Graphviz' in 2.0.0");
|
|
1028
353
|
if (!dotSource)
|
|
1029
354
|
return "";
|
|
1030
355
|
const graphViz = new this._wasm.Graphviz(ext?.yInvert ? 1 : 0, ext?.nop ? ext?.nop : 0);
|
|
@@ -1154,5 +479,5 @@ class Zstd extends WasmLibrary {
|
|
|
1154
479
|
interop.doFetch = doFetch;
|
|
1155
480
|
interop.scriptDir = scriptDir;
|
|
1156
481
|
|
|
1157
|
-
export { Base91, GraphvizSync, StackElement, StackParser, Zstd, expatVersion,
|
|
482
|
+
export { Base91, GraphvizSync, StackElement, StackParser, Zstd, expatVersion, graphviz, graphvizSync, graphvizVersion, parse, wasmFolder };
|
|
1158
483
|
//# sourceMappingURL=index.node.es6.mjs.map
|