From 58bc087974452f4dd778af84d5486fe395212b4b Mon Sep 17 00:00:00 2001 From: Jakub Jankiewicz Date: Mon, 12 Feb 2024 15:29:24 +0100 Subject: [PATCH] refactor into using is_nil and is_pair functions --- README.md | 2 +- dist/lips.cjs | 410 ++++++++++++++++++++-------------------- dist/lips.esm.js | 410 ++++++++++++++++++++-------------------- dist/lips.esm.min.js | 6 +- dist/lips.js | 410 ++++++++++++++++++++-------------------- dist/lips.min.js | 8 +- src/lips.js | 432 ++++++++++++++++++++++--------------------- 7 files changed, 834 insertions(+), 844 deletions(-) diff --git a/README.md b/README.md index d0bbfce27..e01e5ecab 100644 --- a/README.md +++ b/README.md @@ -8,7 +8,7 @@ [![npm](https://img.shields.io/badge/npm-1.0.0%E2%80%93beta.18.1-blue.svg)](https://www.npmjs.com/package/@jcubic/lips) ![1.0.0 Complete](https://img.shields.io/github/milestones/progress-percent/jcubic/lips/1?label=1.0.0%20Complete) [![Build and test](https://github.com/jcubic/lips/actions/workflows/build.yaml/badge.svg?branch=devel&event=push)](https://github.com/jcubic/lips/actions/workflows/build.yaml) -[![Coverage Status](https://coveralls.io/repos/github/jcubic/lips/badge.svg?branch=devel&f26755a6ca34a2ad7d42aa1863f83d2d)](https://coveralls.io/github/jcubic/lips?branch=devel) +[![Coverage Status](https://coveralls.io/repos/github/jcubic/lips/badge.svg?branch=devel&7ccec6c3acb14b8586e722ee751d6509)](https://coveralls.io/github/jcubic/lips?branch=devel) [![Join Gitter Chat](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/jcubic/lips) ![NPM Download Count](https://img.shields.io/npm/dm/@jcubic/lips) ![JSDelivr Download count](https://img.shields.io/jsdelivr/npm/hm/@jcubic/lips) diff --git a/dist/lips.cjs b/dist/lips.cjs index f86df6170..6fa4b8830 100644 --- a/dist/lips.cjs +++ b/dist/lips.cjs @@ -31,7 +31,7 @@ * Copyright (c) 2014-present, Facebook, Inc. * released under MIT license * - * build: Mon, 12 Feb 2024 12:58:05 +0000 + * build: Mon, 12 Feb 2024 14:25:33 +0000 */ 'use strict'; @@ -5025,7 +5025,7 @@ var Parser = /*#__PURE__*/function () { this.skip(); return _context3.abrupt("break", 32); case 10: - if (!(token === '.' && head !== _nil)) { + if (!(token === '.' && !is_nil(head))) { _context3.next = 18; break; } @@ -5051,7 +5051,7 @@ var Parser = /*#__PURE__*/function () { _context3.t1 = _context3.sent; _context3.t2 = _nil; cur = new _context3.t0(_context3.t1, _context3.t2); - if (head === _nil) { + if (is_nil(head)) { head = cur; } else { prev.cdr = cur; @@ -5201,7 +5201,7 @@ var Parser = /*#__PURE__*/function () { }); return _context6.abrupt("return", result); case 6: - if (!(object instanceof Pair)) { + if (!is_pair(object)) { _context6.next = 8; break; } @@ -5226,7 +5226,7 @@ var Parser = /*#__PURE__*/function () { return _regeneratorRuntime.wrap(function _callee7$(_context7) { while (1) switch (_context7.prev = _context7.next) { case 0: - if (!(pair instanceof Pair)) { + if (!is_pair(pair)) { _context7.next = 15; break; } @@ -5326,9 +5326,9 @@ var Parser = /*#__PURE__*/function () { } if (is_literal(token)) { args = [object]; - } else if (object === _nil) { + } else if (is_nil(object)) { args = []; - } else if (object instanceof Pair) { + } else if (is_pair(object)) { args = object.to_array(false); } if (!(args || is_symbol)) { @@ -5363,7 +5363,7 @@ var Parser = /*#__PURE__*/function () { return this.evaluate(expr); case 31: result = _context8.sent; - if (!(result instanceof Pair || result instanceof LSymbol)) { + if (!(is_pair(result) || result instanceof LSymbol)) { _context8.next = 34; break; } @@ -6295,23 +6295,23 @@ function Pair(car, cdr) { function to_array(name, deep) { return function recur(list) { typecheck(name, list, ['pair', 'nil']); - if (list === _nil) { + if (is_nil(list)) { return []; } var result = []; var node = list; while (true) { - if (node instanceof Pair) { + if (is_pair(node)) { if (node.haveCycles('cdr')) { break; } var car = node.car; - if (deep && car instanceof Pair) { + if (deep && is_pair(car)) { car = this.get(name).call(this, car); } result.push(car); node = node.cdr; - } else if (node === _nil) { + } else if (is_nil(node)) { break; } else { throw new Error("".concat(name, ": can't convert improper list")); @@ -6329,7 +6329,7 @@ Pair.prototype.length = function () { var len = 0; var node = this; while (true) { - if (!node || node === _nil || !(node instanceof Pair) || node.haveCycles('cdr')) { + if (!node || is_nil(node) || !is_pair(node) || node.haveCycles('cdr')) { break; } len++; @@ -6341,7 +6341,7 @@ Pair.prototype.length = function () { Pair.match = function (obj, item) { if (obj instanceof LSymbol) { return LSymbol.is(obj, item); - } else if (obj instanceof Pair) { + } else if (is_pair(obj)) { return Pair.match(obj.car, item) || Pair.match(obj.cdr, item); } else if (Array.isArray(obj)) { return obj.some(function (x) { @@ -6364,7 +6364,7 @@ Pair.prototype.clone = function () { var deep = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true; var visited = new Map(); function clone(node) { - if (node instanceof Pair) { + if (is_pair(node)) { if (visited.has(node)) { return visited.get(node); } @@ -6402,7 +6402,7 @@ Pair.prototype.last_pair = function () { Pair.prototype.to_array = function () { var deep = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true; var result = []; - if (this.car instanceof Pair) { + if (is_pair(this.car)) { if (deep) { result.push(this.car.to_array()); } else { @@ -6411,7 +6411,7 @@ Pair.prototype.to_array = function () { } else { result.push(this.car.valueOf()); } - if (this.cdr instanceof Pair) { + if (is_pair(this.cdr)) { result = result.concat(this.cdr.to_array(deep)); } return result; @@ -6423,7 +6423,7 @@ Pair.prototype.to_array = function () { Pair.fromArray = function (array) { var deep = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; var quote = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; - if (array instanceof Pair || quote && array instanceof Array && array[__data__]) { + if (is_pair(array) || quote && array instanceof Array && array[__data__]) { return array; } if (deep === false) { @@ -6462,7 +6462,7 @@ Pair.prototype.to_object = function () { var node = this; var result = {}; while (true) { - if (node instanceof Pair && node.car instanceof Pair) { + if (is_pair(node) && is_pair(node.car)) { var pair = node.car; var name = pair.car; if (name instanceof LSymbol) { @@ -6472,7 +6472,7 @@ Pair.prototype.to_object = function () { name = name.valueOf(); } var cdr = pair.cdr; - if (cdr instanceof Pair) { + if (is_pair(cdr)) { cdr = cdr.to_object(literal); } if (is_native(cdr)) { @@ -6509,7 +6509,7 @@ Pair.prototype.reduce = function (fn) { var node = this; var result = _nil; while (true) { - if (node !== _nil) { + if (!is_nil(node)) { result = fn(result, node.car); node = node.cdr; } else { @@ -6526,7 +6526,7 @@ Pair.prototype.reverse = function () { } var node = this; var prev = _nil; - while (node !== _nil) { + while (!is_nil(node)) { var next = node.cdr; node.cdr = prev; prev = node; @@ -6538,17 +6538,17 @@ Pair.prototype.reverse = function () { // ---------------------------------------------------------------------- Pair.prototype.transform = function (fn) { function recur(pair) { - if (pair instanceof Pair) { + if (is_pair(pair)) { if (pair.replace) { delete pair.replace; return pair; } var car = fn(pair.car); - if (car instanceof Pair) { + if (is_pair(car)) { car = recur(car); } var cdr = fn(pair.cdr); - if (cdr instanceof Pair) { + if (is_pair(cdr)) { cdr = recur(cdr); } return new Pair(car, cdr); @@ -6561,7 +6561,7 @@ Pair.prototype.transform = function (fn) { // ---------------------------------------------------------------------- Pair.prototype.map = function (fn) { if (typeof this.car !== 'undefined') { - return new Pair(fn(this.car), this.cdr === _nil ? _nil : this.cdr.map(fn)); + return new Pair(fn(this.car), is_nil(this.cdr) ? _nil : this.cdr.map(fn)); } else { return _nil; } @@ -6856,7 +6856,7 @@ function markCycles(pair) { } } function set(node, type, child, parents) { - if (child instanceof Pair) { + if (is_pair(child)) { if (parents.includes(child)) { if (!refs.includes(child)) { refs.push(child); @@ -6873,7 +6873,7 @@ function markCycles(pair) { } } var detect = trampoline(function detect_thunk(pair, parents) { - if (pair instanceof Pair) { + if (is_pair(pair)) { delete pair.ref; delete pair[__cycles__]; visit(pair); @@ -6891,7 +6891,7 @@ function markCycles(pair) { } }); function mark_node(node, type) { - if (node[__cycles__][type] instanceof Pair) { + if (is_pair(node[__cycles__][type])) { var count = ref_nodes.indexOf(node[__cycles__][type]); node[__cycles__][type] = "#".concat(count, "#"); } @@ -6929,7 +6929,7 @@ Pair.prototype.toString = function (quote) { if (value !== undefined) { arr.push(value); } - if (this.cdr instanceof Pair) { + if (is_pair(this.cdr)) { if (this[__cycles__] && this[__cycles__].cdr) { arr.push(' . '); arr.push(this[__cycles__].cdr); @@ -6944,7 +6944,7 @@ Pair.prototype.toString = function (quote) { }); arr.push(cdr); } - } else if (this.cdr !== _nil) { + } else if (!is_nil(this.cdr)) { arr = arr.concat([' . ', toString(this.cdr, quote, true)]); } if (!nested || this[__ref__]) { @@ -6956,7 +6956,7 @@ Pair.prototype.toString = function (quote) { // ---------------------------------------------------------------------- Pair.prototype.set = function (prop, value) { this[prop] = value; - if (value instanceof Pair) { + if (is_pair(value)) { this.markCycles(); } }; @@ -6968,15 +6968,15 @@ Pair.prototype.append = function (arg) { } var p = this; if (p.car === undefined) { - if (arg instanceof Pair) { + if (is_pair(arg)) { this.car = arg.car; this.cdr = arg.cdr; } else { this.car = arg; } - } else if (arg !== _nil) { + } else if (!is_nil(arg)) { while (true) { - if (p instanceof Pair && p.cdr !== _nil) { + if (is_pair(p) && !is_nil(p.cdr)) { p = p.cdr; } else { break; @@ -6999,7 +6999,7 @@ Pair.prototype[Symbol.iterator] = function () { next: function next() { var cur = node; node = cur.cdr; - if (cur === _nil) { + if (is_nil(cur)) { return { value: undefined, done: true @@ -7103,7 +7103,7 @@ function same_atom(a, b) { } // ---------------------------------------------------------------------- function is_atom(obj) { - return obj instanceof LSymbol || LString.isString(obj) || obj === _nil || obj === null || obj instanceof LCharacter || obj instanceof LNumber || obj === true || obj === false; + return obj instanceof LSymbol || LString.isString(obj) || is_nil(obj) || obj === null || obj instanceof LCharacter || obj instanceof LNumber || obj === true || obj === false; } // ---------------------------------------------------------------------- var truncate = function () { @@ -7178,7 +7178,7 @@ function macro_expand(single) { return _regeneratorRuntime.wrap(function _callee11$(_context11) { while (1) switch (_context11.prev = _context11.next) { case 0: - if (!(node instanceof Pair && node.car instanceof LSymbol)) { + if (!(is_pair(node) && node.car instanceof LSymbol)) { _context11.next = 50; break; } @@ -7194,7 +7194,7 @@ function macro_expand(single) { }); is_let = is_let_macro(node.car); is_binding = is_let || is_procedure(value, node) || is_lambda(value); - if (!(is_binding && node.cdr.car instanceof Pair)) { + if (!(is_binding && is_pair(node.cdr.car))) { _context11.next = 28; break; } @@ -7240,7 +7240,7 @@ function macro_expand(single) { break; } _result = result, expr = _result.expr, scope = _result.scope; - if (!(expr instanceof Pair)) { + if (!is_pair(expr)) { _context11.next = 40; break; } @@ -7263,7 +7263,7 @@ function macro_expand(single) { } return _context11.abrupt("return", quote(result)); case 43: - if (!(result instanceof Pair)) { + if (!is_pair(result)) { _context11.next = 48; break; } @@ -7286,7 +7286,7 @@ function macro_expand(single) { case 50: // TODO: CYCLE DETECT car = node.car; - if (!(car instanceof Pair)) { + if (!is_pair(car)) { _context11.next = 55; break; } @@ -7296,7 +7296,7 @@ function macro_expand(single) { car = _context11.sent; case 55: cdr = node.cdr; - if (!(cdr instanceof Pair)) { + if (!is_pair(cdr)) { _context11.next = 60; break; } @@ -7324,7 +7324,7 @@ function macro_expand(single) { return _regeneratorRuntime.wrap(function _callee10$(_context10) { while (1) switch (_context10.prev = _context10.next) { case 0: - if (!(node === _nil)) { + if (!is_nil(node)) { _context10.next = 2; break; } @@ -7360,7 +7360,7 @@ function macro_expand(single) { }; let_binding = function _let_binding(node) { return [].concat(_toConsumableArray(bindings), _toConsumableArray(node.to_array(false).map(function (node) { - if (node instanceof Pair) { + if (is_pair(node)) { return node.car.valueOf(); } var t = type(node); @@ -7371,7 +7371,7 @@ function macro_expand(single) { proc_bindings = function _proc_bindings(node) { var names = []; while (true) { - if (node !== _nil) { + if (!is_nil(node)) { if (node instanceof LSymbol) { names.push(node.valueOf()); break; @@ -7388,7 +7388,7 @@ function macro_expand(single) { return value === lambda; }; is_procedure = function _is_procedure(value, node) { - return value === define && node.cdr.car instanceof Pair; + return value === define && is_pair(node.cdr.car); }; is_let_macro = function _is_let_macro(symbol) { var name = symbol.valueOf(); @@ -7399,7 +7399,7 @@ function macro_expand(single) { let_macros = ['let', 'let*', 'letrec']; lambda = global_env.get('lambda'); define = global_env.get('define'); //var this.__code__ = code; - if (!(code.cdr instanceof Pair && LNumber.isNumber(code.cdr.car))) { + if (!(is_pair(code.cdr) && LNumber.isNumber(code.cdr.car))) { _context12.next = 21; break; } @@ -7574,9 +7574,9 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol) { return first && rest; } // pattern (a b (x ...)) and (x ...) match nil - if (pattern instanceof Pair && pattern.car instanceof Pair && pattern.car.cdr instanceof Pair && LSymbol.is(pattern.car.cdr.car, ellipsis_symbol)) { + if (is_pair(pattern) && is_pair(pattern.car) && is_pair(pattern.car.cdr) && LSymbol.is(pattern.car.cdr.car, ellipsis_symbol)) { log('>> 0'); - if (code === _nil) { + if (is_nil(code)) { log({ pattern: pattern }); @@ -7589,10 +7589,10 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol) { } } } - if (pattern instanceof Pair && pattern.cdr instanceof Pair && LSymbol.is(pattern.cdr.car, ellipsis_symbol)) { + if (is_pair(pattern) && is_pair(pattern.cdr) && LSymbol.is(pattern.cdr.car, ellipsis_symbol)) { // pattern (... ???) - SRFI-46 - if (pattern.cdr.cdr !== _nil) { - if (pattern.cdr.cdr instanceof Pair) { + if (!is_nil(pattern.cdr.cdr)) { + if (is_pair(pattern.cdr.cdr)) { // if we have (x ... a b) we need to remove two from the end var list_len = pattern.cdr.cdr.length(); if (!is_pair(code)) { @@ -7617,7 +7617,7 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol) { throw new Error('syntax: named ellipsis can only appear onces'); } log('>> 1'); - if (code === _nil) { + if (is_nil(code)) { log('>> 2'); if (ellipsis) { log('NIL'); @@ -7626,12 +7626,12 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol) { log('NULL'); bindings['...'].symbols[_name3] = null; } - } else if (code instanceof Pair && (code.car instanceof Pair || code.car === _nil)) { + } else if (is_pair(code) && (is_pair(code.car) || is_nil(code.car))) { log('>> 3 ' + ellipsis); if (ellipsis) { if (bindings['...'].symbols[_name3]) { var _node = bindings['...'].symbols[_name3]; - if (_node === _nil) { + if (is_nil(_node)) { _node = new Pair(_nil, new Pair(code, _nil)); } else { _node = _node.append(new Pair(code, _nil)); @@ -7646,11 +7646,11 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol) { } } else { log('>> 6'); - if (code instanceof Pair) { + if (is_pair(code)) { // cons (a . b) => (var ... . x) - if (!(code.cdr instanceof Pair) && code.cdr !== _nil) { + if (!is_pair(code.cdr) && !is_nil(code.cdr)) { log('>> 7 (b)'); - if (pattern.cdr.cdr === _nil) { + if (is_nil(pattern.cdr.cdr)) { return false; } else if (!bindings['...'].symbols[_name3]) { bindings['...'].symbols[_name3] = new Pair(code.car, _nil); @@ -7659,8 +7659,8 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol) { } // code as improper list var last_pair = code.last_pair(); - if (last_pair.cdr !== _nil) { - if (pattern.cdr.cdr === _nil) { + if (!is_nil(last_pair.cdr)) { + if (is_nil(pattern.cdr.cdr)) { // case (a ...) for (a b . x) return false; } else { @@ -7682,7 +7682,7 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol) { log({ IIIIII: bindings['...'].symbols[_name3] }); - } else if (pattern.car instanceof LSymbol && pattern.cdr instanceof Pair && LSymbol.is(pattern.cdr.car, ellipsis_symbol)) { + } else if (pattern.car instanceof LSymbol && is_pair(pattern.cdr) && LSymbol.is(pattern.cdr.car, ellipsis_symbol)) { // empty ellipsis with rest (a b ... . d) #290 log('>> 8'); bindings['...'].symbols[_name3] = null; @@ -7694,16 +7694,16 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol) { } } return true; - } else if (pattern.car instanceof Pair) { + } else if (is_pair(pattern.car)) { var names = _toConsumableArray(pattern_names); - if (code === _nil) { + if (is_nil(code)) { log('>> 10'); bindings['...'].lists.push(_nil); return true; } log('>> 11'); var _node3 = code; - while (_node3 instanceof Pair) { + while (is_pair(_node3)) { if (!traverse(pattern.car, _node3.car, names, true)) { return false; } @@ -7714,7 +7714,7 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol) { if (Array.isArray(pattern.car)) { var names = _toConsumableArray(pattern_names); var _node4 = code; - while (_node4 instanceof Pair) { + while (is_pair(_node4)) { if (!traverse(pattern.car, _node4.car, names, true)) { return false; } @@ -7743,14 +7743,14 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol) { } return true; } - if (pattern instanceof Pair && code instanceof Pair) { + if (is_pair(pattern) && is_pair(code)) { log('>> 13'); log({ a: 13, code: code, pattern: pattern }); - if (code.cdr === _nil) { + if (is_nil(code.cdr)) { // last item in in call using in recursive calls on // last element of the list // case of pattern (p . rest) and code (0) @@ -7778,7 +7778,7 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol) { code: code }); // case (x y) ===> (var0 var1 ... warn) where var1 match nil - if (pattern.cdr instanceof Pair && pattern.cdr.cdr instanceof Pair && pattern.cdr.car instanceof LSymbol && LSymbol.is(pattern.cdr.cdr.car, ellipsis_symbol) && pattern.cdr.cdr.cdr instanceof Pair && !LSymbol.is(pattern.cdr.cdr.cdr.car, ellipsis_symbol) && traverse(pattern.car, code.car, pattern_names, ellipsis) && traverse(pattern.cdr.cdr.cdr, code.cdr, pattern_names, ellipsis)) { + if (is_pair(pattern.cdr) && is_pair(pattern.cdr.cdr) && pattern.cdr.car instanceof LSymbol && LSymbol.is(pattern.cdr.cdr.car, ellipsis_symbol) && is_pair(pattern.cdr.cdr.cdr) && !LSymbol.is(pattern.cdr.cdr.cdr.car, ellipsis_symbol) && traverse(pattern.car, code.car, pattern_names, ellipsis) && traverse(pattern.cdr.cdr.cdr, code.cdr, pattern_names, ellipsis)) { var _name6 = pattern.cdr.car.__name__; log({ pattern: pattern, @@ -7810,11 +7810,11 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol) { if (car && cdr) { return true; } - } else if (pattern === _nil && (code === _nil || code === undefined)) { + } else if (is_nil(pattern) && (is_nil(code) || code === undefined)) { // undefined is case when you don't have body ... // and you do recursive call return true; - } else if (pattern.car instanceof Pair && LSymbol.is(pattern.car.car, ellipsis_symbol)) { + } else if (is_pair(pattern.car) && LSymbol.is(pattern.car.car, ellipsis_symbol)) { // pattern (...) throw new Error('syntax: invalid usage of ellipsis'); } else { @@ -7833,7 +7833,7 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol) { // ---------------------------------------------------------------------- function clear_gensyms(node, gensyms) { function traverse(node) { - if (node instanceof Pair) { + if (is_pair(node)) { if (!gensyms.length) { return node; } @@ -7963,19 +7963,19 @@ function transform_syntax() { if (is_gensym(expr) && !bindings[name]) ; log('[t 1'); if (bindings[name]) { - if (bindings[name] instanceof Pair) { + if (is_pair(bindings[name])) { var _bindings$name = bindings[name], car = _bindings$name.car, cdr = _bindings$name.cdr; if (nested) { var caar = car.car, cadr = car.cdr; - if (cadr !== _nil) { + if (!is_nil(cadr)) { next(name, new Pair(cadr, _nil)); } return caar; } - if (cdr !== _nil) { + if (!is_nil(cdr)) { next(name, cdr); } return car; @@ -7987,7 +7987,7 @@ function transform_syntax() { return transform(expr); } var is_array = Array.isArray(expr); - if (expr instanceof Pair || is_array) { + if (is_pair(expr) || is_array) { var first = is_array ? expr[0] : expr.car; var second = is_array ? expr[1] : is_pair(expr.cdr) && expr.cdr.car; if (first instanceof LSymbol && LSymbol.is(second, ellipsis_symbol)) { @@ -8002,17 +8002,17 @@ function transform_syntax() { name: _name7, binding: bindings[_name7] }); - if (item instanceof Pair) { + if (is_pair(item)) { log('[t 2 Pair ' + nested); var _car = item.car, _cdr = item.cdr; var _rest_expr = is_array ? expr.slice(2) : expr.cdr.cdr; if (nested) { - if (_cdr !== _nil) { + if (!is_nil(_cdr)) { log('|| next 1'); next(_name7, _cdr); } - if (is_array && _rest_expr.length || _rest_expr !== _nil && !is_array) { + if (is_array && _rest_expr.length || !is_nil(_rest_expr) && !is_array) { var _rest7 = transform_ellipsis_expr(_rest_expr, bindings, state, next); if (is_array) { return _car.concat(_rest7); @@ -8023,13 +8023,13 @@ function transform_syntax() { } } return _car; - } else if (_car instanceof Pair) { - if (_car.cdr !== _nil) { + } else if (is_pair(_car)) { + if (!is_nil(_car.cdr)) { log('|| next 2'); next(_name7, new Pair(_car.cdr, _cdr)); } return _car.car; - } else if (_cdr === _nil) { + } else if (is_nil(_cdr)) { return _car; } else { var last_pair = expr.last_pair(); @@ -8083,7 +8083,7 @@ function transform_syntax() { if (x === null) { return !skip_nulls; } - return x instanceof Pair || x === _nil || x instanceof Array && x.length; + return is_pair(x) || is_nil(x) || Array.isArray(x) && x.length; }); } function get_names(object) { @@ -8098,7 +8098,7 @@ function transform_syntax() { if (is_array && expr.length === 0) { return expr; } - if (expr instanceof Pair || is_array) { + if (is_pair(expr) || is_array) { var first = is_array ? expr[0] : expr.car; var second, rest_second; if (is_array) { @@ -8146,7 +8146,7 @@ function transform_syntax() { // lists is free ellipsis on pairs ((???) ...) // TODO: will this work in every case? Do we need to handle // nesting here? - if (bindings['...'].lists[0] === _nil) { + if (is_nil(bindings['...'].lists[0])) { if (!is_spread) { return traverse(rest_second, { disabled: disabled @@ -8194,7 +8194,7 @@ function transform_syntax() { log('ZONK {1}'); } } else { - if (result === _nil) { + if (is_nil(result)) { result = car; } else { result = result.append(car); @@ -8211,7 +8211,7 @@ function transform_syntax() { while (true) { if (_loop()) break; } - if (result !== _nil && !is_spread && !is_array) { + if (!is_nil(result) && !is_spread && !is_array) { result = result.reverse(); } // case of (list) ... (rest code) @@ -8228,7 +8228,7 @@ function transform_syntax() { } return result; } - if (expr.cdr.cdr !== _nil && !LSymbol.is(expr.cdr.cdr.car, ellipsis_symbol)) { + if (!is_nil(expr.cdr.cdr) && !LSymbol.is(expr.cdr.cdr.car, ellipsis_symbol)) { var _rest10 = traverse(expr.cdr.cdr, { disabled: disabled }); @@ -8290,14 +8290,14 @@ function transform_syntax() { while (true) { if (_loop2()) break; } - if (_result3 !== _nil && !is_array) { + if (!is_nil(_result3) && !is_array) { _result3 = _result3.reverse(); } // case if (x ... y ...) second spread is not processed // and (??? . x) last symbol // by ellipsis transformation - if (expr.cdr instanceof Pair) { - if (expr.cdr.cdr instanceof Pair || expr.cdr.cdr instanceof LSymbol) { + if (is_pair(expr.cdr)) { + if (is_pair(expr.cdr.cdr) || expr.cdr.cdr instanceof LSymbol) { var node = traverse(expr.cdr.cdr, { disabled: disabled }); @@ -8307,7 +8307,7 @@ function transform_syntax() { if (_is_null) { return node; } - if (_result3 === _nil) { + if (is_nil(_result3)) { _result3 = node; } else { _result3.append(node); @@ -8383,7 +8383,11 @@ function transform_syntax() { // :: Check for nullish values // ---------------------------------------------------------------------- function is_null(value) { - return is_undef(value) || value === _nil || value === null; + return is_undef(value) || is_nil(value) || value === null; +} +// ---------------------------------------------------------------------- +function is_nil(value) { + return value === _nil; } // ---------------------------------------------------------------------- function is_function(o) { @@ -8521,7 +8525,7 @@ function unbox(object) { } // ---------------------------------------------------------------------- function patch_value(value, context) { - if (value instanceof Pair) { + if (is_pair(value)) { value.markCycles(); return quote(value); } @@ -8714,11 +8718,11 @@ function let_macro(symbol) { // named let: // (let iter ((x 10)) (iter (- x 1))) -> (let* ((iter (lambda (x) ... if (code.car instanceof LSymbol) { - if (!(code.cdr.car instanceof Pair || code.cdr.car === _nil)) { + if (!(is_pair(code.cdr.car) || is_nil(code.cdr.car))) { throw new Error('let require list of pairs'); } var params; - if (code.cdr.car === _nil) { + if (is_nil(code.cdr.car)) { args = _nil; params = _nil; } else { @@ -8830,7 +8834,7 @@ function parallel(name, fn) { var dynamic_env = this; var results = []; var node = code; - while (node instanceof Pair) { + while (is_pair(node)) { results.push(_evaluate(node.car, { env: env, dynamic_env: dynamic_env, @@ -11523,7 +11527,7 @@ function quote(value) { if (is_promise(value)) { return value.then(quote); } - if (value instanceof Pair || value instanceof LSymbol) { + if (is_pair(value) || value instanceof LSymbol) { value[__data__] = true; } return value; @@ -11730,7 +11734,7 @@ var global_env = new Environment({ }(), "(read [string])\n\n This function, if used with a string, will parse it and\n return the LIPS code, if there is any. If called with a\n port, it will parse the next item from the port. If called\n without an input, it will read a string from standard input\n (using the browser's prompt or a user defined input method)\n and calls itself with that string. This function can be used\n together with `eval` to evaluate code from a string."), // ------------------------------------------------------------------ pprint: doc('pprint', function pprint(arg) { - if (arg instanceof Pair) { + if (is_pair(arg)) { arg = new lips.Formatter(arg.toString(true))["break"]().format(); global_env.get('display').call(global_env, arg); } else { @@ -11838,7 +11842,7 @@ var global_env = new Environment({ var symbol; if (code.car instanceof LSymbol) { symbol = code.car; - } else if (code.car instanceof Pair && code.car.car instanceof LSymbol) { + } else if (is_pair(code.car) && code.car.car instanceof LSymbol) { symbol = code.car.car; } else { var env = this; @@ -11917,7 +11921,7 @@ var global_env = new Environment({ env.get('set-obj!').call(env, object, key, value); return value; } - if (code.car instanceof Pair && LSymbol.is(code.car.car, '.')) { + if (is_pair(code.car) && LSymbol.is(code.car.car, '.')) { var second = code.car.cdr.car; var third = code.car.cdr.cdr.car; var object = _evaluate(second, eval_args); @@ -11974,7 +11978,7 @@ var global_env = new Environment({ }, "(set-cdr! obj value)\n\n Function that sets the cdr (tail) of the list/pair to specified value.\n It will destroy the list. The old tail is lost."), // ------------------------------------------------------------------ 'empty?': doc('empty?', function (x) { - return typeof x === 'undefined' || x === _nil; + return typeof x === 'undefined' || is_nil(x); }, "(empty? object)\n\n Function that returns #t if value is nil (an empty list) or undefined."), // ------------------------------------------------------------------ gensym: doc('gensym', gensym, "(gensym)\n\n Generates a unique symbol that is not bound anywhere,\n to use with macros as meta name."), @@ -12059,7 +12063,7 @@ var global_env = new Environment({ case 10: _args19 = _context17.sent; case 11: - if (_args19 && _args19 !== _nil) { + if (_args19 && !is_nil(_args19)) { process.cwd(); file = path.join(path.dirname(_args19.car.valueOf()), file); } @@ -12134,7 +12138,7 @@ var global_env = new Environment({ vars = code.car; test = code.cdr.car; body = code.cdr.cdr; - if (body !== _nil) { + if (!is_nil(body)) { body = new Pair(LSymbol('begin'), body); } eval_args = { @@ -12145,7 +12149,7 @@ var global_env = new Environment({ }; node = vars; case 9: - if (!(node !== _nil)) { + if (is_nil(node)) { _context19.next = 20; break; } @@ -12171,7 +12175,7 @@ var global_env = new Environment({ return _regeneratorRuntime.wrap(function _loop3$(_context18) { while (1) switch (_context18.prev = _context18.next) { case 0: - if (!(body !== _nil)) { + if (is_nil(body)) { _context18.next = 3; break; } @@ -12181,12 +12185,12 @@ var global_env = new Environment({ node = vars; next = {}; case 5: - if (!(node !== _nil)) { + if (is_nil(node)) { _context18.next = 15; break; } _item = node.car; - if (!(_item.cdr.cdr !== _nil)) { + if (is_nil(_item.cdr.cdr)) { _context18.next = 12; break; } @@ -12224,7 +12228,7 @@ var global_env = new Environment({ _context19.next = 22; break; case 29: - if (!(test.cdr !== _nil)) { + if (is_nil(test.cdr)) { _context19.next = 33; break; } @@ -12262,7 +12266,7 @@ var global_env = new Environment({ return _evaluate(code.cdr.car, eval_args); } }; - if (code === _nil) { + if (is_nil(code)) { throw new Error('too few expressions for `if`'); } var cond = _evaluate(code.car, eval_args); @@ -12306,7 +12310,7 @@ var global_env = new Environment({ shuffle: doc('shuffle', function (arg) { typecheck('shuffle', arg, ['pair', 'nil', 'array']); var random = global_env.get('random'); - if (arg === _nil) { + if (is_nil(arg)) { return _nil; } if (Array.isArray(arg)) { @@ -12399,7 +12403,7 @@ var global_env = new Environment({ eval_args.dynamic_env; var init = _evaluate(code.car, eval_args); var fn; - if (code.cdr.car instanceof Pair) { + if (is_pair(code.cdr.car)) { fn = _evaluate(code.cdr.car, eval_args); } return new Parameter(init, fn); @@ -12420,7 +12424,7 @@ var global_env = new Environment({ syntax.__name__ = syntax.__name__.valueOf(); } var __doc__; - if (code.cdr.cdr instanceof Pair && LString.isString(code.cdr.cdr.car)) { + if (is_pair(code.cdr.cdr) && LString.isString(code.cdr.cdr.car)) { __doc__ = code.cdr.cdr.car.valueOf(); } env.set(code.car, new SyntaxParameter(syntax), __doc__, true); @@ -12467,7 +12471,7 @@ var global_env = new Environment({ // ------------------------------------------------------------------ define: doc(Macro.defmacro('define', function (code, eval_args) { var env = this; - if (code.car instanceof Pair && code.car.car instanceof LSymbol) { + if (is_pair(code.car) && code.car.car instanceof LSymbol) { var new_code = new Pair(new LSymbol("define"), new Pair(code.car.car, new Pair(new Pair(new LSymbol("lambda"), new Pair(code.car.cdr, code.cdr))))); return new_code; } else if (eval_args.macro_expand) { @@ -12478,7 +12482,7 @@ var global_env = new Environment({ eval_args.env = env; var value = code.cdr.car; var new_expr; - if (value instanceof Pair) { + if (is_pair(value)) { value = _evaluate(value, eval_args); new_expr = true; } else if (value instanceof LSymbol) { @@ -12496,7 +12500,7 @@ var global_env = new Environment({ } } var __doc__; - if (code.cdr.cdr instanceof Pair && LString.isString(code.cdr.cdr.car)) { + if (is_pair(code.cdr.cdr) && LString.isString(code.cdr.cdr.car)) { __doc__ = code.cdr.cdr.car.valueOf(); } env.set(code.car, value, __doc__, true); @@ -12518,7 +12522,7 @@ var global_env = new Environment({ } else if (is_prototype(obj) && is_function(value)) { obj[key] = unbind(value); obj[key][__prototype__] = true; - } else if (is_function(value) || is_native(value) || value === _nil) { + } else if (is_function(value) || is_native(value) || is_nil(value)) { obj[key] = value; } else { obj[key] = value && !is_prototype(value) ? value.valueOf() : value; @@ -12588,7 +12592,7 @@ var global_env = new Environment({ error = _ref34.error; var self = this; var __doc__; - if (code.cdr instanceof Pair && LString.isString(code.cdr.car) && code.cdr.cdr !== _nil) { + if (is_pair(code.cdr) && LString.isString(code.cdr.car) && !is_nil(code.cdr.cdr)) { __doc__ = code.cdr.car.valueOf(); } function lambda() { @@ -12635,9 +12639,9 @@ var global_env = new Environment({ } var name = code.car; var i = 0; - if (name instanceof LSymbol || name !== _nil) { + if (name instanceof LSymbol || !is_nil(name)) { while (true) { - if (name.car !== _nil) { + if (!is_nil(name.car)) { if (name instanceof LSymbol) { // rest argument, can also be first argument var value = quote(Pair.fromArray(args.slice(i), false)); @@ -12648,7 +12652,7 @@ var global_env = new Environment({ set(name.car, _value6); } } - if (name.cdr === _nil) { + if (is_nil(name.cdr)) { break; } i++; @@ -12665,10 +12669,10 @@ var global_env = new Environment({ }; return _evaluate(output, eval_args); } - var length = code.car instanceof Pair ? code.car.length() : null; + var length = is_pair(code.car) ? code.car.length() : null; lambda.__code__ = new Pair(new LSymbol('lambda'), code); lambda[__lambda__] = true; - if (!(code.car instanceof Pair)) { + if (!is_pair(code.car)) { return doc(lambda, __doc__, true); // variable arguments } // wrap and decorate with __doc__ @@ -12680,10 +12684,10 @@ var global_env = new Environment({ 'define-macro': doc(new Macro(macro, function (macro, _ref36) { var use_dynamic = _ref36.use_dynamic, error = _ref36.error; - if (macro.car instanceof Pair && macro.car.car instanceof LSymbol) { + if (is_pair(macro.car) && macro.car.car instanceof LSymbol) { var name = macro.car.car.__name__; var __doc__; - if (LString.isString(macro.cdr.car) && macro.cdr.cdr instanceof Pair) { + if (LString.isString(macro.cdr.car) && is_pair(macro.cdr.cdr)) { __doc__ = macro.cdr.car.valueOf(); } var makro_instance = Macro.defmacro(name, function (code) { @@ -12691,26 +12695,26 @@ var global_env = new Environment({ var name = macro.car.cdr; var arg = code; while (true) { - if (name === _nil) { + if (is_nil(name)) { break; } if (name instanceof LSymbol) { env.__env__[name.__name__] = arg; break; - } else if (name.car !== _nil) { - if (arg === _nil) { + } else if (!is_nil(name.car)) { + if (is_nil(arg)) { env.__env__[name.car.__name__] = _nil; } else { - if (arg.car instanceof Pair) { + if (is_pair(arg.car)) { arg.car[__data__] = true; } env.__env__[name.car.__name__] = arg.car; } } - if (name.cdr === _nil) { + if (is_nil(name.cdr)) { break; } - if (arg !== _nil) { + if (!is_nil(arg)) { arg = arg.cdr; } name = name.cdr; @@ -12722,7 +12726,7 @@ var global_env = new Environment({ error: error }; // evaluate macro - if (macro.cdr instanceof Pair) { + if (is_pair(macro.cdr)) { // this eval will return lips code var rest = __doc__ ? macro.cdr.cdr : macro.cdr; var result = rest.reduce(function (result, node) { @@ -12748,7 +12752,7 @@ var global_env = new Environment({ var env = this; function get_identifiers(node) { var symbols = []; - while (node !== _nil) { + while (!is_nil(node)) { var x = node.car; symbols.push(x.valueOf()); node = node.cdr; @@ -12756,7 +12760,7 @@ var global_env = new Environment({ return symbols; } function validate_identifiers(node) { - while (node !== _nil) { + while (!is_nil(node)) { var x = node.car; if (!(x instanceof LSymbol)) { throw new Error('syntax-rules: wrong identifier'); @@ -12803,7 +12807,7 @@ var global_env = new Environment({ rules = macro.cdr; } try { - while (rules !== _nil) { + while (!is_nil(rules)) { var rule = rules.car.car; var expr = rules.car.cdr.car; log('[[[ RULE'); @@ -12881,12 +12885,12 @@ var global_env = new Environment({ var dynamic_env = self; // ----------------------------------------------------------------- function is_struct(value) { - return value instanceof Pair || is_plain_object(value) || Array.isArray(value); + return is_pair(value) || is_plain_object(value) || Array.isArray(value); } // ----------------------------------------------------------------- function resolve_pair(pair, fn) { var test = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : is_struct; - if (pair instanceof Pair) { + if (is_pair(pair)) { var car = pair.car; var cdr = pair.cdr; if (test(car)) { @@ -12910,8 +12914,8 @@ var global_env = new Environment({ } // ----------------------------------------------------------------- function join(eval_pair, value) { - if (eval_pair instanceof Pair) { - if (value !== _nil) { + if (is_pair(eval_pair)) { + if (!is_nil(value)) { eval_pair.append(value); } } else { @@ -12922,13 +12926,13 @@ var global_env = new Environment({ // ----------------------------------------------------------------- function unquoted_arr(arr) { return !!arr.filter(function (value) { - return value instanceof Pair && LSymbol.is(value.car, /^(unquote|unquote-splicing)$/); + return is_pair(value) && LSymbol.is(value.car, /^(unquote|unquote-splicing)$/); }).length; } // ----------------------------------------------------------------- function quote_vector(arr, unquote_cnt, max_unq) { return arr.reduce(function (acc, x) { - if (!(x instanceof Pair)) { + if (!is_pair(x)) { acc.push(x); return acc; } @@ -12944,7 +12948,7 @@ var global_env = new Environment({ error: error }); } - if (!(result instanceof Pair)) { + if (!is_pair(result)) { throw new Error("Expecting list ".concat(type(x), " found")); } return acc.concat(result.to_array()); @@ -12959,7 +12963,7 @@ var global_env = new Environment({ unquote_cnt++; Object.keys(object).forEach(function (key) { var value = object[key]; - if (value instanceof Pair) { + if (is_pair(value)) { if (LSymbol.is(value.car, 'unquote-splicing')) { throw new Error("You can't call `unquote-splicing` " + "inside object"); } @@ -12998,17 +13002,17 @@ var global_env = new Environment({ error: error }); lists.push(value); - if (node.cdr instanceof Pair) { + if (is_pair(node.cdr)) { return next(node.cdr); } return unpromise(lists, function (arr) { if (arr.some(function (x) { - return !(x instanceof Pair); + return !is_pair(x); })) { - if (pair.cdr instanceof Pair && LSymbol.is(pair.cdr.car, '.') && pair.cdr.cdr instanceof Pair && pair.cdr.cdr.cdr === _nil) { + if (is_pair(pair.cdr) && LSymbol.is(pair.cdr.car, '.') && is_pair(pair.cdr.cdr) && is_nil(pair.cdr.cdr.cdr)) { return pair.cdr.cdr.car; } - if (!(pair.cdr === _nil || pair.cdr instanceof Pair)) { + if (!(is_nil(pair.cdr) || is_pair(pair.cdr))) { var msg = "You can't splice atom inside list"; throw new Error(msg); } @@ -13016,7 +13020,7 @@ var global_env = new Environment({ var _msg = "You can't splice multiple atoms inside list"; throw new Error(_msg); } - if (!(pair.cdr instanceof Pair && arr[0] === _nil)) { + if (!(is_pair(pair.cdr) && is_nil(arr[0]))) { return arr[0]; } } @@ -13030,11 +13034,11 @@ var global_env = new Environment({ } }); var value = recur(pair.cdr, 0, 1); - if (value === _nil && arr[0] === _nil) { + if (is_nil(value) && is_nil(arr[0])) { return undefined; } return unpromise(value, function (value) { - if (arr[0] === _nil) { + if (is_nil(arr[0])) { return value; } if (arr.length === 1) { @@ -13051,22 +13055,22 @@ var global_env = new Environment({ // ----------------------------------------------------------------- var splices = new Set(); function recur(pair, unquote_cnt, max_unq) { - if (pair instanceof Pair) { - if (pair.car instanceof Pair) { + if (is_pair(pair)) { + if (is_pair(pair.car)) { if (LSymbol.is(pair.car.car, 'unquote-splicing')) { return unquote_splice(pair, unquote_cnt + 1, max_unq); } if (LSymbol.is(pair.car.car, 'unquote')) { // + 2 - one for unquote and one for unquote splicing - if (unquote_cnt + 2 === max_unq && pair.car.cdr instanceof Pair && pair.car.cdr.car instanceof Pair && LSymbol.is(pair.car.cdr.car.car, 'unquote-splicing')) { + if (unquote_cnt + 2 === max_unq && is_pair(pair.car.cdr) && is_pair(pair.car.cdr.car) && LSymbol.is(pair.car.cdr.car.car, 'unquote-splicing')) { var rest = pair.car.cdr; return new Pair(new Pair(new LSymbol('unquote'), unquote_splice(rest, unquote_cnt + 2, max_unq)), _nil); - } else if (pair.car.cdr instanceof Pair && pair.car.cdr.cdr !== _nil) { - if (pair.car.cdr.car instanceof Pair) { + } else if (is_pair(pair.car.cdr) && !is_nil(pair.car.cdr.cdr)) { + if (is_pair(pair.car.cdr.car)) { // values inside unquote are lists var result = []; return function recur(node) { - if (node === _nil) { + if (is_nil(node)) { return Pair.fromArray(result); } return unpromise(_evaluate(node.car, { @@ -13103,9 +13107,9 @@ var global_env = new Environment({ if (unquote_cnt > max_unq) { throw new Error("You can't call `unquote` outside " + "of quasiquote"); } - if (pair.cdr instanceof Pair) { - if (pair.cdr.cdr !== _nil) { - if (pair.cdr.car instanceof Pair) { + if (is_pair(pair.cdr)) { + if (!is_nil(pair.cdr.cdr)) { + if (is_pair(pair.cdr.car)) { // TODO: test if this part is needed // this part was duplicated in previous section // if (LSymbol.is(pair.car.car, 'unquote')) { @@ -13113,7 +13117,7 @@ var global_env = new Environment({ var _result4 = []; // evaluate all values in unquote return function recur(node) { - if (node === _nil) { + if (is_nil(node)) { return Pair.fromArray(_result4); } return unpromise(_evaluate(node.car, { @@ -13152,7 +13156,7 @@ var global_env = new Environment({ } // ----------------------------------------------------------------- function clear(node) { - if (node instanceof Pair) { + if (is_pair(node)) { delete node[__data__]; if (!node.haveCycles('car')) { clear(node.car); @@ -13169,7 +13173,7 @@ var global_env = new Environment({ if (Array.isArray(arg.car) && !unquoted_arr(arg.car)) { return quote(arg.car); } - if (arg.car instanceof Pair && !arg.car.find('unquote') && !arg.car.find('unquote-splicing') && !arg.car.find('quasiquote')) { + if (is_pair(arg.car) && !arg.car.find('unquote') && !arg.car.find('unquote-splicing') && !arg.car.find('quasiquote')) { return quote(arg.car); } var x = recur(arg.car, 0, 1); @@ -13191,7 +13195,7 @@ var global_env = new Environment({ items[_key25] = arguments[_key25]; } items = items.map(function (item) { - if (item instanceof Pair) { + if (is_pair(item)) { return item.clone(); } return item; @@ -13206,11 +13210,11 @@ var global_env = new Environment({ } return items.reduce(function (acc, item) { typecheck('append!', acc, ['nil', 'pair']); - if ((item instanceof Pair || item === _nil) && !is_list(item)) { + if ((is_pair(item) || is_nil(item)) && !is_list(item)) { throw new Error('append!: Invalid argument, value is not a list'); } - if (acc === _nil) { - if (item === _nil) { + if (is_nil(acc)) { + if (is_nil(item)) { return _nil; } return item; @@ -13224,10 +13228,10 @@ var global_env = new Environment({ // ------------------------------------------------------------------ reverse: doc('reverse', function reverse(arg) { typecheck('reverse', arg, ['array', 'pair', 'nil']); - if (arg === _nil) { + if (is_nil(arg)) { return _nil; } - if (arg instanceof Pair) { + if (is_pair(arg)) { var arr = global_env.get('list->array')(arg).reverse(); return global_env.get('array->list')(arr); } else if (Array.isArray(arg)) { @@ -13240,11 +13244,11 @@ var global_env = new Environment({ nth: doc('nth', function nth(index, obj) { typecheck('nth', index, 'number'); typecheck('nth', obj, ['array', 'pair']); - if (obj instanceof Pair) { + if (is_pair(obj)) { var node = obj; var count = 0; while (count < index) { - if (!node.cdr || node.cdr === _nil || node.haveCycles('cdr')) { + if (!node.cdr || is_nil(node.cdr) || node.haveCycles('cdr')) { return _nil; } node = node.cdr; @@ -13422,9 +13426,7 @@ var global_env = new Environment({ return LString.isString(obj); }, "(string? expression)\n\n Predicate that tests if value is a string."), // ------------------------------------------------------------------ - 'pair?': doc('pair?', function (obj) { - return obj instanceof Pair; - }, "(pair? expression)\n\n Predicate that tests if value is a pair or list structure."), + 'pair?': doc('pair?', is_pair, "(pair? expression)\n\n Predicate that tests if value is a pair or list structure."), // ------------------------------------------------------------------ 'regex?': doc('regex?', function (obj) { return obj instanceof RegExp; @@ -13447,7 +13449,7 @@ var global_env = new Environment({ }, "(array? expression)\n\n Predicate that tests if value is an array."), // ------------------------------------------------------------------ 'object?': doc('object?', function (obj) { - return obj !== _nil && obj !== null && !(obj instanceof LCharacter) && !(obj instanceof RegExp) && !(obj instanceof LString) && !(obj instanceof Pair) && !(obj instanceof LNumber) && _typeof$1(obj) === 'object' && !(obj instanceof Array); + return !is_nil(obj) && obj !== null && !(obj instanceof LCharacter) && !(obj instanceof RegExp) && !(obj instanceof LString) && !is_pair(obj) && !(obj instanceof LNumber) && _typeof$1(obj) === 'object' && !(obj instanceof Array); }, "(object? expression)\n\n Predicate that tests if value is an plain object (not another LIPS type)."), // ------------------------------------------------------------------ flatten: doc('flatten', function flatten(list) { @@ -13476,10 +13478,10 @@ var global_env = new Environment({ }, "(apply fn list)\n\n Function that calls fn with the list of arguments."), // ------------------------------------------------------------------ length: doc('length', function length(obj) { - if (!obj || obj === _nil) { + if (!obj || is_nil(obj)) { return 0; } - if (obj instanceof Pair) { + if (is_pair(obj)) { return obj.length(); } if ("length" in obj) { @@ -13517,7 +13519,7 @@ var global_env = new Environment({ var catch_clause, finally_clause; if (LSymbol.is(code.cdr.car.car, 'catch')) { catch_clause = code.cdr.car; - if (code.cdr.cdr instanceof Pair && LSymbol.is(code.cdr.cdr.car.car, 'finally')) { + if (is_pair(code.cdr.cdr) && LSymbol.is(code.cdr.cdr.car.car, 'finally')) { finally_clause = code.cdr.cdr.car; } } else if (LSymbol.is(code.cdr.car.car, 'finally')) { @@ -13606,7 +13608,7 @@ var global_env = new Environment({ } var fn = matcher('find', arg); return unpromise(fn(list.car), function (value) { - if (value && value !== _nil) { + if (value && !is_nil(value)) { return list.car; } return find(arg, list.cdr); @@ -13641,16 +13643,14 @@ var global_env = new Environment({ lists.forEach(function (arg, i) { typecheck('map', arg, ['pair', 'nil'], i + 1); // detect cycles - if (arg instanceof Pair && !is_list.call(_this27, arg)) { + if (is_pair(arg) && !is_list.call(_this27, arg)) { throw new Error("map: argument ".concat(i + 1, " is not a list")); } }); if (lists.length === 0) { return _nil; } - if (lists.some(function (x) { - return x === _nil; - })) { + if (lists.some(is_nil)) { return _nil; } var args = lists.map(function (l) { @@ -13676,10 +13676,10 @@ var global_env = new Environment({ 'list?': doc('list?', function (obj) { var node = obj; while (true) { - if (node === _nil) { + if (is_nil(node)) { return true; } - if (!(node instanceof Pair)) { + if (!is_pair(node)) { return false; } if (node.haveCycles('cdr')) { @@ -13709,9 +13709,7 @@ var global_env = new Environment({ lists.forEach(function (arg, i) { typecheck('fold', arg, ['pair', 'nil'], i + 1); }); - if (lists.some(function (x) { - return x === _nil; - })) { + if (lists.some(is_nil)) { return init; } var value = fold.call.apply(fold, [this, fn, init].concat(_toConsumableArray(lists.map(function (l) { @@ -13757,9 +13755,7 @@ var global_env = new Environment({ lists.forEach(function (arg, i) { typecheck('reduce', arg, ['pair', 'nil'], i + 1); }); - if (lists.some(function (x) { - return x === _nil; - })) { + if (lists.some(is_nil)) { return init; } return unpromise(fn.apply(void 0, _toConsumableArray(lists.map(function (l) { @@ -13779,7 +13775,7 @@ var global_env = new Environment({ var fn = matcher('filter', arg); return function loop(i) { function next(value) { - if (value && value !== _nil) { + if (value && !is_nil(value)) { result.push(item); } return loop(++i); @@ -14302,7 +14298,7 @@ function typecheck_number(fn, arg, expected) { typecheck(fn, arg, 'number', position); var arg_type = arg.__type__; var match; - if (expected instanceof Pair) { + if (is_pair(expected)) { expected = expected.to_array(); } if (expected instanceof Array) { @@ -14357,7 +14353,7 @@ function typecheck(fn, arg, expected) { return; } var match = false; - if (expected instanceof Pair) { + if (is_pair(expected)) { expected = expected.to_array(); } if (expected instanceof Array) { @@ -14450,7 +14446,7 @@ function resolve_promises(arg) { function traverse(node) { if (is_promise(node)) { promises.push(node); - } else if (node instanceof Pair) { + } else if (is_pair(node)) { if (!node.haveCycles('car')) { traverse(node.car); } @@ -14516,7 +14512,7 @@ function resolve_promises(arg) { if (node instanceof Array) { return promise_all(node.map(resolve)); } - if (node instanceof Pair && promises.length) { + if (is_pair(node) && promises.length) { return promise(node); } return node; @@ -14533,7 +14529,7 @@ function evaluate_args(rest, _ref43) { return args; } return function loop() { - if (node instanceof Pair) { + if (is_pair(node)) { var arg = _evaluate(node.car, _objectSpread({ use_dynamic: use_dynamic }, options)); @@ -14554,7 +14550,7 @@ function evaluate_args(rest, _ref43) { node = node.cdr; return loop(); }); - } else if (node === _nil) { + } else if (is_nil(node)) { return next(); } else { throw new Error('Syntax Error: improper list found in apply'); @@ -14565,7 +14561,7 @@ function evaluate_args(rest, _ref43) { function evaluate_syntax(macro, code, eval_args) { var value = macro.invoke(code, eval_args); return unpromise(resolve_promises(value), function (value) { - if (value instanceof Pair) { + if (is_pair(value)) { value.markCycles(); } return quote(value); @@ -14574,7 +14570,7 @@ function evaluate_syntax(macro, code, eval_args) { // ------------------------------------------------------------------------- function evaluate_macro(macro, code, eval_args) { function finalize(result) { - if (result instanceof Pair) { + if (is_pair(result)) { result.markCycles(); return result; } @@ -14676,7 +14672,7 @@ function apply(fn, args) { use_dynamic: use_dynamic }); return unpromise(result, function (result) { - if (result instanceof Pair) { + if (is_pair(result)) { result.markCycles(); return quote(result); } @@ -14842,12 +14838,12 @@ function _evaluate(code) { if (code instanceof LSymbol) { return env.get(code); } - if (!(code instanceof Pair)) { + if (!is_pair(code)) { return code; } var first = code.car; var rest = code.cdr; - if (first instanceof Pair) { + if (is_pair(first)) { value = resolve_promises(_evaluate(first, eval_args)); if (is_promise(value)) { return value.then(function (value) { @@ -14886,7 +14882,7 @@ function _evaluate(code) { } } else if (is_continuation(value)) { result = value.invoke(); - } else if (code instanceof Pair) { + } else if (is_pair(code)) { value = first && first.toString(); throw new Error("".concat(type(first), " ").concat(value, " is not a function")); } else { @@ -14901,7 +14897,7 @@ function _evaluate(code) { // When promise is not quoted it happen automatically, when returning // promise from evaluate. result = result.then(function (result) { - if (result instanceof Pair && !value[__data__]) { + if (is_pair(result) && !value[__data__]) { return _evaluate(result, eval_args); } return result; @@ -15587,10 +15583,10 @@ if (typeof window !== 'undefined') { // ------------------------------------------------------------------------- var banner = function () { // Rollup tree-shaking is removing the variable if it's normal string because - // obviously 'Mon, 12 Feb 2024 12:58:05 +0000' == '{{' + 'DATE}}'; can be removed + // obviously 'Mon, 12 Feb 2024 14:25:33 +0000' == '{{' + 'DATE}}'; can be removed // but disabling Tree-shaking is adding lot of not used code so we use this // hack instead - var date = LString('Mon, 12 Feb 2024 12:58:05 +0000').valueOf(); + var date = LString('Mon, 12 Feb 2024 14:25:33 +0000').valueOf(); var _date = date === '{{' + 'DATE}}' ? new Date() : new Date(date); var _format = function _format(x) { return x.toString().padStart(2, '0'); @@ -15630,7 +15626,7 @@ read_only(QuotedPromise, '__class__', 'promise'); read_only(Parameter, '__class__', 'parameter'); // ------------------------------------------------------------------------- var version = 'DEV'; -var date = 'Mon, 12 Feb 2024 12:58:05 +0000'; +var date = 'Mon, 12 Feb 2024 14:25:33 +0000'; // unwrap async generator into Promise var parse = compose(uniterate_async, _parse); diff --git a/dist/lips.esm.js b/dist/lips.esm.js index ea26c9041..c3d415c3b 100644 --- a/dist/lips.esm.js +++ b/dist/lips.esm.js @@ -31,7 +31,7 @@ * Copyright (c) 2014-present, Facebook, Inc. * released under MIT license * - * build: Mon, 12 Feb 2024 12:58:05 +0000 + * build: Mon, 12 Feb 2024 14:25:33 +0000 */ function _classApplyDescriptorGet(receiver, descriptor) { @@ -6999,7 +6999,7 @@ var Parser = /*#__PURE__*/function () { this.skip(); return _context3.abrupt("break", 32); case 10: - if (!(token === '.' && head !== _nil)) { + if (!(token === '.' && !is_nil(head))) { _context3.next = 18; break; } @@ -7025,7 +7025,7 @@ var Parser = /*#__PURE__*/function () { _context3.t1 = _context3.sent; _context3.t2 = _nil; cur = new _context3.t0(_context3.t1, _context3.t2); - if (head === _nil) { + if (is_nil(head)) { head = cur; } else { prev.cdr = cur; @@ -7175,7 +7175,7 @@ var Parser = /*#__PURE__*/function () { }); return _context6.abrupt("return", result); case 6: - if (!(object instanceof Pair)) { + if (!is_pair(object)) { _context6.next = 8; break; } @@ -7200,7 +7200,7 @@ var Parser = /*#__PURE__*/function () { return _regeneratorRuntime.wrap(function _callee7$(_context7) { while (1) switch (_context7.prev = _context7.next) { case 0: - if (!(pair instanceof Pair)) { + if (!is_pair(pair)) { _context7.next = 15; break; } @@ -7300,9 +7300,9 @@ var Parser = /*#__PURE__*/function () { } if (is_literal(token)) { args = [object]; - } else if (object === _nil) { + } else if (is_nil(object)) { args = []; - } else if (object instanceof Pair) { + } else if (is_pair(object)) { args = object.to_array(false); } if (!(args || is_symbol)) { @@ -7337,7 +7337,7 @@ var Parser = /*#__PURE__*/function () { return this.evaluate(expr); case 31: result = _context8.sent; - if (!(result instanceof Pair || result instanceof LSymbol)) { + if (!(is_pair(result) || result instanceof LSymbol)) { _context8.next = 34; break; } @@ -8269,23 +8269,23 @@ function Pair(car, cdr) { function to_array(name, deep) { return function recur(list) { typecheck(name, list, ['pair', 'nil']); - if (list === _nil) { + if (is_nil(list)) { return []; } var result = []; var node = list; while (true) { - if (node instanceof Pair) { + if (is_pair(node)) { if (node.haveCycles('cdr')) { break; } var car = node.car; - if (deep && car instanceof Pair) { + if (deep && is_pair(car)) { car = this.get(name).call(this, car); } result.push(car); node = node.cdr; - } else if (node === _nil) { + } else if (is_nil(node)) { break; } else { throw new Error("".concat(name, ": can't convert improper list")); @@ -8303,7 +8303,7 @@ Pair.prototype.length = function () { var len = 0; var node = this; while (true) { - if (!node || node === _nil || !(node instanceof Pair) || node.haveCycles('cdr')) { + if (!node || is_nil(node) || !is_pair(node) || node.haveCycles('cdr')) { break; } len++; @@ -8315,7 +8315,7 @@ Pair.prototype.length = function () { Pair.match = function (obj, item) { if (obj instanceof LSymbol) { return LSymbol.is(obj, item); - } else if (obj instanceof Pair) { + } else if (is_pair(obj)) { return Pair.match(obj.car, item) || Pair.match(obj.cdr, item); } else if (Array.isArray(obj)) { return obj.some(function (x) { @@ -8338,7 +8338,7 @@ Pair.prototype.clone = function () { var deep = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true; var visited = new Map(); function clone(node) { - if (node instanceof Pair) { + if (is_pair(node)) { if (visited.has(node)) { return visited.get(node); } @@ -8376,7 +8376,7 @@ Pair.prototype.last_pair = function () { Pair.prototype.to_array = function () { var deep = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true; var result = []; - if (this.car instanceof Pair) { + if (is_pair(this.car)) { if (deep) { result.push(this.car.to_array()); } else { @@ -8385,7 +8385,7 @@ Pair.prototype.to_array = function () { } else { result.push(this.car.valueOf()); } - if (this.cdr instanceof Pair) { + if (is_pair(this.cdr)) { result = result.concat(this.cdr.to_array(deep)); } return result; @@ -8397,7 +8397,7 @@ Pair.prototype.to_array = function () { Pair.fromArray = function (array) { var deep = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; var quote = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; - if (array instanceof Pair || quote && array instanceof Array && array[__data__]) { + if (is_pair(array) || quote && array instanceof Array && array[__data__]) { return array; } if (deep === false) { @@ -8436,7 +8436,7 @@ Pair.prototype.to_object = function () { var node = this; var result = {}; while (true) { - if (node instanceof Pair && node.car instanceof Pair) { + if (is_pair(node) && is_pair(node.car)) { var pair = node.car; var name = pair.car; if (name instanceof LSymbol) { @@ -8446,7 +8446,7 @@ Pair.prototype.to_object = function () { name = name.valueOf(); } var cdr = pair.cdr; - if (cdr instanceof Pair) { + if (is_pair(cdr)) { cdr = cdr.to_object(literal); } if (is_native(cdr)) { @@ -8483,7 +8483,7 @@ Pair.prototype.reduce = function (fn) { var node = this; var result = _nil; while (true) { - if (node !== _nil) { + if (!is_nil(node)) { result = fn(result, node.car); node = node.cdr; } else { @@ -8500,7 +8500,7 @@ Pair.prototype.reverse = function () { } var node = this; var prev = _nil; - while (node !== _nil) { + while (!is_nil(node)) { var next = node.cdr; node.cdr = prev; prev = node; @@ -8512,17 +8512,17 @@ Pair.prototype.reverse = function () { // ---------------------------------------------------------------------- Pair.prototype.transform = function (fn) { function recur(pair) { - if (pair instanceof Pair) { + if (is_pair(pair)) { if (pair.replace) { delete pair.replace; return pair; } var car = fn(pair.car); - if (car instanceof Pair) { + if (is_pair(car)) { car = recur(car); } var cdr = fn(pair.cdr); - if (cdr instanceof Pair) { + if (is_pair(cdr)) { cdr = recur(cdr); } return new Pair(car, cdr); @@ -8535,7 +8535,7 @@ Pair.prototype.transform = function (fn) { // ---------------------------------------------------------------------- Pair.prototype.map = function (fn) { if (typeof this.car !== 'undefined') { - return new Pair(fn(this.car), this.cdr === _nil ? _nil : this.cdr.map(fn)); + return new Pair(fn(this.car), is_nil(this.cdr) ? _nil : this.cdr.map(fn)); } else { return _nil; } @@ -8830,7 +8830,7 @@ function markCycles(pair) { } } function set(node, type, child, parents) { - if (child instanceof Pair) { + if (is_pair(child)) { if (parents.includes(child)) { if (!refs.includes(child)) { refs.push(child); @@ -8847,7 +8847,7 @@ function markCycles(pair) { } } var detect = trampoline(function detect_thunk(pair, parents) { - if (pair instanceof Pair) { + if (is_pair(pair)) { delete pair.ref; delete pair[__cycles__]; visit(pair); @@ -8865,7 +8865,7 @@ function markCycles(pair) { } }); function mark_node(node, type) { - if (node[__cycles__][type] instanceof Pair) { + if (is_pair(node[__cycles__][type])) { var count = ref_nodes.indexOf(node[__cycles__][type]); node[__cycles__][type] = "#".concat(count, "#"); } @@ -8903,7 +8903,7 @@ Pair.prototype.toString = function (quote) { if (value !== undefined) { arr.push(value); } - if (this.cdr instanceof Pair) { + if (is_pair(this.cdr)) { if (this[__cycles__] && this[__cycles__].cdr) { arr.push(' . '); arr.push(this[__cycles__].cdr); @@ -8918,7 +8918,7 @@ Pair.prototype.toString = function (quote) { }); arr.push(cdr); } - } else if (this.cdr !== _nil) { + } else if (!is_nil(this.cdr)) { arr = arr.concat([' . ', toString(this.cdr, quote, true)]); } if (!nested || this[__ref__]) { @@ -8930,7 +8930,7 @@ Pair.prototype.toString = function (quote) { // ---------------------------------------------------------------------- Pair.prototype.set = function (prop, value) { this[prop] = value; - if (value instanceof Pair) { + if (is_pair(value)) { this.markCycles(); } }; @@ -8942,15 +8942,15 @@ Pair.prototype.append = function (arg) { } var p = this; if (p.car === undefined) { - if (arg instanceof Pair) { + if (is_pair(arg)) { this.car = arg.car; this.cdr = arg.cdr; } else { this.car = arg; } - } else if (arg !== _nil) { + } else if (!is_nil(arg)) { while (true) { - if (p instanceof Pair && p.cdr !== _nil) { + if (is_pair(p) && !is_nil(p.cdr)) { p = p.cdr; } else { break; @@ -8973,7 +8973,7 @@ Pair.prototype[Symbol.iterator] = function () { next: function next() { var cur = node; node = cur.cdr; - if (cur === _nil) { + if (is_nil(cur)) { return { value: undefined, done: true @@ -9077,7 +9077,7 @@ function same_atom(a, b) { } // ---------------------------------------------------------------------- function is_atom(obj) { - return obj instanceof LSymbol || LString.isString(obj) || obj === _nil || obj === null || obj instanceof LCharacter || obj instanceof LNumber || obj === true || obj === false; + return obj instanceof LSymbol || LString.isString(obj) || is_nil(obj) || obj === null || obj instanceof LCharacter || obj instanceof LNumber || obj === true || obj === false; } // ---------------------------------------------------------------------- var truncate = function () { @@ -9152,7 +9152,7 @@ function macro_expand(single) { return _regeneratorRuntime.wrap(function _callee11$(_context11) { while (1) switch (_context11.prev = _context11.next) { case 0: - if (!(node instanceof Pair && node.car instanceof LSymbol)) { + if (!(is_pair(node) && node.car instanceof LSymbol)) { _context11.next = 50; break; } @@ -9168,7 +9168,7 @@ function macro_expand(single) { }); is_let = is_let_macro(node.car); is_binding = is_let || is_procedure(value, node) || is_lambda(value); - if (!(is_binding && node.cdr.car instanceof Pair)) { + if (!(is_binding && is_pair(node.cdr.car))) { _context11.next = 28; break; } @@ -9214,7 +9214,7 @@ function macro_expand(single) { break; } _result = result, expr = _result.expr, scope = _result.scope; - if (!(expr instanceof Pair)) { + if (!is_pair(expr)) { _context11.next = 40; break; } @@ -9237,7 +9237,7 @@ function macro_expand(single) { } return _context11.abrupt("return", quote(result)); case 43: - if (!(result instanceof Pair)) { + if (!is_pair(result)) { _context11.next = 48; break; } @@ -9260,7 +9260,7 @@ function macro_expand(single) { case 50: // TODO: CYCLE DETECT car = node.car; - if (!(car instanceof Pair)) { + if (!is_pair(car)) { _context11.next = 55; break; } @@ -9270,7 +9270,7 @@ function macro_expand(single) { car = _context11.sent; case 55: cdr = node.cdr; - if (!(cdr instanceof Pair)) { + if (!is_pair(cdr)) { _context11.next = 60; break; } @@ -9298,7 +9298,7 @@ function macro_expand(single) { return _regeneratorRuntime.wrap(function _callee10$(_context10) { while (1) switch (_context10.prev = _context10.next) { case 0: - if (!(node === _nil)) { + if (!is_nil(node)) { _context10.next = 2; break; } @@ -9334,7 +9334,7 @@ function macro_expand(single) { }; let_binding = function _let_binding(node) { return [].concat(_toConsumableArray(bindings), _toConsumableArray(node.to_array(false).map(function (node) { - if (node instanceof Pair) { + if (is_pair(node)) { return node.car.valueOf(); } var t = type(node); @@ -9345,7 +9345,7 @@ function macro_expand(single) { proc_bindings = function _proc_bindings(node) { var names = []; while (true) { - if (node !== _nil) { + if (!is_nil(node)) { if (node instanceof LSymbol) { names.push(node.valueOf()); break; @@ -9362,7 +9362,7 @@ function macro_expand(single) { return value === lambda; }; is_procedure = function _is_procedure(value, node) { - return value === define && node.cdr.car instanceof Pair; + return value === define && is_pair(node.cdr.car); }; is_let_macro = function _is_let_macro(symbol) { var name = symbol.valueOf(); @@ -9373,7 +9373,7 @@ function macro_expand(single) { let_macros = ['let', 'let*', 'letrec']; lambda = global_env.get('lambda'); define = global_env.get('define'); //var this.__code__ = code; - if (!(code.cdr instanceof Pair && LNumber.isNumber(code.cdr.car))) { + if (!(is_pair(code.cdr) && LNumber.isNumber(code.cdr.car))) { _context12.next = 21; break; } @@ -9548,9 +9548,9 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol) { return first && rest; } // pattern (a b (x ...)) and (x ...) match nil - if (pattern instanceof Pair && pattern.car instanceof Pair && pattern.car.cdr instanceof Pair && LSymbol.is(pattern.car.cdr.car, ellipsis_symbol)) { + if (is_pair(pattern) && is_pair(pattern.car) && is_pair(pattern.car.cdr) && LSymbol.is(pattern.car.cdr.car, ellipsis_symbol)) { log('>> 0'); - if (code === _nil) { + if (is_nil(code)) { log({ pattern: pattern }); @@ -9563,10 +9563,10 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol) { } } } - if (pattern instanceof Pair && pattern.cdr instanceof Pair && LSymbol.is(pattern.cdr.car, ellipsis_symbol)) { + if (is_pair(pattern) && is_pair(pattern.cdr) && LSymbol.is(pattern.cdr.car, ellipsis_symbol)) { // pattern (... ???) - SRFI-46 - if (pattern.cdr.cdr !== _nil) { - if (pattern.cdr.cdr instanceof Pair) { + if (!is_nil(pattern.cdr.cdr)) { + if (is_pair(pattern.cdr.cdr)) { // if we have (x ... a b) we need to remove two from the end var list_len = pattern.cdr.cdr.length(); if (!is_pair(code)) { @@ -9591,7 +9591,7 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol) { throw new Error('syntax: named ellipsis can only appear onces'); } log('>> 1'); - if (code === _nil) { + if (is_nil(code)) { log('>> 2'); if (ellipsis) { log('NIL'); @@ -9600,12 +9600,12 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol) { log('NULL'); bindings['...'].symbols[_name3] = null; } - } else if (code instanceof Pair && (code.car instanceof Pair || code.car === _nil)) { + } else if (is_pair(code) && (is_pair(code.car) || is_nil(code.car))) { log('>> 3 ' + ellipsis); if (ellipsis) { if (bindings['...'].symbols[_name3]) { var _node = bindings['...'].symbols[_name3]; - if (_node === _nil) { + if (is_nil(_node)) { _node = new Pair(_nil, new Pair(code, _nil)); } else { _node = _node.append(new Pair(code, _nil)); @@ -9620,11 +9620,11 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol) { } } else { log('>> 6'); - if (code instanceof Pair) { + if (is_pair(code)) { // cons (a . b) => (var ... . x) - if (!(code.cdr instanceof Pair) && code.cdr !== _nil) { + if (!is_pair(code.cdr) && !is_nil(code.cdr)) { log('>> 7 (b)'); - if (pattern.cdr.cdr === _nil) { + if (is_nil(pattern.cdr.cdr)) { return false; } else if (!bindings['...'].symbols[_name3]) { bindings['...'].symbols[_name3] = new Pair(code.car, _nil); @@ -9633,8 +9633,8 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol) { } // code as improper list var last_pair = code.last_pair(); - if (last_pair.cdr !== _nil) { - if (pattern.cdr.cdr === _nil) { + if (!is_nil(last_pair.cdr)) { + if (is_nil(pattern.cdr.cdr)) { // case (a ...) for (a b . x) return false; } else { @@ -9656,7 +9656,7 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol) { log({ IIIIII: bindings['...'].symbols[_name3] }); - } else if (pattern.car instanceof LSymbol && pattern.cdr instanceof Pair && LSymbol.is(pattern.cdr.car, ellipsis_symbol)) { + } else if (pattern.car instanceof LSymbol && is_pair(pattern.cdr) && LSymbol.is(pattern.cdr.car, ellipsis_symbol)) { // empty ellipsis with rest (a b ... . d) #290 log('>> 8'); bindings['...'].symbols[_name3] = null; @@ -9668,16 +9668,16 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol) { } } return true; - } else if (pattern.car instanceof Pair) { + } else if (is_pair(pattern.car)) { var names = _toConsumableArray(pattern_names); - if (code === _nil) { + if (is_nil(code)) { log('>> 10'); bindings['...'].lists.push(_nil); return true; } log('>> 11'); var _node3 = code; - while (_node3 instanceof Pair) { + while (is_pair(_node3)) { if (!traverse(pattern.car, _node3.car, names, true)) { return false; } @@ -9688,7 +9688,7 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol) { if (Array.isArray(pattern.car)) { var names = _toConsumableArray(pattern_names); var _node4 = code; - while (_node4 instanceof Pair) { + while (is_pair(_node4)) { if (!traverse(pattern.car, _node4.car, names, true)) { return false; } @@ -9717,14 +9717,14 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol) { } return true; } - if (pattern instanceof Pair && code instanceof Pair) { + if (is_pair(pattern) && is_pair(code)) { log('>> 13'); log({ a: 13, code: code, pattern: pattern }); - if (code.cdr === _nil) { + if (is_nil(code.cdr)) { // last item in in call using in recursive calls on // last element of the list // case of pattern (p . rest) and code (0) @@ -9752,7 +9752,7 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol) { code: code }); // case (x y) ===> (var0 var1 ... warn) where var1 match nil - if (pattern.cdr instanceof Pair && pattern.cdr.cdr instanceof Pair && pattern.cdr.car instanceof LSymbol && LSymbol.is(pattern.cdr.cdr.car, ellipsis_symbol) && pattern.cdr.cdr.cdr instanceof Pair && !LSymbol.is(pattern.cdr.cdr.cdr.car, ellipsis_symbol) && traverse(pattern.car, code.car, pattern_names, ellipsis) && traverse(pattern.cdr.cdr.cdr, code.cdr, pattern_names, ellipsis)) { + if (is_pair(pattern.cdr) && is_pair(pattern.cdr.cdr) && pattern.cdr.car instanceof LSymbol && LSymbol.is(pattern.cdr.cdr.car, ellipsis_symbol) && is_pair(pattern.cdr.cdr.cdr) && !LSymbol.is(pattern.cdr.cdr.cdr.car, ellipsis_symbol) && traverse(pattern.car, code.car, pattern_names, ellipsis) && traverse(pattern.cdr.cdr.cdr, code.cdr, pattern_names, ellipsis)) { var _name6 = pattern.cdr.car.__name__; log({ pattern: pattern, @@ -9784,11 +9784,11 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol) { if (car && cdr) { return true; } - } else if (pattern === _nil && (code === _nil || code === undefined)) { + } else if (is_nil(pattern) && (is_nil(code) || code === undefined)) { // undefined is case when you don't have body ... // and you do recursive call return true; - } else if (pattern.car instanceof Pair && LSymbol.is(pattern.car.car, ellipsis_symbol)) { + } else if (is_pair(pattern.car) && LSymbol.is(pattern.car.car, ellipsis_symbol)) { // pattern (...) throw new Error('syntax: invalid usage of ellipsis'); } else { @@ -9807,7 +9807,7 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol) { // ---------------------------------------------------------------------- function clear_gensyms(node, gensyms) { function traverse(node) { - if (node instanceof Pair) { + if (is_pair(node)) { if (!gensyms.length) { return node; } @@ -9937,19 +9937,19 @@ function transform_syntax() { if (is_gensym(expr) && !bindings[name]) ; log('[t 1'); if (bindings[name]) { - if (bindings[name] instanceof Pair) { + if (is_pair(bindings[name])) { var _bindings$name = bindings[name], car = _bindings$name.car, cdr = _bindings$name.cdr; if (nested) { var caar = car.car, cadr = car.cdr; - if (cadr !== _nil) { + if (!is_nil(cadr)) { next(name, new Pair(cadr, _nil)); } return caar; } - if (cdr !== _nil) { + if (!is_nil(cdr)) { next(name, cdr); } return car; @@ -9961,7 +9961,7 @@ function transform_syntax() { return transform(expr); } var is_array = Array.isArray(expr); - if (expr instanceof Pair || is_array) { + if (is_pair(expr) || is_array) { var first = is_array ? expr[0] : expr.car; var second = is_array ? expr[1] : is_pair(expr.cdr) && expr.cdr.car; if (first instanceof LSymbol && LSymbol.is(second, ellipsis_symbol)) { @@ -9976,17 +9976,17 @@ function transform_syntax() { name: _name7, binding: bindings[_name7] }); - if (item instanceof Pair) { + if (is_pair(item)) { log('[t 2 Pair ' + nested); var _car = item.car, _cdr = item.cdr; var _rest_expr = is_array ? expr.slice(2) : expr.cdr.cdr; if (nested) { - if (_cdr !== _nil) { + if (!is_nil(_cdr)) { log('|| next 1'); next(_name7, _cdr); } - if (is_array && _rest_expr.length || _rest_expr !== _nil && !is_array) { + if (is_array && _rest_expr.length || !is_nil(_rest_expr) && !is_array) { var _rest7 = transform_ellipsis_expr(_rest_expr, bindings, state, next); if (is_array) { return _car.concat(_rest7); @@ -9997,13 +9997,13 @@ function transform_syntax() { } } return _car; - } else if (_car instanceof Pair) { - if (_car.cdr !== _nil) { + } else if (is_pair(_car)) { + if (!is_nil(_car.cdr)) { log('|| next 2'); next(_name7, new Pair(_car.cdr, _cdr)); } return _car.car; - } else if (_cdr === _nil) { + } else if (is_nil(_cdr)) { return _car; } else { var last_pair = expr.last_pair(); @@ -10057,7 +10057,7 @@ function transform_syntax() { if (x === null) { return !skip_nulls; } - return x instanceof Pair || x === _nil || x instanceof Array && x.length; + return is_pair(x) || is_nil(x) || Array.isArray(x) && x.length; }); } function get_names(object) { @@ -10072,7 +10072,7 @@ function transform_syntax() { if (is_array && expr.length === 0) { return expr; } - if (expr instanceof Pair || is_array) { + if (is_pair(expr) || is_array) { var first = is_array ? expr[0] : expr.car; var second, rest_second; if (is_array) { @@ -10120,7 +10120,7 @@ function transform_syntax() { // lists is free ellipsis on pairs ((???) ...) // TODO: will this work in every case? Do we need to handle // nesting here? - if (bindings['...'].lists[0] === _nil) { + if (is_nil(bindings['...'].lists[0])) { if (!is_spread) { return traverse(rest_second, { disabled: disabled @@ -10168,7 +10168,7 @@ function transform_syntax() { log('ZONK {1}'); } } else { - if (result === _nil) { + if (is_nil(result)) { result = car; } else { result = result.append(car); @@ -10185,7 +10185,7 @@ function transform_syntax() { while (true) { if (_loop()) break; } - if (result !== _nil && !is_spread && !is_array) { + if (!is_nil(result) && !is_spread && !is_array) { result = result.reverse(); } // case of (list) ... (rest code) @@ -10202,7 +10202,7 @@ function transform_syntax() { } return result; } - if (expr.cdr.cdr !== _nil && !LSymbol.is(expr.cdr.cdr.car, ellipsis_symbol)) { + if (!is_nil(expr.cdr.cdr) && !LSymbol.is(expr.cdr.cdr.car, ellipsis_symbol)) { var _rest10 = traverse(expr.cdr.cdr, { disabled: disabled }); @@ -10264,14 +10264,14 @@ function transform_syntax() { while (true) { if (_loop2()) break; } - if (_result3 !== _nil && !is_array) { + if (!is_nil(_result3) && !is_array) { _result3 = _result3.reverse(); } // case if (x ... y ...) second spread is not processed // and (??? . x) last symbol // by ellipsis transformation - if (expr.cdr instanceof Pair) { - if (expr.cdr.cdr instanceof Pair || expr.cdr.cdr instanceof LSymbol) { + if (is_pair(expr.cdr)) { + if (is_pair(expr.cdr.cdr) || expr.cdr.cdr instanceof LSymbol) { var node = traverse(expr.cdr.cdr, { disabled: disabled }); @@ -10281,7 +10281,7 @@ function transform_syntax() { if (_is_null) { return node; } - if (_result3 === _nil) { + if (is_nil(_result3)) { _result3 = node; } else { _result3.append(node); @@ -10357,7 +10357,11 @@ function transform_syntax() { // :: Check for nullish values // ---------------------------------------------------------------------- function is_null(value) { - return is_undef(value) || value === _nil || value === null; + return is_undef(value) || is_nil(value) || value === null; +} +// ---------------------------------------------------------------------- +function is_nil(value) { + return value === _nil; } // ---------------------------------------------------------------------- function is_function(o) { @@ -10495,7 +10499,7 @@ function unbox(object) { } // ---------------------------------------------------------------------- function patch_value(value, context) { - if (value instanceof Pair) { + if (is_pair(value)) { value.markCycles(); return quote(value); } @@ -10688,11 +10692,11 @@ function let_macro(symbol) { // named let: // (let iter ((x 10)) (iter (- x 1))) -> (let* ((iter (lambda (x) ... if (code.car instanceof LSymbol) { - if (!(code.cdr.car instanceof Pair || code.cdr.car === _nil)) { + if (!(is_pair(code.cdr.car) || is_nil(code.cdr.car))) { throw new Error('let require list of pairs'); } var params; - if (code.cdr.car === _nil) { + if (is_nil(code.cdr.car)) { args = _nil; params = _nil; } else { @@ -10804,7 +10808,7 @@ function parallel(name, fn) { var dynamic_env = this; var results = []; var node = code; - while (node instanceof Pair) { + while (is_pair(node)) { results.push(_evaluate(node.car, { env: env, dynamic_env: dynamic_env, @@ -13497,7 +13501,7 @@ function quote(value) { if (is_promise(value)) { return value.then(quote); } - if (value instanceof Pair || value instanceof LSymbol) { + if (is_pair(value) || value instanceof LSymbol) { value[__data__] = true; } return value; @@ -13704,7 +13708,7 @@ var global_env = new Environment({ }(), "(read [string])\n\n This function, if used with a string, will parse it and\n return the LIPS code, if there is any. If called with a\n port, it will parse the next item from the port. If called\n without an input, it will read a string from standard input\n (using the browser's prompt or a user defined input method)\n and calls itself with that string. This function can be used\n together with `eval` to evaluate code from a string."), // ------------------------------------------------------------------ pprint: doc('pprint', function pprint(arg) { - if (arg instanceof Pair) { + if (is_pair(arg)) { arg = new lips.Formatter(arg.toString(true))["break"]().format(); global_env.get('display').call(global_env, arg); } else { @@ -13812,7 +13816,7 @@ var global_env = new Environment({ var symbol; if (code.car instanceof LSymbol) { symbol = code.car; - } else if (code.car instanceof Pair && code.car.car instanceof LSymbol) { + } else if (is_pair(code.car) && code.car.car instanceof LSymbol) { symbol = code.car.car; } else { var env = this; @@ -13891,7 +13895,7 @@ var global_env = new Environment({ env.get('set-obj!').call(env, object, key, value); return value; } - if (code.car instanceof Pair && LSymbol.is(code.car.car, '.')) { + if (is_pair(code.car) && LSymbol.is(code.car.car, '.')) { var second = code.car.cdr.car; var third = code.car.cdr.cdr.car; var object = _evaluate(second, eval_args); @@ -13948,7 +13952,7 @@ var global_env = new Environment({ }, "(set-cdr! obj value)\n\n Function that sets the cdr (tail) of the list/pair to specified value.\n It will destroy the list. The old tail is lost."), // ------------------------------------------------------------------ 'empty?': doc('empty?', function (x) { - return typeof x === 'undefined' || x === _nil; + return typeof x === 'undefined' || is_nil(x); }, "(empty? object)\n\n Function that returns #t if value is nil (an empty list) or undefined."), // ------------------------------------------------------------------ gensym: doc('gensym', gensym, "(gensym)\n\n Generates a unique symbol that is not bound anywhere,\n to use with macros as meta name."), @@ -14033,7 +14037,7 @@ var global_env = new Environment({ case 10: _args19 = _context17.sent; case 11: - if (_args19 && _args19 !== _nil) { + if (_args19 && !is_nil(_args19)) { process.cwd(); file = path.join(path.dirname(_args19.car.valueOf()), file); } @@ -14108,7 +14112,7 @@ var global_env = new Environment({ vars = code.car; test = code.cdr.car; body = code.cdr.cdr; - if (body !== _nil) { + if (!is_nil(body)) { body = new Pair(LSymbol('begin'), body); } eval_args = { @@ -14119,7 +14123,7 @@ var global_env = new Environment({ }; node = vars; case 9: - if (!(node !== _nil)) { + if (is_nil(node)) { _context19.next = 20; break; } @@ -14145,7 +14149,7 @@ var global_env = new Environment({ return _regeneratorRuntime.wrap(function _loop3$(_context18) { while (1) switch (_context18.prev = _context18.next) { case 0: - if (!(body !== _nil)) { + if (is_nil(body)) { _context18.next = 3; break; } @@ -14155,12 +14159,12 @@ var global_env = new Environment({ node = vars; next = {}; case 5: - if (!(node !== _nil)) { + if (is_nil(node)) { _context18.next = 15; break; } _item = node.car; - if (!(_item.cdr.cdr !== _nil)) { + if (is_nil(_item.cdr.cdr)) { _context18.next = 12; break; } @@ -14198,7 +14202,7 @@ var global_env = new Environment({ _context19.next = 22; break; case 29: - if (!(test.cdr !== _nil)) { + if (is_nil(test.cdr)) { _context19.next = 33; break; } @@ -14236,7 +14240,7 @@ var global_env = new Environment({ return _evaluate(code.cdr.car, eval_args); } }; - if (code === _nil) { + if (is_nil(code)) { throw new Error('too few expressions for `if`'); } var cond = _evaluate(code.car, eval_args); @@ -14280,7 +14284,7 @@ var global_env = new Environment({ shuffle: doc('shuffle', function (arg) { typecheck('shuffle', arg, ['pair', 'nil', 'array']); var random = global_env.get('random'); - if (arg === _nil) { + if (is_nil(arg)) { return _nil; } if (Array.isArray(arg)) { @@ -14373,7 +14377,7 @@ var global_env = new Environment({ eval_args.dynamic_env; var init = _evaluate(code.car, eval_args); var fn; - if (code.cdr.car instanceof Pair) { + if (is_pair(code.cdr.car)) { fn = _evaluate(code.cdr.car, eval_args); } return new Parameter(init, fn); @@ -14394,7 +14398,7 @@ var global_env = new Environment({ syntax.__name__ = syntax.__name__.valueOf(); } var __doc__; - if (code.cdr.cdr instanceof Pair && LString.isString(code.cdr.cdr.car)) { + if (is_pair(code.cdr.cdr) && LString.isString(code.cdr.cdr.car)) { __doc__ = code.cdr.cdr.car.valueOf(); } env.set(code.car, new SyntaxParameter(syntax), __doc__, true); @@ -14441,7 +14445,7 @@ var global_env = new Environment({ // ------------------------------------------------------------------ define: doc(Macro.defmacro('define', function (code, eval_args) { var env = this; - if (code.car instanceof Pair && code.car.car instanceof LSymbol) { + if (is_pair(code.car) && code.car.car instanceof LSymbol) { var new_code = new Pair(new LSymbol("define"), new Pair(code.car.car, new Pair(new Pair(new LSymbol("lambda"), new Pair(code.car.cdr, code.cdr))))); return new_code; } else if (eval_args.macro_expand) { @@ -14452,7 +14456,7 @@ var global_env = new Environment({ eval_args.env = env; var value = code.cdr.car; var new_expr; - if (value instanceof Pair) { + if (is_pair(value)) { value = _evaluate(value, eval_args); new_expr = true; } else if (value instanceof LSymbol) { @@ -14470,7 +14474,7 @@ var global_env = new Environment({ } } var __doc__; - if (code.cdr.cdr instanceof Pair && LString.isString(code.cdr.cdr.car)) { + if (is_pair(code.cdr.cdr) && LString.isString(code.cdr.cdr.car)) { __doc__ = code.cdr.cdr.car.valueOf(); } env.set(code.car, value, __doc__, true); @@ -14492,7 +14496,7 @@ var global_env = new Environment({ } else if (is_prototype(obj) && is_function(value)) { obj[key] = unbind(value); obj[key][__prototype__] = true; - } else if (is_function(value) || is_native(value) || value === _nil) { + } else if (is_function(value) || is_native(value) || is_nil(value)) { obj[key] = value; } else { obj[key] = value && !is_prototype(value) ? value.valueOf() : value; @@ -14562,7 +14566,7 @@ var global_env = new Environment({ error = _ref34.error; var self = this; var __doc__; - if (code.cdr instanceof Pair && LString.isString(code.cdr.car) && code.cdr.cdr !== _nil) { + if (is_pair(code.cdr) && LString.isString(code.cdr.car) && !is_nil(code.cdr.cdr)) { __doc__ = code.cdr.car.valueOf(); } function lambda() { @@ -14609,9 +14613,9 @@ var global_env = new Environment({ } var name = code.car; var i = 0; - if (name instanceof LSymbol || name !== _nil) { + if (name instanceof LSymbol || !is_nil(name)) { while (true) { - if (name.car !== _nil) { + if (!is_nil(name.car)) { if (name instanceof LSymbol) { // rest argument, can also be first argument var value = quote(Pair.fromArray(args.slice(i), false)); @@ -14622,7 +14626,7 @@ var global_env = new Environment({ set(name.car, _value6); } } - if (name.cdr === _nil) { + if (is_nil(name.cdr)) { break; } i++; @@ -14639,10 +14643,10 @@ var global_env = new Environment({ }; return _evaluate(output, eval_args); } - var length = code.car instanceof Pair ? code.car.length() : null; + var length = is_pair(code.car) ? code.car.length() : null; lambda.__code__ = new Pair(new LSymbol('lambda'), code); lambda[__lambda__] = true; - if (!(code.car instanceof Pair)) { + if (!is_pair(code.car)) { return doc(lambda, __doc__, true); // variable arguments } // wrap and decorate with __doc__ @@ -14654,10 +14658,10 @@ var global_env = new Environment({ 'define-macro': doc(new Macro(macro, function (macro, _ref36) { var use_dynamic = _ref36.use_dynamic, error = _ref36.error; - if (macro.car instanceof Pair && macro.car.car instanceof LSymbol) { + if (is_pair(macro.car) && macro.car.car instanceof LSymbol) { var name = macro.car.car.__name__; var __doc__; - if (LString.isString(macro.cdr.car) && macro.cdr.cdr instanceof Pair) { + if (LString.isString(macro.cdr.car) && is_pair(macro.cdr.cdr)) { __doc__ = macro.cdr.car.valueOf(); } var makro_instance = Macro.defmacro(name, function (code) { @@ -14665,26 +14669,26 @@ var global_env = new Environment({ var name = macro.car.cdr; var arg = code; while (true) { - if (name === _nil) { + if (is_nil(name)) { break; } if (name instanceof LSymbol) { env.__env__[name.__name__] = arg; break; - } else if (name.car !== _nil) { - if (arg === _nil) { + } else if (!is_nil(name.car)) { + if (is_nil(arg)) { env.__env__[name.car.__name__] = _nil; } else { - if (arg.car instanceof Pair) { + if (is_pair(arg.car)) { arg.car[__data__] = true; } env.__env__[name.car.__name__] = arg.car; } } - if (name.cdr === _nil) { + if (is_nil(name.cdr)) { break; } - if (arg !== _nil) { + if (!is_nil(arg)) { arg = arg.cdr; } name = name.cdr; @@ -14696,7 +14700,7 @@ var global_env = new Environment({ error: error }; // evaluate macro - if (macro.cdr instanceof Pair) { + if (is_pair(macro.cdr)) { // this eval will return lips code var rest = __doc__ ? macro.cdr.cdr : macro.cdr; var result = rest.reduce(function (result, node) { @@ -14722,7 +14726,7 @@ var global_env = new Environment({ var env = this; function get_identifiers(node) { var symbols = []; - while (node !== _nil) { + while (!is_nil(node)) { var x = node.car; symbols.push(x.valueOf()); node = node.cdr; @@ -14730,7 +14734,7 @@ var global_env = new Environment({ return symbols; } function validate_identifiers(node) { - while (node !== _nil) { + while (!is_nil(node)) { var x = node.car; if (!(x instanceof LSymbol)) { throw new Error('syntax-rules: wrong identifier'); @@ -14777,7 +14781,7 @@ var global_env = new Environment({ rules = macro.cdr; } try { - while (rules !== _nil) { + while (!is_nil(rules)) { var rule = rules.car.car; var expr = rules.car.cdr.car; log('[[[ RULE'); @@ -14855,12 +14859,12 @@ var global_env = new Environment({ var dynamic_env = self; // ----------------------------------------------------------------- function is_struct(value) { - return value instanceof Pair || is_plain_object(value) || Array.isArray(value); + return is_pair(value) || is_plain_object(value) || Array.isArray(value); } // ----------------------------------------------------------------- function resolve_pair(pair, fn) { var test = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : is_struct; - if (pair instanceof Pair) { + if (is_pair(pair)) { var car = pair.car; var cdr = pair.cdr; if (test(car)) { @@ -14884,8 +14888,8 @@ var global_env = new Environment({ } // ----------------------------------------------------------------- function join(eval_pair, value) { - if (eval_pair instanceof Pair) { - if (value !== _nil) { + if (is_pair(eval_pair)) { + if (!is_nil(value)) { eval_pair.append(value); } } else { @@ -14896,13 +14900,13 @@ var global_env = new Environment({ // ----------------------------------------------------------------- function unquoted_arr(arr) { return !!arr.filter(function (value) { - return value instanceof Pair && LSymbol.is(value.car, /^(unquote|unquote-splicing)$/); + return is_pair(value) && LSymbol.is(value.car, /^(unquote|unquote-splicing)$/); }).length; } // ----------------------------------------------------------------- function quote_vector(arr, unquote_cnt, max_unq) { return arr.reduce(function (acc, x) { - if (!(x instanceof Pair)) { + if (!is_pair(x)) { acc.push(x); return acc; } @@ -14918,7 +14922,7 @@ var global_env = new Environment({ error: error }); } - if (!(result instanceof Pair)) { + if (!is_pair(result)) { throw new Error("Expecting list ".concat(type(x), " found")); } return acc.concat(result.to_array()); @@ -14933,7 +14937,7 @@ var global_env = new Environment({ unquote_cnt++; Object.keys(object).forEach(function (key) { var value = object[key]; - if (value instanceof Pair) { + if (is_pair(value)) { if (LSymbol.is(value.car, 'unquote-splicing')) { throw new Error("You can't call `unquote-splicing` " + "inside object"); } @@ -14972,17 +14976,17 @@ var global_env = new Environment({ error: error }); lists.push(value); - if (node.cdr instanceof Pair) { + if (is_pair(node.cdr)) { return next(node.cdr); } return unpromise(lists, function (arr) { if (arr.some(function (x) { - return !(x instanceof Pair); + return !is_pair(x); })) { - if (pair.cdr instanceof Pair && LSymbol.is(pair.cdr.car, '.') && pair.cdr.cdr instanceof Pair && pair.cdr.cdr.cdr === _nil) { + if (is_pair(pair.cdr) && LSymbol.is(pair.cdr.car, '.') && is_pair(pair.cdr.cdr) && is_nil(pair.cdr.cdr.cdr)) { return pair.cdr.cdr.car; } - if (!(pair.cdr === _nil || pair.cdr instanceof Pair)) { + if (!(is_nil(pair.cdr) || is_pair(pair.cdr))) { var msg = "You can't splice atom inside list"; throw new Error(msg); } @@ -14990,7 +14994,7 @@ var global_env = new Environment({ var _msg = "You can't splice multiple atoms inside list"; throw new Error(_msg); } - if (!(pair.cdr instanceof Pair && arr[0] === _nil)) { + if (!(is_pair(pair.cdr) && is_nil(arr[0]))) { return arr[0]; } } @@ -15004,11 +15008,11 @@ var global_env = new Environment({ } }); var value = recur(pair.cdr, 0, 1); - if (value === _nil && arr[0] === _nil) { + if (is_nil(value) && is_nil(arr[0])) { return undefined; } return unpromise(value, function (value) { - if (arr[0] === _nil) { + if (is_nil(arr[0])) { return value; } if (arr.length === 1) { @@ -15025,22 +15029,22 @@ var global_env = new Environment({ // ----------------------------------------------------------------- var splices = new Set(); function recur(pair, unquote_cnt, max_unq) { - if (pair instanceof Pair) { - if (pair.car instanceof Pair) { + if (is_pair(pair)) { + if (is_pair(pair.car)) { if (LSymbol.is(pair.car.car, 'unquote-splicing')) { return unquote_splice(pair, unquote_cnt + 1, max_unq); } if (LSymbol.is(pair.car.car, 'unquote')) { // + 2 - one for unquote and one for unquote splicing - if (unquote_cnt + 2 === max_unq && pair.car.cdr instanceof Pair && pair.car.cdr.car instanceof Pair && LSymbol.is(pair.car.cdr.car.car, 'unquote-splicing')) { + if (unquote_cnt + 2 === max_unq && is_pair(pair.car.cdr) && is_pair(pair.car.cdr.car) && LSymbol.is(pair.car.cdr.car.car, 'unquote-splicing')) { var rest = pair.car.cdr; return new Pair(new Pair(new LSymbol('unquote'), unquote_splice(rest, unquote_cnt + 2, max_unq)), _nil); - } else if (pair.car.cdr instanceof Pair && pair.car.cdr.cdr !== _nil) { - if (pair.car.cdr.car instanceof Pair) { + } else if (is_pair(pair.car.cdr) && !is_nil(pair.car.cdr.cdr)) { + if (is_pair(pair.car.cdr.car)) { // values inside unquote are lists var result = []; return function recur(node) { - if (node === _nil) { + if (is_nil(node)) { return Pair.fromArray(result); } return unpromise(_evaluate(node.car, { @@ -15077,9 +15081,9 @@ var global_env = new Environment({ if (unquote_cnt > max_unq) { throw new Error("You can't call `unquote` outside " + "of quasiquote"); } - if (pair.cdr instanceof Pair) { - if (pair.cdr.cdr !== _nil) { - if (pair.cdr.car instanceof Pair) { + if (is_pair(pair.cdr)) { + if (!is_nil(pair.cdr.cdr)) { + if (is_pair(pair.cdr.car)) { // TODO: test if this part is needed // this part was duplicated in previous section // if (LSymbol.is(pair.car.car, 'unquote')) { @@ -15087,7 +15091,7 @@ var global_env = new Environment({ var _result4 = []; // evaluate all values in unquote return function recur(node) { - if (node === _nil) { + if (is_nil(node)) { return Pair.fromArray(_result4); } return unpromise(_evaluate(node.car, { @@ -15126,7 +15130,7 @@ var global_env = new Environment({ } // ----------------------------------------------------------------- function clear(node) { - if (node instanceof Pair) { + if (is_pair(node)) { delete node[__data__]; if (!node.haveCycles('car')) { clear(node.car); @@ -15143,7 +15147,7 @@ var global_env = new Environment({ if (Array.isArray(arg.car) && !unquoted_arr(arg.car)) { return quote(arg.car); } - if (arg.car instanceof Pair && !arg.car.find('unquote') && !arg.car.find('unquote-splicing') && !arg.car.find('quasiquote')) { + if (is_pair(arg.car) && !arg.car.find('unquote') && !arg.car.find('unquote-splicing') && !arg.car.find('quasiquote')) { return quote(arg.car); } var x = recur(arg.car, 0, 1); @@ -15165,7 +15169,7 @@ var global_env = new Environment({ items[_key25] = arguments[_key25]; } items = items.map(function (item) { - if (item instanceof Pair) { + if (is_pair(item)) { return item.clone(); } return item; @@ -15180,11 +15184,11 @@ var global_env = new Environment({ } return items.reduce(function (acc, item) { typecheck('append!', acc, ['nil', 'pair']); - if ((item instanceof Pair || item === _nil) && !is_list(item)) { + if ((is_pair(item) || is_nil(item)) && !is_list(item)) { throw new Error('append!: Invalid argument, value is not a list'); } - if (acc === _nil) { - if (item === _nil) { + if (is_nil(acc)) { + if (is_nil(item)) { return _nil; } return item; @@ -15198,10 +15202,10 @@ var global_env = new Environment({ // ------------------------------------------------------------------ reverse: doc('reverse', function reverse(arg) { typecheck('reverse', arg, ['array', 'pair', 'nil']); - if (arg === _nil) { + if (is_nil(arg)) { return _nil; } - if (arg instanceof Pair) { + if (is_pair(arg)) { var arr = global_env.get('list->array')(arg).reverse(); return global_env.get('array->list')(arr); } else if (Array.isArray(arg)) { @@ -15214,11 +15218,11 @@ var global_env = new Environment({ nth: doc('nth', function nth(index, obj) { typecheck('nth', index, 'number'); typecheck('nth', obj, ['array', 'pair']); - if (obj instanceof Pair) { + if (is_pair(obj)) { var node = obj; var count = 0; while (count < index) { - if (!node.cdr || node.cdr === _nil || node.haveCycles('cdr')) { + if (!node.cdr || is_nil(node.cdr) || node.haveCycles('cdr')) { return _nil; } node = node.cdr; @@ -15396,9 +15400,7 @@ var global_env = new Environment({ return LString.isString(obj); }, "(string? expression)\n\n Predicate that tests if value is a string."), // ------------------------------------------------------------------ - 'pair?': doc('pair?', function (obj) { - return obj instanceof Pair; - }, "(pair? expression)\n\n Predicate that tests if value is a pair or list structure."), + 'pair?': doc('pair?', is_pair, "(pair? expression)\n\n Predicate that tests if value is a pair or list structure."), // ------------------------------------------------------------------ 'regex?': doc('regex?', function (obj) { return obj instanceof RegExp; @@ -15421,7 +15423,7 @@ var global_env = new Environment({ }, "(array? expression)\n\n Predicate that tests if value is an array."), // ------------------------------------------------------------------ 'object?': doc('object?', function (obj) { - return obj !== _nil && obj !== null && !(obj instanceof LCharacter) && !(obj instanceof RegExp) && !(obj instanceof LString) && !(obj instanceof Pair) && !(obj instanceof LNumber) && _typeof$1(obj) === 'object' && !(obj instanceof Array); + return !is_nil(obj) && obj !== null && !(obj instanceof LCharacter) && !(obj instanceof RegExp) && !(obj instanceof LString) && !is_pair(obj) && !(obj instanceof LNumber) && _typeof$1(obj) === 'object' && !(obj instanceof Array); }, "(object? expression)\n\n Predicate that tests if value is an plain object (not another LIPS type)."), // ------------------------------------------------------------------ flatten: doc('flatten', function flatten(list) { @@ -15450,10 +15452,10 @@ var global_env = new Environment({ }, "(apply fn list)\n\n Function that calls fn with the list of arguments."), // ------------------------------------------------------------------ length: doc('length', function length(obj) { - if (!obj || obj === _nil) { + if (!obj || is_nil(obj)) { return 0; } - if (obj instanceof Pair) { + if (is_pair(obj)) { return obj.length(); } if ("length" in obj) { @@ -15491,7 +15493,7 @@ var global_env = new Environment({ var catch_clause, finally_clause; if (LSymbol.is(code.cdr.car.car, 'catch')) { catch_clause = code.cdr.car; - if (code.cdr.cdr instanceof Pair && LSymbol.is(code.cdr.cdr.car.car, 'finally')) { + if (is_pair(code.cdr.cdr) && LSymbol.is(code.cdr.cdr.car.car, 'finally')) { finally_clause = code.cdr.cdr.car; } } else if (LSymbol.is(code.cdr.car.car, 'finally')) { @@ -15580,7 +15582,7 @@ var global_env = new Environment({ } var fn = matcher('find', arg); return unpromise(fn(list.car), function (value) { - if (value && value !== _nil) { + if (value && !is_nil(value)) { return list.car; } return find(arg, list.cdr); @@ -15615,16 +15617,14 @@ var global_env = new Environment({ lists.forEach(function (arg, i) { typecheck('map', arg, ['pair', 'nil'], i + 1); // detect cycles - if (arg instanceof Pair && !is_list.call(_this27, arg)) { + if (is_pair(arg) && !is_list.call(_this27, arg)) { throw new Error("map: argument ".concat(i + 1, " is not a list")); } }); if (lists.length === 0) { return _nil; } - if (lists.some(function (x) { - return x === _nil; - })) { + if (lists.some(is_nil)) { return _nil; } var args = lists.map(function (l) { @@ -15650,10 +15650,10 @@ var global_env = new Environment({ 'list?': doc('list?', function (obj) { var node = obj; while (true) { - if (node === _nil) { + if (is_nil(node)) { return true; } - if (!(node instanceof Pair)) { + if (!is_pair(node)) { return false; } if (node.haveCycles('cdr')) { @@ -15683,9 +15683,7 @@ var global_env = new Environment({ lists.forEach(function (arg, i) { typecheck('fold', arg, ['pair', 'nil'], i + 1); }); - if (lists.some(function (x) { - return x === _nil; - })) { + if (lists.some(is_nil)) { return init; } var value = fold.call.apply(fold, [this, fn, init].concat(_toConsumableArray(lists.map(function (l) { @@ -15731,9 +15729,7 @@ var global_env = new Environment({ lists.forEach(function (arg, i) { typecheck('reduce', arg, ['pair', 'nil'], i + 1); }); - if (lists.some(function (x) { - return x === _nil; - })) { + if (lists.some(is_nil)) { return init; } return unpromise(fn.apply(void 0, _toConsumableArray(lists.map(function (l) { @@ -15753,7 +15749,7 @@ var global_env = new Environment({ var fn = matcher('filter', arg); return function loop(i) { function next(value) { - if (value && value !== _nil) { + if (value && !is_nil(value)) { result.push(item); } return loop(++i); @@ -16276,7 +16272,7 @@ function typecheck_number(fn, arg, expected) { typecheck(fn, arg, 'number', position); var arg_type = arg.__type__; var match; - if (expected instanceof Pair) { + if (is_pair(expected)) { expected = expected.to_array(); } if (expected instanceof Array) { @@ -16331,7 +16327,7 @@ function typecheck(fn, arg, expected) { return; } var match = false; - if (expected instanceof Pair) { + if (is_pair(expected)) { expected = expected.to_array(); } if (expected instanceof Array) { @@ -16424,7 +16420,7 @@ function resolve_promises(arg) { function traverse(node) { if (is_promise(node)) { promises.push(node); - } else if (node instanceof Pair) { + } else if (is_pair(node)) { if (!node.haveCycles('car')) { traverse(node.car); } @@ -16490,7 +16486,7 @@ function resolve_promises(arg) { if (node instanceof Array) { return promise_all(node.map(resolve)); } - if (node instanceof Pair && promises.length) { + if (is_pair(node) && promises.length) { return promise(node); } return node; @@ -16507,7 +16503,7 @@ function evaluate_args(rest, _ref43) { return args; } return function loop() { - if (node instanceof Pair) { + if (is_pair(node)) { var arg = _evaluate(node.car, _objectSpread({ use_dynamic: use_dynamic }, options)); @@ -16528,7 +16524,7 @@ function evaluate_args(rest, _ref43) { node = node.cdr; return loop(); }); - } else if (node === _nil) { + } else if (is_nil(node)) { return next(); } else { throw new Error('Syntax Error: improper list found in apply'); @@ -16539,7 +16535,7 @@ function evaluate_args(rest, _ref43) { function evaluate_syntax(macro, code, eval_args) { var value = macro.invoke(code, eval_args); return unpromise(resolve_promises(value), function (value) { - if (value instanceof Pair) { + if (is_pair(value)) { value.markCycles(); } return quote(value); @@ -16548,7 +16544,7 @@ function evaluate_syntax(macro, code, eval_args) { // ------------------------------------------------------------------------- function evaluate_macro(macro, code, eval_args) { function finalize(result) { - if (result instanceof Pair) { + if (is_pair(result)) { result.markCycles(); return result; } @@ -16650,7 +16646,7 @@ function apply(fn, args) { use_dynamic: use_dynamic }); return unpromise(result, function (result) { - if (result instanceof Pair) { + if (is_pair(result)) { result.markCycles(); return quote(result); } @@ -16816,12 +16812,12 @@ function _evaluate(code) { if (code instanceof LSymbol) { return env.get(code); } - if (!(code instanceof Pair)) { + if (!is_pair(code)) { return code; } var first = code.car; var rest = code.cdr; - if (first instanceof Pair) { + if (is_pair(first)) { value = resolve_promises(_evaluate(first, eval_args)); if (is_promise(value)) { return value.then(function (value) { @@ -16860,7 +16856,7 @@ function _evaluate(code) { } } else if (is_continuation(value)) { result = value.invoke(); - } else if (code instanceof Pair) { + } else if (is_pair(code)) { value = first && first.toString(); throw new Error("".concat(type(first), " ").concat(value, " is not a function")); } else { @@ -16875,7 +16871,7 @@ function _evaluate(code) { // When promise is not quoted it happen automatically, when returning // promise from evaluate. result = result.then(function (result) { - if (result instanceof Pair && !value[__data__]) { + if (is_pair(result) && !value[__data__]) { return _evaluate(result, eval_args); } return result; @@ -17561,10 +17557,10 @@ if (typeof window !== 'undefined') { // ------------------------------------------------------------------------- var banner = function () { // Rollup tree-shaking is removing the variable if it's normal string because - // obviously 'Mon, 12 Feb 2024 12:58:05 +0000' == '{{' + 'DATE}}'; can be removed + // obviously 'Mon, 12 Feb 2024 14:25:33 +0000' == '{{' + 'DATE}}'; can be removed // but disabling Tree-shaking is adding lot of not used code so we use this // hack instead - var date = LString('Mon, 12 Feb 2024 12:58:05 +0000').valueOf(); + var date = LString('Mon, 12 Feb 2024 14:25:33 +0000').valueOf(); var _date = date === '{{' + 'DATE}}' ? new Date() : new Date(date); var _format = function _format(x) { return x.toString().padStart(2, '0'); @@ -17604,7 +17600,7 @@ read_only(QuotedPromise, '__class__', 'promise'); read_only(Parameter, '__class__', 'parameter'); // ------------------------------------------------------------------------- var version = 'DEV'; -var date = 'Mon, 12 Feb 2024 12:58:05 +0000'; +var date = 'Mon, 12 Feb 2024 14:25:33 +0000'; // unwrap async generator into Promise var parse = compose(uniterate_async, _parse); diff --git a/dist/lips.esm.min.js b/dist/lips.esm.min.js index 5a18156ca..8cc007e51 100644 --- a/dist/lips.esm.min.js +++ b/dist/lips.esm.min.js @@ -31,9 +31,9 @@ * Copyright (c) 2014-present, Facebook, Inc. * released under MIT license * - * build: Mon, 12 Feb 2024 12:58:05 +0000 + * build: Mon, 12 Feb 2024 14:25:33 +0000 */ -function _classApplyDescriptorGet(e,t){if(t.get){return t.get.call(e)}return t.value}function _classExtractFieldDescriptor(e,t,r){if(!t.has(e)){throw new TypeError("attempted to "+r+" private field on non-instance")}return t.get(e)}function _classPrivateFieldGet(e,t){var r=_classExtractFieldDescriptor(e,t,"get");return _classApplyDescriptorGet(e,r)}function _classApplyDescriptorSet(e,t,r){if(t.set){t.set.call(e,r)}else{if(!t.writable){throw new TypeError("attempted to set read only private field")}t.value=r}}function _classPrivateFieldSet(e,t,r){var n=_classExtractFieldDescriptor(e,t,"set");_classApplyDescriptorSet(e,n,r);return r}function _getPrototypeOf(e){_getPrototypeOf=Object.setPrototypeOf?Object.getPrototypeOf.bind():function e(t){return t.__proto__||Object.getPrototypeOf(t)};return _getPrototypeOf(e)}function _setPrototypeOf(e,t){_setPrototypeOf=Object.setPrototypeOf?Object.setPrototypeOf.bind():function e(t,r){t.__proto__=r;return t};return _setPrototypeOf(e,t)}function _isNativeFunction(t){try{return Function.toString.call(t).indexOf("[native code]")!==-1}catch(e){return typeof t==="function"}}function _isNativeReflectConstruct$1(){try{var t=!Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){}))}catch(t){}return(_isNativeReflectConstruct$1=function e(){return!!t})()}function _construct(e,t,r){if(_isNativeReflectConstruct$1())return Reflect.construct.apply(null,arguments);var n=[null];n.push.apply(n,t);var i=new(e.bind.apply(e,n));return r&&_setPrototypeOf(i,r.prototype),i}function _wrapNativeSuper(e){var n=typeof Map==="function"?new Map:undefined;_wrapNativeSuper=function e(t){if(t===null||!_isNativeFunction(t))return t;if(typeof t!=="function"){throw new TypeError("Super expression must either be null or a function")}if(typeof n!=="undefined"){if(n.has(t))return n.get(t);n.set(t,r)}function r(){return _construct(t,arguments,_getPrototypeOf(this).constructor)}r.prototype=Object.create(t.prototype,{constructor:{value:r,enumerable:false,writable:true,configurable:true}});return _setPrototypeOf(r,t)};return _wrapNativeSuper(e)}function _typeof$1(e){"@babel/helpers - typeof";return _typeof$1="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},_typeof$1(e)}function _assertThisInitialized(e){if(e===void 0){throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}return e}function _possibleConstructorReturn(e,t){if(t&&(_typeof$1(t)==="object"||typeof t==="function")){return t}else if(t!==void 0){throw new TypeError("Derived constructors may only return object or undefined")}return _assertThisInitialized(e)}function _inherits(e,t){if(typeof t!=="function"&&t!==null){throw new TypeError("Super expression must either be null or a function")}e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,writable:true,configurable:true}});Object.defineProperty(e,"prototype",{writable:false});if(t)_setPrototypeOf(e,t)}function _arrayWithHoles(e){if(Array.isArray(e))return e}function _iterableToArray(e){if(typeof Symbol!=="undefined"&&e[Symbol.iterator]!=null||e["@@iterator"]!=null)return Array.from(e)}function _arrayLikeToArray$1(e,t){if(t==null||t>e.length)t=e.length;for(var r=0,n=new Array(t);r=0)continue;r[i]=e[i]}return r}function _objectWithoutProperties(e,t){if(e==null)return{};var r=_objectWithoutPropertiesLoose(e,t);var n,i;if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(i=0;i=0)continue;if(!Object.prototype.propertyIsEnumerable.call(e,n))continue;r[n]=e[n]}}return r}function _iterableToArrayLimit(e,t){var r=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=r){var n,i,a,o,u=[],s=!0,c=!1;try{if(a=(r=r.call(e)).next,0===t){if(Object(r)!==r)return;s=!1}else for(;!(s=(n=a.call(r)).done)&&(u.push(n.value),u.length!==t);s=!0);}catch(e){c=!0,i=e}finally{try{if(!s&&null!=r["return"]&&(o=r["return"](),Object(o)!==o))return}finally{if(c)throw i}}return u}}function _slicedToArray(e,t){return _arrayWithHoles(e)||_iterableToArrayLimit(e,t)||_unsupportedIterableToArray$1(e,t)||_nonIterableRest()}function _arrayWithoutHoles(e){if(Array.isArray(e))return _arrayLikeToArray$1(e)}function _nonIterableSpread(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function _toConsumableArray(e){return _arrayWithoutHoles(e)||_iterableToArray(e)||_unsupportedIterableToArray$1(e)||_nonIterableSpread()}function _OverloadYield(e,t){this.v=e,this.k=t}function _awaitAsyncGenerator(e){return new _OverloadYield(e,0)}function AsyncGenerator(o){var a,u;function s(r,e){try{var n=o[r](e),i=n.value,a=i instanceof _OverloadYield;Promise.resolve(a?i.v:i).then(function(e){if(a){var t="return"===r?"return":"next";if(!i.k||e.done)return s(t,e);e=o[t](e).value}c(n.done?"return":"normal",e)},function(e){s("throw",e)})}catch(e){c("throw",e)}}function c(e,t){switch(e){case"return":a.resolve({value:t,done:!0});break;case"throw":a.reject(t);break;default:a.resolve({value:t,done:!1})}(a=a.next)?s(a.key,a.arg):u=null}this._invoke=function(n,i){return new Promise(function(e,t){var r={key:n,arg:i,resolve:e,reject:t,next:null};u?u=u.next=r:(a=u=r,s(n,i))})},"function"!=typeof o["return"]&&(this["return"]=void 0)}AsyncGenerator.prototype["function"==typeof Symbol&&Symbol.asyncIterator||"@@asyncIterator"]=function(){return this},AsyncGenerator.prototype.next=function(e){return this._invoke("next",e)},AsyncGenerator.prototype["throw"]=function(e){return this._invoke("throw",e)},AsyncGenerator.prototype["return"]=function(e){return this._invoke("return",e)};function _wrapAsyncGenerator(e){return function(){return new AsyncGenerator(e.apply(this,arguments))}}function getDefaultExportFromCjs(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,"default")?e["default"]:e}var regeneratorRuntime$1={exports:{}};var _typeof={exports:{}};(function(t){function r(e){"@babel/helpers - typeof";return t.exports=r="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},t.exports.__esModule=true,t.exports["default"]=t.exports,r(e)}t.exports=r,t.exports.__esModule=true,t.exports["default"]=t.exports})(_typeof);var _typeofExports=_typeof.exports;(function(B){var O=_typeofExports["default"];function I(){B.exports=I=function e(){return o},B.exports.__esModule=true,B.exports["default"]=B.exports;var c,o={},e=Object.prototype,l=e.hasOwnProperty,f=Object.defineProperty||function(e,t,r){e[t]=r.value},t="function"==typeof Symbol?Symbol:{},i=t.iterator||"@@iterator",r=t.asyncIterator||"@@asyncIterator",n=t.toStringTag||"@@toStringTag";function a(e,t,r){return Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}),e[t]}try{a({},"")}catch(c){a=function e(t,r,n){return t[r]=n}}function u(e,t,r,n){var i=t&&t.prototype instanceof s?t:s,a=Object.create(i.prototype),o=new P(n||[]);return f(a,"_invoke",{value:A(e,r,o)}),a}function _(e,t,r){try{return{type:"normal",arg:e.call(t,r)}}catch(e){return{type:"throw",arg:e}}}o.wrap=u;var p="suspendedStart",h="suspendedYield",d="executing",m="completed",y={};function s(){}function v(){}function g(){}var b={};a(b,i,function(){return this});var w=Object.getPrototypeOf,D=w&&w(w(C([])));D&&D!==e&&l.call(D,i)&&(b=D);var x=g.prototype=s.prototype=Object.create(b);function E(e){["next","throw","return"].forEach(function(t){a(e,t,function(e){return this._invoke(t,e)})})}function L(u,s){function c(e,t,r,n){var i=_(u[e],u,t);if("throw"!==i.type){var a=i.arg,o=a.value;return o&&"object"==O(o)&&l.call(o,"__await")?s.resolve(o.__await).then(function(e){c("next",e,r,n)},function(e){c("throw",e,r,n)}):s.resolve(o).then(function(e){a.value=e,r(a)},function(e){return c("throw",e,r,n)})}n(i.arg)}var i;f(this,"_invoke",{value:function e(r,n){function t(){return new s(function(e,t){c(r,n,e,t)})}return i=i?i.then(t,t):t()}})}function A(a,o,u){var s=p;return function(e,t){if(s===d)throw new Error("Generator is already running");if(s===m){if("throw"===e)throw t;return{value:c,done:!0}}for(u.method=e,u.arg=t;;){var r=u.delegate;if(r){var n=S(r,u);if(n){if(n===y)continue;return n}}if("next"===u.method)u.sent=u._sent=u.arg;else if("throw"===u.method){if(s===p)throw s=m,u.arg;u.dispatchException(u.arg)}else"return"===u.method&&u.abrupt("return",u.arg);s=d;var i=_(a,o,u);if("normal"===i.type){if(s=u.done?m:h,i.arg===y)continue;return{value:i.arg,done:u.done}}"throw"===i.type&&(s=m,u.method="throw",u.arg=i.arg)}}}function S(e,t){var r=t.method,n=e.iterator[r];if(n===c)return t.delegate=null,"throw"===r&&e.iterator["return"]&&(t.method="return",t.arg=c,S(e,t),"throw"===t.method)||"return"!==r&&(t.method="throw",t.arg=new TypeError("The iterator does not provide a '"+r+"' method")),y;var i=_(n,e.iterator,t.arg);if("throw"===i.type)return t.method="throw",t.arg=i.arg,t.delegate=null,y;var a=i.arg;return a?a.done?(t[e.resultName]=a.value,t.next=e.nextLoc,"return"!==t.method&&(t.method="next",t.arg=c),t.delegate=null,y):a:(t.method="throw",t.arg=new TypeError("iterator result is not an object"),t.delegate=null,y)}function F(e){var t={tryLoc:e[0]};1 in e&&(t.catchLoc=e[1]),2 in e&&(t.finallyLoc=e[2],t.afterLoc=e[3]),this.tryEntries.push(t)}function k(e){var t=e.completion||{};t.type="normal",delete t.arg,e.completion=t}function P(e){this.tryEntries=[{tryLoc:"root"}],e.forEach(F,this),this.reset(!0)}function C(t){if(t||""===t){var e=t[i];if(e)return e.call(t);if("function"==typeof t.next)return t;if(!isNaN(t.length)){var r=-1,n=function e(){for(;++r=0;--i){var a=this.tryEntries[i],o=a.completion;if("root"===a.tryLoc)return t("end");if(a.tryLoc<=this.prev){var u=l.call(a,"catchLoc"),s=l.call(a,"finallyLoc");if(u&&s){if(this.prev=0;--n){var i=this.tryEntries[n];if(i.tryLoc<=this.prev&&l.call(i,"finallyLoc")&&this.prev=0;--r){var n=this.tryEntries[r];if(n.finallyLoc===t)return this.complete(n.completion,n.afterLoc),k(n),y}},catch:function e(t){for(var r=this.tryEntries.length-1;r>=0;--r){var n=this.tryEntries[r];if(n.tryLoc===t){var i=n.completion;if("throw"===i.type){var a=i.arg;k(n)}return a}}throw new Error("illegal catch attempt")},delegateYield:function e(t,r,n){return this.delegate={iterator:C(t),resultName:r,nextLoc:n},"next"===this.method&&(this.arg=c),y}},o}B.exports=I,B.exports.__esModule=true,B.exports["default"]=B.exports})(regeneratorRuntime$1);var regeneratorRuntimeExports=regeneratorRuntime$1.exports;var runtime=regeneratorRuntimeExports();var regenerator=runtime;try{regeneratorRuntime=runtime}catch(e){if(typeof globalThis==="object"){globalThis.regeneratorRuntime=runtime}else{Function("r","regeneratorRuntime = r")(runtime)}}var _regeneratorRuntime=getDefaultExportFromCjs(regenerator);var global$1=typeof global!=="undefined"?global:typeof self!=="undefined"?self:typeof window!=="undefined"?window:{};var lookup=[];var revLookup=[];var Arr=typeof Uint8Array!=="undefined"?Uint8Array:Array;var inited=false;function init$1(){inited=true;var e="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";for(var t=0,r=e.length;t0){throw new Error("Invalid string. Length must be a multiple of 4")}a=e[u-2]==="="?2:e[u-1]==="="?1:0;o=new Arr(u*3/4-a);n=a>0?u-4:u;var s=0;for(t=0,r=0;t>16&255;o[s++]=i>>8&255;o[s++]=i&255}if(a===2){i=revLookup[e.charCodeAt(t)]<<2|revLookup[e.charCodeAt(t+1)]>>4;o[s++]=i&255}else if(a===1){i=revLookup[e.charCodeAt(t)]<<10|revLookup[e.charCodeAt(t+1)]<<4|revLookup[e.charCodeAt(t+2)]>>2;o[s++]=i>>8&255;o[s++]=i&255}return o}function tripletToBase64(e){return lookup[e>>18&63]+lookup[e>>12&63]+lookup[e>>6&63]+lookup[e&63]}function encodeChunk(e,t,r){var n;var i=[];for(var a=t;as?s:u+o))}if(n===1){t=e[r-1];i+=lookup[t>>2];i+=lookup[t<<4&63];i+="=="}else if(n===2){t=(e[r-2]<<8)+e[r-1];i+=lookup[t>>10];i+=lookup[t>>4&63];i+=lookup[t<<2&63];i+="="}a.push(i);return a.join("")}function read$1(e,t,r,n,i){var a,o;var u=i*8-n-1;var s=(1<>1;var l=-7;var f=r?i-1:0;var _=r?-1:1;var p=e[t+f];f+=_;a=p&(1<<-l)-1;p>>=-l;l+=u;for(;l>0;a=a*256+e[t+f],f+=_,l-=8){}o=a&(1<<-l)-1;a>>=-l;l+=n;for(;l>0;o=o*256+e[t+f],f+=_,l-=8){}if(a===0){a=1-c}else if(a===s){return o?NaN:(p?-1:1)*Infinity}else{o=o+Math.pow(2,n);a=a-c}return(p?-1:1)*o*Math.pow(2,a-n)}function write(e,t,r,n,i,a){var o,u,s;var c=a*8-i-1;var l=(1<>1;var _=i===23?Math.pow(2,-24)-Math.pow(2,-77):0;var p=n?0:a-1;var h=n?1:-1;var d=t<0||t===0&&1/t<0?1:0;t=Math.abs(t);if(isNaN(t)||t===Infinity){u=isNaN(t)?1:0;o=l}else{o=Math.floor(Math.log(t)/Math.LN2);if(t*(s=Math.pow(2,-o))<1){o--;s*=2}if(o+f>=1){t+=_/s}else{t+=_*Math.pow(2,1-f)}if(t*s>=2){o++;s/=2}if(o+f>=l){u=0;o=l}else if(o+f>=1){u=(t*s-1)*Math.pow(2,i);o=o+f}else{u=t*Math.pow(2,f-1)*Math.pow(2,i);o=0}}for(;i>=8;e[r+p]=u&255,p+=h,u/=256,i-=8){}o=o<0;e[r+p]=o&255,p+=h,o/=256,c-=8){}e[r+p-h]|=d*128}var toString$1={}.toString;var isArray=Array.isArray||function(e){return toString$1.call(e)=="[object Array]"}; +function _classApplyDescriptorGet(e,t){if(t.get){return t.get.call(e)}return t.value}function _classExtractFieldDescriptor(e,t,r){if(!t.has(e)){throw new TypeError("attempted to "+r+" private field on non-instance")}return t.get(e)}function _classPrivateFieldGet(e,t){var r=_classExtractFieldDescriptor(e,t,"get");return _classApplyDescriptorGet(e,r)}function _classApplyDescriptorSet(e,t,r){if(t.set){t.set.call(e,r)}else{if(!t.writable){throw new TypeError("attempted to set read only private field")}t.value=r}}function _classPrivateFieldSet(e,t,r){var n=_classExtractFieldDescriptor(e,t,"set");_classApplyDescriptorSet(e,n,r);return r}function _getPrototypeOf(e){_getPrototypeOf=Object.setPrototypeOf?Object.getPrototypeOf.bind():function e(t){return t.__proto__||Object.getPrototypeOf(t)};return _getPrototypeOf(e)}function _setPrototypeOf(e,t){_setPrototypeOf=Object.setPrototypeOf?Object.setPrototypeOf.bind():function e(t,r){t.__proto__=r;return t};return _setPrototypeOf(e,t)}function _isNativeFunction(t){try{return Function.toString.call(t).indexOf("[native code]")!==-1}catch(e){return typeof t==="function"}}function _isNativeReflectConstruct$1(){try{var t=!Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){}))}catch(t){}return(_isNativeReflectConstruct$1=function e(){return!!t})()}function _construct(e,t,r){if(_isNativeReflectConstruct$1())return Reflect.construct.apply(null,arguments);var n=[null];n.push.apply(n,t);var i=new(e.bind.apply(e,n));return r&&_setPrototypeOf(i,r.prototype),i}function _wrapNativeSuper(e){var n=typeof Map==="function"?new Map:undefined;_wrapNativeSuper=function e(t){if(t===null||!_isNativeFunction(t))return t;if(typeof t!=="function"){throw new TypeError("Super expression must either be null or a function")}if(typeof n!=="undefined"){if(n.has(t))return n.get(t);n.set(t,r)}function r(){return _construct(t,arguments,_getPrototypeOf(this).constructor)}r.prototype=Object.create(t.prototype,{constructor:{value:r,enumerable:false,writable:true,configurable:true}});return _setPrototypeOf(r,t)};return _wrapNativeSuper(e)}function _typeof$1(e){"@babel/helpers - typeof";return _typeof$1="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},_typeof$1(e)}function _assertThisInitialized(e){if(e===void 0){throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}return e}function _possibleConstructorReturn(e,t){if(t&&(_typeof$1(t)==="object"||typeof t==="function")){return t}else if(t!==void 0){throw new TypeError("Derived constructors may only return object or undefined")}return _assertThisInitialized(e)}function _inherits(e,t){if(typeof t!=="function"&&t!==null){throw new TypeError("Super expression must either be null or a function")}e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,writable:true,configurable:true}});Object.defineProperty(e,"prototype",{writable:false});if(t)_setPrototypeOf(e,t)}function _arrayWithHoles(e){if(Array.isArray(e))return e}function _iterableToArray(e){if(typeof Symbol!=="undefined"&&e[Symbol.iterator]!=null||e["@@iterator"]!=null)return Array.from(e)}function _arrayLikeToArray$1(e,t){if(t==null||t>e.length)t=e.length;for(var r=0,n=new Array(t);r=0)continue;r[i]=e[i]}return r}function _objectWithoutProperties(e,t){if(e==null)return{};var r=_objectWithoutPropertiesLoose(e,t);var n,i;if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(i=0;i=0)continue;if(!Object.prototype.propertyIsEnumerable.call(e,n))continue;r[n]=e[n]}}return r}function _iterableToArrayLimit(e,t){var r=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=r){var n,i,a,o,u=[],s=!0,c=!1;try{if(a=(r=r.call(e)).next,0===t){if(Object(r)!==r)return;s=!1}else for(;!(s=(n=a.call(r)).done)&&(u.push(n.value),u.length!==t);s=!0);}catch(e){c=!0,i=e}finally{try{if(!s&&null!=r["return"]&&(o=r["return"](),Object(o)!==o))return}finally{if(c)throw i}}return u}}function _slicedToArray(e,t){return _arrayWithHoles(e)||_iterableToArrayLimit(e,t)||_unsupportedIterableToArray$1(e,t)||_nonIterableRest()}function _arrayWithoutHoles(e){if(Array.isArray(e))return _arrayLikeToArray$1(e)}function _nonIterableSpread(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function _toConsumableArray(e){return _arrayWithoutHoles(e)||_iterableToArray(e)||_unsupportedIterableToArray$1(e)||_nonIterableSpread()}function _OverloadYield(e,t){this.v=e,this.k=t}function _awaitAsyncGenerator(e){return new _OverloadYield(e,0)}function AsyncGenerator(o){var a,u;function s(r,e){try{var n=o[r](e),i=n.value,a=i instanceof _OverloadYield;Promise.resolve(a?i.v:i).then(function(e){if(a){var t="return"===r?"return":"next";if(!i.k||e.done)return s(t,e);e=o[t](e).value}c(n.done?"return":"normal",e)},function(e){s("throw",e)})}catch(e){c("throw",e)}}function c(e,t){switch(e){case"return":a.resolve({value:t,done:!0});break;case"throw":a.reject(t);break;default:a.resolve({value:t,done:!1})}(a=a.next)?s(a.key,a.arg):u=null}this._invoke=function(n,i){return new Promise(function(e,t){var r={key:n,arg:i,resolve:e,reject:t,next:null};u?u=u.next=r:(a=u=r,s(n,i))})},"function"!=typeof o["return"]&&(this["return"]=void 0)}AsyncGenerator.prototype["function"==typeof Symbol&&Symbol.asyncIterator||"@@asyncIterator"]=function(){return this},AsyncGenerator.prototype.next=function(e){return this._invoke("next",e)},AsyncGenerator.prototype["throw"]=function(e){return this._invoke("throw",e)},AsyncGenerator.prototype["return"]=function(e){return this._invoke("return",e)};function _wrapAsyncGenerator(e){return function(){return new AsyncGenerator(e.apply(this,arguments))}}function getDefaultExportFromCjs(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,"default")?e["default"]:e}var regeneratorRuntime$1={exports:{}};var _typeof={exports:{}};(function(t){function r(e){"@babel/helpers - typeof";return t.exports=r="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},t.exports.__esModule=true,t.exports["default"]=t.exports,r(e)}t.exports=r,t.exports.__esModule=true,t.exports["default"]=t.exports})(_typeof);var _typeofExports=_typeof.exports;(function(O){var P=_typeofExports["default"];function I(){O.exports=I=function e(){return o},O.exports.__esModule=true,O.exports["default"]=O.exports;var c,o={},e=Object.prototype,l=e.hasOwnProperty,f=Object.defineProperty||function(e,t,r){e[t]=r.value},t="function"==typeof Symbol?Symbol:{},i=t.iterator||"@@iterator",r=t.asyncIterator||"@@asyncIterator",n=t.toStringTag||"@@toStringTag";function a(e,t,r){return Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}),e[t]}try{a({},"")}catch(c){a=function e(t,r,n){return t[r]=n}}function u(e,t,r,n){var i=t&&t.prototype instanceof s?t:s,a=Object.create(i.prototype),o=new C(n||[]);return f(a,"_invoke",{value:A(e,r,o)}),a}function _(e,t,r){try{return{type:"normal",arg:e.call(t,r)}}catch(e){return{type:"throw",arg:e}}}o.wrap=u;var p="suspendedStart",h="suspendedYield",d="executing",m="completed",y={};function s(){}function v(){}function g(){}var b={};a(b,i,function(){return this});var w=Object.getPrototypeOf,D=w&&w(w(B([])));D&&D!==e&&l.call(D,i)&&(b=D);var x=g.prototype=s.prototype=Object.create(b);function E(e){["next","throw","return"].forEach(function(t){a(e,t,function(e){return this._invoke(t,e)})})}function L(u,s){function c(e,t,r,n){var i=_(u[e],u,t);if("throw"!==i.type){var a=i.arg,o=a.value;return o&&"object"==P(o)&&l.call(o,"__await")?s.resolve(o.__await).then(function(e){c("next",e,r,n)},function(e){c("throw",e,r,n)}):s.resolve(o).then(function(e){a.value=e,r(a)},function(e){return c("throw",e,r,n)})}n(i.arg)}var i;f(this,"_invoke",{value:function e(r,n){function t(){return new s(function(e,t){c(r,n,e,t)})}return i=i?i.then(t,t):t()}})}function A(a,o,u){var s=p;return function(e,t){if(s===d)throw new Error("Generator is already running");if(s===m){if("throw"===e)throw t;return{value:c,done:!0}}for(u.method=e,u.arg=t;;){var r=u.delegate;if(r){var n=S(r,u);if(n){if(n===y)continue;return n}}if("next"===u.method)u.sent=u._sent=u.arg;else if("throw"===u.method){if(s===p)throw s=m,u.arg;u.dispatchException(u.arg)}else"return"===u.method&&u.abrupt("return",u.arg);s=d;var i=_(a,o,u);if("normal"===i.type){if(s=u.done?m:h,i.arg===y)continue;return{value:i.arg,done:u.done}}"throw"===i.type&&(s=m,u.method="throw",u.arg=i.arg)}}}function S(e,t){var r=t.method,n=e.iterator[r];if(n===c)return t.delegate=null,"throw"===r&&e.iterator["return"]&&(t.method="return",t.arg=c,S(e,t),"throw"===t.method)||"return"!==r&&(t.method="throw",t.arg=new TypeError("The iterator does not provide a '"+r+"' method")),y;var i=_(n,e.iterator,t.arg);if("throw"===i.type)return t.method="throw",t.arg=i.arg,t.delegate=null,y;var a=i.arg;return a?a.done?(t[e.resultName]=a.value,t.next=e.nextLoc,"return"!==t.method&&(t.method="next",t.arg=c),t.delegate=null,y):a:(t.method="throw",t.arg=new TypeError("iterator result is not an object"),t.delegate=null,y)}function F(e){var t={tryLoc:e[0]};1 in e&&(t.catchLoc=e[1]),2 in e&&(t.finallyLoc=e[2],t.afterLoc=e[3]),this.tryEntries.push(t)}function k(e){var t=e.completion||{};t.type="normal",delete t.arg,e.completion=t}function C(e){this.tryEntries=[{tryLoc:"root"}],e.forEach(F,this),this.reset(!0)}function B(t){if(t||""===t){var e=t[i];if(e)return e.call(t);if("function"==typeof t.next)return t;if(!isNaN(t.length)){var r=-1,n=function e(){for(;++r=0;--i){var a=this.tryEntries[i],o=a.completion;if("root"===a.tryLoc)return t("end");if(a.tryLoc<=this.prev){var u=l.call(a,"catchLoc"),s=l.call(a,"finallyLoc");if(u&&s){if(this.prev=0;--n){var i=this.tryEntries[n];if(i.tryLoc<=this.prev&&l.call(i,"finallyLoc")&&this.prev=0;--r){var n=this.tryEntries[r];if(n.finallyLoc===t)return this.complete(n.completion,n.afterLoc),k(n),y}},catch:function e(t){for(var r=this.tryEntries.length-1;r>=0;--r){var n=this.tryEntries[r];if(n.tryLoc===t){var i=n.completion;if("throw"===i.type){var a=i.arg;k(n)}return a}}throw new Error("illegal catch attempt")},delegateYield:function e(t,r,n){return this.delegate={iterator:B(t),resultName:r,nextLoc:n},"next"===this.method&&(this.arg=c),y}},o}O.exports=I,O.exports.__esModule=true,O.exports["default"]=O.exports})(regeneratorRuntime$1);var regeneratorRuntimeExports=regeneratorRuntime$1.exports;var runtime=regeneratorRuntimeExports();var regenerator=runtime;try{regeneratorRuntime=runtime}catch(e){if(typeof globalThis==="object"){globalThis.regeneratorRuntime=runtime}else{Function("r","regeneratorRuntime = r")(runtime)}}var _regeneratorRuntime=getDefaultExportFromCjs(regenerator);var global$1=typeof global!=="undefined"?global:typeof self!=="undefined"?self:typeof window!=="undefined"?window:{};var lookup=[];var revLookup=[];var Arr=typeof Uint8Array!=="undefined"?Uint8Array:Array;var inited=false;function init$1(){inited=true;var e="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";for(var t=0,r=e.length;t0){throw new Error("Invalid string. Length must be a multiple of 4")}a=e[u-2]==="="?2:e[u-1]==="="?1:0;o=new Arr(u*3/4-a);n=a>0?u-4:u;var s=0;for(t=0,r=0;t>16&255;o[s++]=i>>8&255;o[s++]=i&255}if(a===2){i=revLookup[e.charCodeAt(t)]<<2|revLookup[e.charCodeAt(t+1)]>>4;o[s++]=i&255}else if(a===1){i=revLookup[e.charCodeAt(t)]<<10|revLookup[e.charCodeAt(t+1)]<<4|revLookup[e.charCodeAt(t+2)]>>2;o[s++]=i>>8&255;o[s++]=i&255}return o}function tripletToBase64(e){return lookup[e>>18&63]+lookup[e>>12&63]+lookup[e>>6&63]+lookup[e&63]}function encodeChunk(e,t,r){var n;var i=[];for(var a=t;as?s:u+o))}if(n===1){t=e[r-1];i+=lookup[t>>2];i+=lookup[t<<4&63];i+="=="}else if(n===2){t=(e[r-2]<<8)+e[r-1];i+=lookup[t>>10];i+=lookup[t>>4&63];i+=lookup[t<<2&63];i+="="}a.push(i);return a.join("")}function read$1(e,t,r,n,i){var a,o;var u=i*8-n-1;var s=(1<>1;var l=-7;var f=r?i-1:0;var _=r?-1:1;var p=e[t+f];f+=_;a=p&(1<<-l)-1;p>>=-l;l+=u;for(;l>0;a=a*256+e[t+f],f+=_,l-=8){}o=a&(1<<-l)-1;a>>=-l;l+=n;for(;l>0;o=o*256+e[t+f],f+=_,l-=8){}if(a===0){a=1-c}else if(a===s){return o?NaN:(p?-1:1)*Infinity}else{o=o+Math.pow(2,n);a=a-c}return(p?-1:1)*o*Math.pow(2,a-n)}function write(e,t,r,n,i,a){var o,u,s;var c=a*8-i-1;var l=(1<>1;var _=i===23?Math.pow(2,-24)-Math.pow(2,-77):0;var p=n?0:a-1;var h=n?1:-1;var d=t<0||t===0&&1/t<0?1:0;t=Math.abs(t);if(isNaN(t)||t===Infinity){u=isNaN(t)?1:0;o=l}else{o=Math.floor(Math.log(t)/Math.LN2);if(t*(s=Math.pow(2,-o))<1){o--;s*=2}if(o+f>=1){t+=_/s}else{t+=_*Math.pow(2,1-f)}if(t*s>=2){o++;s/=2}if(o+f>=l){u=0;o=l}else if(o+f>=1){u=(t*s-1)*Math.pow(2,i);o=o+f}else{u=t*Math.pow(2,f-1)*Math.pow(2,i);o=0}}for(;i>=8;e[r+p]=u&255,p+=h,u/=256,i-=8){}o=o<0;e[r+p]=o&255,p+=h,o/=256,c-=8){}e[r+p-h]|=d*128}var toString$1={}.toString;var isArray=Array.isArray||function(e){return toString$1.call(e)=="[object Array]"}; /*! * The buffer module from node.js, for the browser. * @@ -48,4 +48,4 @@ function _classApplyDescriptorGet(e,t){if(t.get){return t.get.call(e)}return t.v * Released under BSD-3-Clause License * * build: Wed, 27 Oct 2021 10:43:10 GMT - */Object.defineProperty(lzjbPack,"__esModule",{value:true});const NBBY=8,MATCH_BITS=6,MATCH_MIN=3,MATCH_MAX=(1<r-MATCH_MAX){t[i++]=e[n++];continue}l=(e[n]+13^e[n+1]-13^e[n+2])&LEMPEL_SIZE-1;c=n-f[l]&OFFSET_MASK;f[l]=n;a=n-c;if(a>=0&&a!=n&&e[n]==e[a]&&e[n+1]==e[a+1]&&e[n+2]==e[a+2]){t[o]|=u;for(s=MATCH_MIN;s>NBBY;t[i++]=c;n+=s}else{t[i++]=e[n++]}}console.assert(e.length>=n);return i}function decompress(e,t,r){t=t|0;var n=0,i=0,a=0,o=0,u=1<<(NBBY-1|0),s=0,c=0;while(n>(NBBY-MATCH_BITS|0))+MATCH_MIN|0;c=(e[n]<4){r[i]=r[a];i=i+1|0;a=a+1|0;r[i]=r[a];i=i+1|0;a=a+1|0;r[i]=r[a];i=i+1|0;a=a+1|0;r[i]=r[a];i=i+1|0;a=a+1|0;s=s-4|0}while(s>0){r[i]=r[a];i=i+1|0;a=a+1|0;s=s-1|0}}}else{r[i]=e[n];i=i+1|0;n=n+1|0}}return i}function encode_magic$1(){const e=new TextEncoder("utf-8");return e.encode(MAGIC_STRING)}const MAGIC_STRING="@lzjb";const MAGIC=encode_magic$1();function merge_uint8_array$1(...e){if(e.length>1){const r=e.reduce((e,t)=>e+t.length,0);const n=new Uint8Array(r);let t=0;e.forEach(e=>{n.set(e,t);t+=e.length});return n}else if(e.length){return e[0]}}function number_to_bytes(t){const e=Math.ceil(Math.log2(t)/8);const r=new Uint8Array(e);for(let e=0;e=0;e--){r=r*256+t[e]}return r}function pack(e,{magic:t=true}={}){const r=new Uint8Array(Math.max(e.length*1.5|0,16*1024));const n=compress(e,r);const i=number_to_bytes(e.length);const a=[Uint8Array.of(i.length),i,r.slice(0,n)];if(t){a.unshift(MAGIC)}return merge_uint8_array$1(...a)}function unpack(t,{magic:e=true}={}){if(e){const e=new TextDecoder("utf-8");const s=e.decode(t.slice(0,MAGIC.length));if(s!==MAGIC_STRING){throw new Error("Invalid magic value")}}const r=e?MAGIC.length:0;const n=t[r];const i=r+1;const a=r+n+1;const o=bytes_to_number(t.slice(i,a));t=t.slice(a);const u=new Uint8Array(o);decompress(t,t.length,u);return u}var pack_1=lzjbPack.pack=pack;var unpack_1=lzjbPack.unpack=unpack;function unfetch(s,c){return c=c||{},new Promise(function(e,t){var r=new XMLHttpRequest,n=[],i=[],a={},o=function(){return{ok:2==(r.status/100|0),statusText:r.statusText,status:r.status,url:r.responseURL,text:function(){return Promise.resolve(r.responseText)},json:function(){return Promise.resolve(r.responseText).then(JSON.parse)},blob:function(){return Promise.resolve(new Blob([r.response]))},clone:o,headers:{keys:function(){return n},entries:function(){return i},get:function(e){return a[e.toLowerCase()]},has:function(e){return e.toLowerCase()in a}}}};for(var u in r.open(c.method||"get",s,!0),r.onload=function(){r.getAllResponseHeaders().replace(/^(.*?):[^\S\n]*([\s\S]*?)$/gm,function(e,t,r){n.push(t=t.toLowerCase()),i.push([t,r]),a[t]=a[t]?a[t]+","+r:r}),e(o())},r.onerror=t,r.withCredentials="include"==c.credentials,c.headers)r.setRequestHeader(u,c.headers[u]);r.send(c.body||null)})}var _excluded=["token"],_excluded2=["env"],_excluded3=["stderr","stdin","stdout","command_line"],_excluded4=["use_dynamic"],_excluded5=["use_dynamic"],_excluded6=["env","dynamic_env","use_dynamic","error"];function _classPrivateFieldInitSpec(e,t,r){_checkPrivateRedeclaration(e,t);t.set(e,r)}function _checkPrivateRedeclaration(e,t){if(t.has(e)){throw new TypeError("Cannot initialize the same private elements twice on an object")}}function _callSuper(e,t,r){return t=_getPrototypeOf(t),_possibleConstructorReturn(e,_isNativeReflectConstruct()?Reflect.construct(t,r||[],_getPrototypeOf(e).constructor):t.apply(e,r))}function _isNativeReflectConstruct(){try{var t=!Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){}))}catch(t){}return(_isNativeReflectConstruct=function e(){return!!t})()}function _createForOfIteratorHelper(t,e){var r=typeof Symbol!=="undefined"&&t[Symbol.iterator]||t["@@iterator"];if(!r){if(Array.isArray(t)||(r=_unsupportedIterableToArray(t))||e&&t&&typeof t.length==="number"){if(r)t=r;var n=0;var i=function e(){};return{s:i,n:function e(){if(n>=t.length)return{done:true};return{done:false,value:t[n++]}},e:function e(t){throw t},f:i}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var a=true,o=false,u;return{s:function e(){r=r.call(t)},n:function e(){var t=r.next();a=t.done;return t},e:function e(t){o=true;u=t},f:function e(){try{if(!a&&r["return"]!=null)r["return"]()}finally{if(o)throw u}}}}function _unsupportedIterableToArray(e,t){if(!e)return;if(typeof e==="string")return _arrayLikeToArray(e,t);var r=Object.prototype.toString.call(e).slice(8,-1);if(r==="Object"&&e.constructor)r=e.constructor.name;if(r==="Map"||r==="Set")return Array.from(e);if(r==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r))return _arrayLikeToArray(e,t)}function _arrayLikeToArray(e,t){if(t==null||t>e.length)t=e.length;for(var r=0,n=new Array(t);r1?r-1:0),i=1;i0&&arguments[0]!==undefined?arguments[0]:null;var t=user_env&&user_env.get("DEBUG",{throwError:false});if(e===null){return t===true}return(t===null||t===void 0?void 0:t.valueOf())===e.valueOf()}function num_mnemicic_re(e){return e?"(?:#".concat(e,"(?:#[ie])?|#[ie]#").concat(e,")"):"(?:#[ie])?"}function gen_rational_re(e,t){return"".concat(num_mnemicic_re(e),"[+-]?").concat(t,"+/").concat(t,"+")}function gen_complex_re(e,t){return"".concat(num_mnemicic_re(e),"(?:[+-]?(?:").concat(t,"+/").concat(t,"+|nan.0|inf.0|").concat(t,"+))?(?:[+-]i|[+-]?(?:").concat(t,"+/").concat(t,"+|").concat(t,"+|nan.0|inf.0)i)(?=[()[\\]\\s]|$)")}function gen_integer_re(e,t){return"".concat(num_mnemicic_re(e),"[+-]?").concat(t,"+")}var re_re=/^#\/((?:\\\/|[^/]|\[[^\]]*\/[^\]]*\])+)\/([gimyus]*)$/;var float_stre="(?:[-+]?(?:[0-9]+(?:[eE][-+]?[0-9]+)|(?:\\.[0-9]+|[0-9]+\\.[0-9]+)(?:[eE][-+]?[0-9]+)?)|[0-9]+\\.)";var complex_float_stre="(?:#[ie])?(?:[+-]?(?:[0-9]+/[0-9]+|nan.0|inf.0|".concat(float_stre,"|[+-]?[0-9]+))?(?:").concat(float_stre,"|[+-](?:[0-9]+/[0-9]+|[0-9]+|nan.0|inf.0))i");var float_re=new RegExp("^(#[ie])?".concat(float_stre,"$"),"i");function make_complex_match_re(e,t){var r=e==="x"?"(?!\\+|".concat(t,")"):"(?!\\.|".concat(t,")");var n="";if(e===""){n="(?:[-+]?(?:[0-9]+(?:[eE][-+]?[0-9]+)|(?:\\.[0-9]+|[0-9]+\\.[0-9]+(?![0-9]))(?:[eE][-+]?[0-9]+)?))"}return new RegExp("^((?:(?:".concat(n,"|[-+]?inf.0|[-+]?nan.0|[+-]?").concat(t,"+/").concat(t,"+(?!").concat(t,")|[+-]?").concat(t,"+)").concat(r,")?)(").concat(n,"|[-+]?inf.0|[-+]?nan.0|[+-]?").concat(t,"+/").concat(t,"+|[+-]?").concat(t,"+|[+-])i$"),"i")}var complex_list_re=function(){var a={};[[10,"","[0-9]"],[16,"x","[0-9a-fA-F]"],[8,"o","[0-7]"],[2,"b","[01]"]].forEach(function(e){var t=_slicedToArray(e,3),r=t[0],n=t[1],i=t[2];a[r]=make_complex_match_re(n,i)});return a}();var characters={alarm:"",backspace:"\b",delete:"",escape:"",newline:"\n",null:"\0",return:"\r",space:" ",tab:"\t",dle:"",soh:"",dc1:"",stx:"",dc2:"",etx:"",dc3:"",eot:"",dc4:"",enq:"",nak:"",ack:"",syn:"",bel:"",etb:"",bs:"\b",can:"",ht:"\t",em:"",lf:"\n",sub:"",vt:"\v",esc:"",ff:"\f",fs:"",cr:"\r",gs:"",so:"",rs:"",si:"",us:"",del:""};function ucs2decode(e){var t=[];var r=0;var n=e.length;while(r=55296&&i<=56319&&r1&&arguments[1]!==undefined?arguments[1]:10;var r=num_pre_parse(e);var n=r.number.split("/");var i=LRational({num:LNumber([n[0],r.radix||t]),denom:LNumber([n[1],r.radix||t])});if(r.inexact){return i.valueOf()}else{return i}}function parse_integer(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:10;var r=num_pre_parse(e);if(r.inexact){return LFloat(parseInt(r.number,r.radix||t))}return LNumber([r.number,r.radix||t])}function parse_character(e){var t=e.match(/#\\x([0-9a-f]+)$/i);var r;if(t){var n=parseInt(t[1],16);r=String.fromCodePoint(n)}else{t=e.match(/#\\([\s\S]+)$/);if(t){r=t[1]}}if(r){return LCharacter(r)}throw new Error("Parse: invalid character")}function parse_complex(e){var i=arguments.length>1&&arguments[1]!==undefined?arguments[1]:10;function t(e){var t;if(e==="+"){t=LNumber(1)}else if(e==="-"){t=LNumber(-1)}else if(e.match(int_bare_re)){t=LNumber([e,i])}else if(e.match(rational_bare_re)){var r=e.split("/");t=LRational({num:LNumber([r[0],i]),denom:LNumber([r[1],i])})}else if(e.match(float_re)){var n=parse_float(e);if(a.exact){return n.toRational()}return n}else if(e.match(/nan.0$/)){return LNumber(NaN)}else if(e.match(/inf.0$/)){if(e[0]==="-"){return LNumber(Number.NEGATIVE_INFINITY)}return LNumber(Number.POSITIVE_INFINITY)}else{throw new Error("Internal Parser Error")}if(a.inexact){return LFloat(t.valueOf())}return t}var a=num_pre_parse(e);i=a.radix||i;var r;var n=a.number.match(complex_bare_match_re);if(i!==10&&n){r=n}else{r=a.number.match(complex_list_re[i])}var o,u;u=t(r[2]);if(r[1]){o=t(r[1])}else{o=LNumber(0)}if(u.cmp(0)===0&&u.__type__==="bigint"){return o}return LComplex({im:u,re:o})}function is_int(e){return parseInt(e.toString(),10)===e}function parse_big_int(e){var t=e.match(/^(([-+]?[0-9]*)(?:\.([0-9]+))?)e([-+]?[0-9]+)/i);if(t){var r=parseInt(t[4],10);var n;var i=t[1].replace(/[-+]?([0-9]*)\..+$/,"$1").length;var a=t[3]&&t[3].length;if(i0&&(t.exact||!t.number.match(/\./))){return LNumber(a).mul(u)}}}r=LFloat(r);if(t.exact){return r.toRational()}return r}function parse_string(e){e=e.replace(/\\x([0-9a-f]+);/gi,function(e,t){return"\\u"+t.padStart(4,"0")}).replace(/\n/g,"\\n");var t=e.match(/(\\*)(\\x[0-9A-F])/i);if(t&&t[1].length%2===0){throw new Error("Invalid string literal, unclosed ".concat(t[2]))}try{var r=LString(JSON.parse(e));r.freeze();return r}catch(e){var n=e.message.replace(/in JSON /,"").replace(/.*Error: /,"");throw new Error("Invalid string literal: ".concat(n))}}function parse_symbol(e){if(e.match(/^\|.*\|$/)){e=e.replace(/(^\|)|(\|$)/g,"");var r={t:"\t",r:"\r",n:"\n"};e=e.replace(/\\(x[^;]+);/g,function(e,t){return String.fromCharCode(parseInt("0"+t,16))}).replace(/\\(.)/g,function(e,t){return r[t]||t})}return new LSymbol(e)}function parse_argument(e){if(constants.hasOwnProperty(e)){return constants[e]}if(e.match(/^"[\s\S]*"$/)){return parse_string(e)}else if(e[0]==="#"){var t=e.match(re_re);if(t){return new RegExp(t[1],t[2])}else if(e.match(char_re)){return parse_character(e)}var r=e.match(/#\\(.+)/);if(r&&ucs2decode(r[1]).length===1){return parse_character(e)}}if(e.match(/[0-9a-f]|[+-]i/i)){if(e.match(int_re)){return parse_integer(e)}else if(e.match(float_re)){return parse_float(e)}else if(e.match(rational_re)){return parse_rational(e)}else if(e.match(complex_re)){return parse_complex(e)}}if(e.match(/^#[iexobd]/)){throw new Error("Invalid numeric constant: "+e)}return parse_symbol(e)}function is_atom_string(e){return!(["(",")","[","]"].includes(e)||specials.names().includes(e))}function is_symbol_string(e){return is_atom_string(e)&&!(e.match(re_re)||e.match(/^"[\s\S]*"$/)||e.match(int_re)||e.match(float_re)||e.match(complex_re)||e.match(rational_re)||e.match(char_re)||["#t","#f","nil"].includes(e))}var string_re=/"(?:\\[\S\s]|[^"])*"?/g;function escape_regex(e){if(typeof e==="string"){var t=/([-\\^$[\]()+{}?*.|])/g;return e.replace(t,"\\$1")}return e}function Stack(){this.data=[]}Stack.prototype.push=function(e){this.data.push(e)};Stack.prototype.top=function(){return this.data[this.data.length-1]};Stack.prototype.pop=function(){return this.data.pop()};Stack.prototype.is_empty=function(){return!this.data.length};function tokens(e){if(e instanceof LString){e=e.valueOf()}var t=new Lexer(e,{whitespace:true});var r=[];while(true){var n=t.peek(true);if(n===eof){break}r.push(n);t.skip()}return r}function multiline_formatter(e){var t=e.token,r=_objectWithoutProperties(e,_excluded);if(t.match(/^"[\s\S]*"$/)&&t.match(/\n/)){var n=new RegExp("^ {1,"+(e.col+1)+"}","mg");t=t.replace(n,"")}return _objectSpread({token:t},r)}function Thunk(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:function(){};this.fn=e;this.cont=t}Thunk.prototype.toString=function(){return"#"};function trampoline(n){return function(){for(var e=arguments.length,t=new Array(e),r=0;r1&&arguments[1]!==undefined?arguments[1]:false;if(e instanceof LString){e=e.toString()}if(t){return tokens(e)}else{var r=tokens(e).map(function(e){if(e.token==="#\\ "||e.token=="#\\\n"){return e.token}return e.token.trim()}).filter(function(e){return e&&!e.match(/^;/)&&!e.match(/^#\|[\s\S]*\|#$/)});return strip_s_comments(r)}}function strip_s_comments(e){var t=0;var r=null;var n=[];for(var i=0;i0&&arguments[0]!==undefined?arguments[0]:null;if(e instanceof LSymbol){if(e.is_gensym()){return e}e=e.valueOf()}if(is_gensym(e)){return LSymbol(e)}if(e!==null){return r(e,Symbol("#:".concat(e)))}t++;return r(t,Symbol("#:g".concat(t)))}}();function QuotedPromise(e){var r=this;var n={pending:true,rejected:false,fulfilled:false,reason:undefined,type:undefined};e=e.then(function(e){n.type=type(e);n.fulfilled=true;n.pending=false;return e});read_only(this,"_promise",e,{hidden:true});if(is_function(e["catch"])){e=e["catch"](function(e){n.rejected=true;n.pending=false;n.reason=e})}Object.keys(n).forEach(function(t){Object.defineProperty(r,"__".concat(t,"__"),{enumerable:true,get:function e(){return n[t]}})});read_only(this,"__promise__",e);this.then=false}QuotedPromise.prototype.then=function(e){return new QuotedPromise(this.valueOf().then(e))};QuotedPromise.prototype["catch"]=function(e){return new QuotedPromise(this.valueOf()["catch"](e))};QuotedPromise.prototype.valueOf=function(){if(!this._promise){throw new Error("QuotedPromise: invalid promise created")}return this._promise};QuotedPromise.prototype.toString=function(){if(this.__pending__){return QuotedPromise.pending_str}if(this.__rejected__){return QuotedPromise.rejected_str}return"#")};QuotedPromise.pending_str="#";QuotedPromise.rejected_str="#";function promise_all(e){if(Array.isArray(e)){return Promise.all(escape_quoted_promises(e)).then(unescape_quoted_promises)}return e}function escape_quoted_promises(e){var t=new Array(e.length),r=e.length;while(r--){var n=e[r];if(n instanceof QuotedPromise){t[r]=new Value(n)}else{t[r]=n}}return t}function unescape_quoted_promises(e){var t=new Array(e.length),r=e.length;while(r--){var n=e[r];if(n instanceof Value){t[r]=n.valueOf()}else{t[r]=n}}return t}var specials={LITERAL:Symbol["for"]("literal"),SPLICE:Symbol["for"]("splice"),SYMBOL:Symbol["for"]("symbol"),names:function e(){return Object.keys(this.__list__)},type:function e(t){try{return this.get(t).type}catch(e){console.log({name:t});console.log(e);return null}},get:function e(t){return this.__list__[t]},off:function e(t){var r=this;var n=arguments.length>1&&arguments[1]!==undefined?arguments[1]:null;if(Array.isArray(t)){t.forEach(function(e){return r.off(e,n)})}else if(n===null){delete this.__events__[t]}else{this.__events__=this.__events__.filter(function(e){return e!==n})}},on:function e(t,r){var n=this;if(Array.isArray(t)){t.forEach(function(e){return n.on(e,r)})}else if(!this.__events__[t]){this.__events__[t]=[r]}else{this.__events__[t].push(r)}},trigger:function e(t){for(var r=arguments.length,n=new Array(r>1?r-1:0),i=1;i",new LSymbol("quote-promise"),specials.LITERAL]];var builtins=defined_specials.map(function(e){return e[0]});Object.freeze(builtins);Object.defineProperty(specials,"__builtins__",{writable:false,value:builtins});defined_specials.forEach(function(e){var t=_slicedToArray(e,3),r=t[0],n=t[1],i=t[2];specials.append(r,n,i)});var Lexer=function(){function p(e){var t=this;var r=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},n=r.whitespace,i=n===void 0?false:n;_classCallCheck(this,p);read_only(this,"__input__",e.replace(/\r/g,""));var a={};["_i","_whitespace","_col","_newline","_line","_state","_next","_token","_prev_char"].forEach(function(r){Object.defineProperty(t,r,{configurable:false,enumerable:false,get:function e(){return a[r]},set:function e(t){a[r]=t}})});this._whitespace=i;this._i=this._line=this._col=this._newline=0;this._state=this._next=this._token=null;this._prev_char=""}_createClass(p,[{key:"get",value:function e(t){return this.__internal[t]}},{key:"set",value:function e(t,r){this.__internal[t]=r}},{key:"token",value:function e(){var t=arguments.length>0&&arguments[0]!==undefined?arguments[0]:false;if(t){var r=this._line;if(this._whitespace&&this._token==="\n"){--r}return{token:this._token,col:this._col,offset:this._i,line:r}}return this._token}},{key:"peek",value:function e(){var t=arguments.length>0&&arguments[0]!==undefined?arguments[0]:false;if(this._i>=this.__input__.length){return eof}if(this._token){return this.token(t)}var r=this.next_token();if(r){this._token=this.__input__.substring(this._i,this._next);return this.token(t)}return eof}},{key:"skip",value:function e(){if(this._next!==null){this._token=null;this._i=this._next}}},{key:"read_line",value:function e(){var t=this.__input__.length;if(this._i>=t){return eof}for(var r=this._i;r=r){return eof}if(t+this._i>=r){return this.read_rest()}var n=this._i+t;var i=this.__input__.substring(this._i,n);var a=i.match(/\n/g);if(a){this._line+=a.length}this._i=n;return i}},{key:"peek_char",value:function e(){if(this._i>=this.__input__.length){return eof}return LCharacter(this.__input__[this._i])}},{key:"read_char",value:function e(){var t=this.peek_char();this.skip_char();return t}},{key:"skip_char",value:function e(){if(this._i1&&arguments[1]!==undefined?arguments[1]:{},n=r.prev_char,i=r["char"],a=r.next_char;var o=_slicedToArray(t,4),u=o[0],s=o[1],c=o[2],l=o[3];if(t.length!==5){throw new Error("Lexer: Invalid rule of length ".concat(t.length))}if(!i.match(u)){return false}if(!match_or_null(s,n)){return false}if(!match_or_null(c,a)){return false}if(l!==this._state){return false}return true}},{key:"next_token",value:function e(){if(this._i>=this.__input__.length){return false}var t=true;e:for(var r=this._i,n=this.__input__.length;r2&&arguments[2]!==undefined?arguments[2]:null;var i=arguments.length>3&&arguments[3]!==undefined?arguments[3]:null;if(t.length===0){throw new Error("Lexer: invalid literal rule")}if(t.length===1){return[[t,n,i,null,null]]}var a=[];for(var o=0,u=t.length;o1&&arguments[1]!==undefined?arguments[1]:{},r=t.env,n=t.meta,i=n===void 0?false:n,a=t.formatter,o=a===void 0?multiline_formatter:a;_classCallCheck(this,u);if(e instanceof LString){e=e.toString()}read_only(this,"_formatter",o,{hidden:true});read_only(this,"__lexer__",new Lexer(e));read_only(this,"__env__",r);read_only(this,"_meta",i,{hidden:true});read_only(this,"_refs",[],{hidden:true});read_only(this,"_state",{parentheses:0},{hidden:true})}_createClass(u,[{key:"resolve",value:function e(t){return this.__env__&&this.__env__.get(t,{throwError:false})}},{key:"peek",value:function(){var e=_asyncToGenerator(_regeneratorRuntime.mark(function e(){var r;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:r=this.__lexer__.peek(true);if(!(r===eof)){t.next=4;break}return t.abrupt("return",eof);case 4:if(!this.is_comment(r.token)){t.next=7;break}this.skip();return t.abrupt("continue",0);case 7:if(!(r.token==="#;")){t.next=14;break}this.skip();if(!(this.__lexer__.peek()===eof)){t.next=11;break}throw new Error("Lexer: syntax error eof found after comment");case 11:t.next=13;return this._read_object();case 13:return t.abrupt("continue",0);case 14:return t.abrupt("break",17);case 17:r=this._formatter(r);if(!this._meta){t.next=20;break}return t.abrupt("return",r);case 20:return t.abrupt("return",r.token);case 21:case"end":return t.stop()}},e,this)}));function t(){return e.apply(this,arguments)}return t}()},{key:"reset",value:function e(){this._refs.length=0}},{key:"skip",value:function e(){this.__lexer__.skip()}},{key:"read",value:function(){var e=_asyncToGenerator(_regeneratorRuntime.mark(function e(){var r;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:t.next=2;return this.peek();case 2:r=t.sent;this.skip();return t.abrupt("return",r);case 5:case"end":return t.stop()}},e,this)}));function t(){return e.apply(this,arguments)}return t}()},{key:"match_datum_label",value:function e(t){var r=t.match(/^#([0-9]+)=$/);return r&&r[1]}},{key:"match_datum_ref",value:function e(t){var r=t.match(/^#([0-9]+)#$/);return r&&r[1]}},{key:"is_open",value:function e(t){var r=["(","["].includes(t);if(r){this._state.parentheses++}return r}},{key:"is_close",value:function e(t){var r=[")","]"].includes(t);if(r){this._state.parentheses--}return r}},{key:"read_list",value:function(){var e=_asyncToGenerator(_regeneratorRuntime.mark(function e(){var r,n,i,a,o;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:r=_nil,n=r;case 1:t.next=4;return this.peek();case 4:a=t.sent;if(!(a===eof)){t.next=7;break}return t.abrupt("break",32);case 7:if(!this.is_close(a)){t.next=10;break}this.skip();return t.abrupt("break",32);case 10:if(!(a==="."&&r!==_nil)){t.next=18;break}this.skip();t.next=14;return this._read_object();case 14:n.cdr=t.sent;i=true;t.next=30;break;case 18:if(!i){t.next=22;break}throw new Error("Parser: syntax error more than one element after dot");case 22:t.t0=Pair;t.next=25;return this._read_object();case 25:t.t1=t.sent;t.t2=_nil;o=new t.t0(t.t1,t.t2);if(r===_nil){r=o}else{n.cdr=o}n=o;case 30:t.next=1;break;case 32:return t.abrupt("return",r);case 33:case"end":return t.stop()}},e,this)}));function t(){return e.apply(this,arguments)}return t}()},{key:"read_value",value:function(){var e=_asyncToGenerator(_regeneratorRuntime.mark(function e(){var r;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:t.next=2;return this.read();case 2:r=t.sent;if(!(r===eof)){t.next=5;break}throw new Error("Parser: Expected token eof found");case 5:return t.abrupt("return",parse_argument(r));case 6:case"end":return t.stop()}},e,this)}));function t(){return e.apply(this,arguments)}return t}()},{key:"is_comment",value:function e(t){return t.match(/^;/)||t.match(/^#\|/)&&t.match(/\|#$/)}},{key:"evaluate",value:function e(t){return _evaluate(t,{env:this.__env__,error:function e(t){throw t}})}},{key:"read_object",value:function(){var e=_asyncToGenerator(_regeneratorRuntime.mark(function e(){var r;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:this.reset();t.next=3;return this._read_object();case 3:r=t.sent;if(r instanceof DatumReference){r=r.valueOf()}if(!this._refs.length){t.next=7;break}return t.abrupt("return",this._resolve_object(r));case 7:return t.abrupt("return",r);case 8:case"end":return t.stop()}},e,this)}));function t(){return e.apply(this,arguments)}return t}()},{key:"balanced",value:function e(){return this._state.parentheses===0}},{key:"ballancing_error",value:function e(t,r){var n=this._state.parentheses;var i;if(n<0){i=new Error("Parser: unexpected parenthesis");i.__code__=[r.toString()+")"]}else{i=new Error("Parser: expected parenthesis but eof found");var a=new RegExp("\\){".concat(n,"}$"));i.__code__=[t.toString().replace(a,"")]}throw i}},{key:"_resolve_object",value:function(){var t=_asyncToGenerator(_regeneratorRuntime.mark(function e(r){var n=this;var i;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(!Array.isArray(r)){t.next=2;break}return t.abrupt("return",r.map(function(e){return n._resolve_object(e)}));case 2:if(!is_plain_object(r)){t.next=6;break}i={};Object.keys(r).forEach(function(e){i[e]=n._resolve_object(r[e])});return t.abrupt("return",i);case 6:if(!(r instanceof Pair)){t.next=8;break}return t.abrupt("return",this._resolve_pair(r));case 8:return t.abrupt("return",r);case 9:case"end":return t.stop()}},e,this)}));function e(e){return t.apply(this,arguments)}return e}()},{key:"_resolve_pair",value:function(){var t=_asyncToGenerator(_regeneratorRuntime.mark(function e(r){return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(!(r instanceof Pair)){t.next=15;break}if(!(r.car instanceof DatumReference)){t.next=7;break}t.next=4;return r.car.valueOf();case 4:r.car=t.sent;t.next=8;break;case 7:this._resolve_pair(r.car);case 8:if(!(r.cdr instanceof DatumReference)){t.next=14;break}t.next=11;return r.cdr.valueOf();case 11:r.cdr=t.sent;t.next=15;break;case 14:this._resolve_pair(r.cdr);case 15:return t.abrupt("return",r);case 16:case"end":return t.stop()}},e,this)}));function e(e){return t.apply(this,arguments)}return e}()},{key:"_read_object",value:function(){var e=_asyncToGenerator(_regeneratorRuntime.mark(function e(){var r,n,i,a,o,u,s,c,l,f,_;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:t.next=2;return this.peek();case 2:r=t.sent;if(!(r===eof)){t.next=5;break}return t.abrupt("return",r);case 5:if(!is_special(r)){t.next=38;break}n=specials.get(r);i=is_builtin(r);this.skip();o=is_symbol_extension(r);if(!o){t.next=14;break}t.t0=undefined;t.next=17;break;case 14:t.next=16;return this._read_object();case 16:t.t0=t.sent;case 17:u=t.t0;if(i){t.next=25;break}s=this.__env__.get(n.symbol);if(!(typeof s==="function")){t.next=25;break}if(is_literal(r)){c=[u]}else if(u===_nil){c=[]}else if(u instanceof Pair){c=u.to_array(false)}if(!(c||o)){t.next=24;break}return t.abrupt("return",call_function(s,o?[]:c,{env:this.__env__,dynamic_env:this.__env__,use_dynamic:false}));case 24:throw new Error("Parse Error: Invalid parser extension "+"invocation ".concat(n.symbol));case 25:if(is_literal(r)){a=new Pair(n.symbol,new Pair(u,_nil))}else{a=new Pair(n.symbol,u)}if(!i){t.next=28;break}return t.abrupt("return",a);case 28:if(!(s instanceof Macro)){t.next=37;break}t.next=31;return this.evaluate(a);case 31:l=t.sent;if(!(l instanceof Pair||l instanceof LSymbol)){t.next=34;break}return t.abrupt("return",Pair.fromArray([LSymbol("quote"),l]));case 34:return t.abrupt("return",l);case 37:throw new Error("Parse Error: invalid parser extension: "+n.symbol);case 38:f=this.match_datum_ref(r);if(!(f!==null)){t.next=44;break}this.skip();if(!this._refs[f]){t.next=43;break}return t.abrupt("return",new DatumReference(f,this._refs[f]));case 43:throw new Error("Parse Error: invalid datum label #".concat(f,"#"));case 44:_=this.match_datum_label(r);if(!(_!==null)){t.next=51;break}this.skip();this._refs[_]=this._read_object();return t.abrupt("return",this._refs[_]);case 51:if(!this.is_close(r)){t.next=55;break}this.skip();t.next=61;break;case 55:if(!this.is_open(r)){t.next=60;break}this.skip();return t.abrupt("return",this.read_list());case 60:return t.abrupt("return",this.read_value());case 61:case"end":return t.stop()}},e,this)}));function t(){return e.apply(this,arguments)}return t}()}]);return u}();var DatumReference=function(){function r(e,t){_classCallCheck(this,r);this.name=e;this.data=t}_createClass(r,[{key:"valueOf",value:function e(){return this.data}}]);return r}();function _parse(e,t){return _parse2.apply(this,arguments)}function _parse2(){_parse2=_wrapAsyncGenerator(_regeneratorRuntime.mark(function e(r,n){var i,a,o;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(!n){if(global_env){n=global_env.get("**interaction-environment**",{throwError:false})}else{n=user_env}}i=new Parser(r,{env:n});case 3:t.next=6;return _awaitAsyncGenerator(i.read_object());case 6:o=t.sent;if(!i.balanced()){i.ballancing_error(o,a)}if(!(o===eof)){t.next=10;break}return t.abrupt("break",15);case 10:a=o;t.next=13;return o;case 13:t.next=3;break;case 15:case"end":return t.stop()}},e)}));return _parse2.apply(this,arguments)}function unpromise(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:function(e){return e};var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:null;if(is_promise(e)){var n=e.then(t);if(r===null){return n}else{return n["catch"](r)}}if(e instanceof Array){return unpromise_array(e,t,r)}if(is_plain_object(e)){return unpromise_object(e,t,r)}return t(e)}function unpromise_array(t,r,e){if(t.find(is_promise)){return unpromise(promise_all(t),function(e){if(Object.isFrozen(t)){Object.freeze(e)}return r(e)},e)}return r(t)}function unpromise_object(t,e,r){var i=Object.keys(t);var n=[],a=[];var o=i.length;while(o--){var u=i[o];var s=t[u];n[o]=s;if(is_promise(s)){a.push(s)}}if(a.length){return unpromise(promise_all(n),function(e){var n={};e.forEach(function(e,t){var r=i[t];n[r]=e});if(Object.isFrozen(t)){Object.freeze(n)}return n},r)}return e(t)}function read_only(e,t,r){var n=arguments.length>3&&arguments[3]!==undefined?arguments[3]:{},i=n.hidden,a=i===void 0?false:i;Object.defineProperty(e,t,{value:r,configurable:true,enumerable:!a})}function uniterate_async(e){return _uniterate_async.apply(this,arguments)}function _uniterate_async(){_uniterate_async=_asyncToGenerator(_regeneratorRuntime.mark(function e(r){var n,i,a,o,u,s,c;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:n=[];i=false;a=false;t.prev=3;u=_asyncIterator(r);case 5:t.next=7;return u.next();case 7:if(!(i=!(s=t.sent).done)){t.next=13;break}c=s.value;n.push(c);case 10:i=false;t.next=5;break;case 13:t.next=19;break;case 15:t.prev=15;t.t0=t["catch"](3);a=true;o=t.t0;case 19:t.prev=19;t.prev=20;if(!(i&&u["return"]!=null)){t.next=24;break}t.next=24;return u["return"]();case 24:t.prev=24;if(!a){t.next=27;break}throw o;case 27:return t.finish(24);case 28:return t.finish(19);case 29:return t.abrupt("return",n);case 30:case"end":return t.stop()}},e,null,[[3,15,19,29],[20,,24,28]])}));return _uniterate_async.apply(this,arguments)}function matcher(e,t){if(t instanceof RegExp){return function(e){return String(e).match(t)}}else if(is_function(t)){return t}throw new Error("Invalid matcher")}function doc(e,t,r,n){if(typeof e!=="string"){t=arguments[0];r=arguments[1];n=arguments[2];e=null}if(r){if(n){t.__doc__=r}else{t.__doc__=trim_lines(r)}}if(e){t.__name__=e}else if(t.name&&!is_lambda(t)){t.__name__=t.name}return t}function trim_lines(e){return e.split("\n").map(function(e){return e.trim()}).join("\n")}function previousSexp(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:1;var r=e.length;if(t<=0){throw Error("previousSexp: Invalid argument sexp = ".concat(t))}e:while(t--&&r>=0){var n=1;while(n>0){var i=e[--r];if(!i){break e}if(i==="("||i.token==="("){n--}else if(i===")"||i.token===")"){n++}}r--}return e.slice(r+1)}function lineIndent(e){if(!e||!e.length){return 0}var t=e.length;if(e[t-1].token==="\n"){return 0}while(--t){if(e[t].token==="\n"){var r=(e[t+1]||{}).token;if(r){return r.length}}}return 0}function match(e,t){return l(e,t)===t.length;function l(r,n){function e(e,t){var r=_createForOfIteratorHelper(e),n;try{for(r.s();!(n=r.n()).done;){var i=n.value;var a=l(i,t);if(a!==-1){return a}}}catch(e){r.e(e)}finally{r.f()}return-1}function t(){return r[a]===Symbol["for"]("symbol")&&!is_symbol_string(n[u])}function i(){var e=r[a+1];var t=n[u+1];if(e!==undefined&&t!==undefined){return l([e],[t])}}var a=0;var o={};for(var u=0;u0){continue}}else if(t()){return-1}}else if(r[a]instanceof Array){var c=l(r[a],n.slice(u));if(c===-1||c+u>n.length){return-1}u+=c-1;a++;continue}else{return-1}a++}if(r.length!==a){return-1}return n.length}}function Formatter(e){this.__code__=e.replace(/\r/g,"")}Formatter.defaults={offset:0,indent:2,exceptions:{specials:[/^(?:#:)?(?:define(?:-values|-syntax|-macro|-class|-record-type)?|(?:call-with-(?:input-file|output-file|port))|lambda|let-env|try|catch|when|unless|while|syntax-rules|(let|letrec)(-syntax|\*?-values|\*)?)$/],shift:{1:["&","#"]}}};Formatter.match=match;Formatter.prototype._options=function e(t){var r=Formatter.defaults;if(typeof t==="undefined"){return Object.assign({},r)}var n=t&&t.exceptions||{};var i=n.specials||[];var a=n.shift||{1:[]};return _objectSpread(_objectSpread(_objectSpread({},r),t),{},{exceptions:{specials:[].concat(_toConsumableArray(r.exceptions.specials),_toConsumableArray(i)),shift:_objectSpread(_objectSpread({},a),{},{1:[].concat(_toConsumableArray(r.exceptions.shift[1]),_toConsumableArray(a[1]))})}})};Formatter.prototype.indent=function e(t){var r=tokenize(this.__code__,true);return this._indent(r,t)};Formatter.exception_shift=function(a,e){function t(e){if(!e.length){return false}if(e.indexOf(a)!==-1){return true}else{var t=e.filter(function(e){return e instanceof RegExp});if(!t.length){return false}var r=_createForOfIteratorHelper(t),n;try{for(r.s();!(n=r.n()).done;){var i=n.value;if(a.match(i)){return true}}}catch(e){r.e(e)}finally{r.f()}}return false}if(t(e.exceptions.specials)){return e.indent}var r=e.exceptions.shift;for(var n=0,i=Object.entries(r);n0){n.offset=0}if(a.toString()===t.toString()&&balanced(a)){return n.offset+a[0].col}else if(a.length===1){return n.offset+a[0].col+1}else{var s=-1;if(o){var c=Formatter.exception_shift(o.token,n);if(c!==-1){s=c}}if(s===-1){s=Formatter.exception_shift(a[1].token,n)}if(s!==-1){return n.offset+a[0].col+s}else if(a[0].line3&&a[1].line===a[3].line){if(a[1].token==="("||a[1].token==="["){return n.offset+a[1].col}return n.offset+a[3].col}else if(a[0].line===a[1].line){return n.offset+n.indent+a[0].col}else{var l=a.slice(2);for(var f=0;f")};Ahead.prototype.match=function(e){return e.match(this.pattern)};function Pattern(){for(var e=arguments.length,t=new Array(e),r=0;r")};Formatter.Pattern=Pattern;Formatter.Ahead=Ahead;var p_o=/^[[(]$/;var p_e=/^[\])]$/;var not_p=/[^()[\]]/;var not_close=new Ahead(/[^)\]]/);var glob=Symbol["for"]("*");var sexp_or_atom=new Pattern([p_o,glob,p_e],[not_p],"+");var sexp=new Pattern([p_o,glob,p_e],"+");var symbol=new Pattern([Symbol["for"]("symbol")],"?");var symbols=new Pattern([Symbol["for"]("symbol")],"*");var identifiers=[p_o,symbols,p_e];var let_value=new Pattern([p_o,Symbol["for"]("symbol"),glob,p_e],"+");var syntax_rules=keywords_re("syntax-rules");var def_lambda_re=keywords_re("define","lambda","define-macro","syntax-rules");var non_def=/^(?!.*\b(?:[()[\]]|define(?:-macro)?|let(?:\*|rec|-env|-syntax|)?|lambda|syntax-rules)\b).*$/;var let_re=/^(?:#:)?(let(?:\*|rec|-env|-syntax)?)$/;function keywords_re(){for(var e=arguments.length,t=new Array(e),r=0;r0&&!u[e]){u[e]=previousSexp(o,e)}});var s=_createForOfIteratorHelper(i),c;try{for(s.s();!(c=s.n()).done;){var l=_slicedToArray(c.value,3),f=l[0],_=l[1],p=l[2];_=_.valueOf();var h=_>0?u[_]:o;var d=h.filter(function(e){return e.trim()&&!is_special(e)});var m=r(h);var y=match(f,d);var v=n.slice(a).find(function(e){return e.trim()&&!is_special(e)});if(y&&(p instanceof Ahead&&p.match(v)||!p)){var g=a-m;if(n[g]!=="\n"){if(!n[g].trim()){n[g]="\n"}else{n.splice(g,0,"\n");a++}}a+=m;continue e}}}catch(e){s.e(e)}finally{s.f()}}this.__code__=n.join("");return this};Formatter.prototype._spaces=function(e){return" ".repeat(e)};Formatter.prototype.format=function e(t){var r=this.__code__.replace(/[ \t]*\n[ \t]*/g,"\n ");var n=tokenize(r,true);var i=this._options(t);var a=0;var o=0;for(var u=0;u0){n=Math.floor(t()*r);r--;var i=[e[n],e[r]];e[r]=i[0];e[n]=i[1]}return e}function Nil(){}Nil.prototype.toString=function(){return"()"};Nil.prototype.valueOf=function(){return undefined};Nil.prototype.serialize=function(){return 0};Nil.prototype.to_object=function(){return{}};Nil.prototype.append=function(e){return new Pair(e,_nil)};Nil.prototype.to_array=function(){return[]};var _nil=new Nil;function Pair(e,t){if(typeof this!=="undefined"&&this.constructor!==Pair||typeof this==="undefined"){return new Pair(e,t)}this.car=e;this.cdr=t}function to_array(a,o){return function e(t){typecheck(a,t,["pair","nil"]);if(t===_nil){return[]}var r=[];var n=t;while(true){if(n instanceof Pair){if(n.haveCycles("cdr")){break}var i=n.car;if(o&&i instanceof Pair){i=this.get(a).call(this,i)}r.push(i);n=n.cdr}else if(n===_nil){break}else{throw new Error("".concat(a,": can't convert improper list"))}}return r}}Pair.prototype.flatten=function(){return Pair.fromArray(flatten(this.to_array()))};Pair.prototype.length=function(){var e=0;var t=this;while(true){if(!t||t===_nil||!(t instanceof Pair)||t.haveCycles("cdr")){break}e++;t=t.cdr}return e};Pair.match=function(e,t){if(e instanceof LSymbol){return LSymbol.is(e,t)}else if(e instanceof Pair){return Pair.match(e.car,t)||Pair.match(e.cdr,t)}else if(Array.isArray(e)){return e.some(function(e){return Pair.match(e,t)})}else if(is_plain_object(e)){return Object.values(e).some(function(e){return Pair.match(e,t)})}return false};Pair.prototype.find=function(e){return Pair.match(this,e)};Pair.prototype.clone=function(){var r=arguments.length>0&&arguments[0]!==undefined?arguments[0]:true;var n=new Map;function i(e){if(e instanceof Pair){if(n.has(e)){return n.get(e)}var t=new Pair;n.set(e,t);if(r){t.car=i(e.car)}else{t.car=e.car}t.cdr=i(e.cdr);t[__cycles__]=e[__cycles__];return t}return e}return i(this)};Pair.prototype.last_pair=function(){var e=this;while(true){if(!is_pair(e.cdr)){return e}if(e.haveCycles("cdr")){break}e=e.cdr}};Pair.prototype.to_array=function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:true;var t=[];if(this.car instanceof Pair){if(e){t.push(this.car.to_array())}else{t.push(this.car)}}else{t.push(this.car.valueOf())}if(this.cdr instanceof Pair){t=t.concat(this.cdr.to_array(e))}return t};Pair.fromArray=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:true;var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:false;if(e instanceof Pair||r&&e instanceof Array&&e[__data__]){return e}if(t===false){var n=_nil;for(var i=e.length;i--;){n=new Pair(e[i],n)}return n}if(e.length&&!(e instanceof Array)){e=_toConsumableArray(e)}var a=_nil;var o=e.length;while(o--){var u=e[o];if(u instanceof Array){u=Pair.fromArray(u,t,r)}else if(typeof u==="string"){u=LString(u)}else if(typeof u==="number"&&!Number.isNaN(u)){u=LNumber(u)}a=new Pair(u,a)}return a};Pair.prototype.to_object=function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:false;var t=this;var r={};while(true){if(t instanceof Pair&&t.car instanceof Pair){var n=t.car;var i=n.car;if(i instanceof LSymbol){i=i.__name__}if(i instanceof LString){i=i.valueOf()}var a=n.cdr;if(a instanceof Pair){a=a.to_object(e)}if(is_native(a)){if(!e){a=a.valueOf()}}r[i]=a;t=t.cdr}else{break}}return r};Pair.fromPairs=function(e){return e.reduce(function(e,t){return new Pair(new Pair(new LSymbol(t[0]),t[1]),e)},_nil)};Pair.fromObject=function(t){var e=Object.keys(t).map(function(e){return[e,t[e]]});return Pair.fromPairs(e)};Pair.prototype.reduce=function(e){var t=this;var r=_nil;while(true){if(t!==_nil){r=e(r,t.car);t=t.cdr}else{break}}return r};Pair.prototype.reverse=function(){if(this.haveCycles()){throw new Error("You can't reverse list that have cycles")}var e=this;var t=_nil;while(e!==_nil){var r=e.cdr;e.cdr=t;t=e;e=r}return t};Pair.prototype.transform=function(n){function i(e){if(e instanceof Pair){if(e.replace){delete e.replace;return e}var t=n(e.car);if(t instanceof Pair){t=i(t)}var r=n(e.cdr);if(r instanceof Pair){r=i(r)}return new Pair(t,r)}return e}return i(this)};Pair.prototype.map=function(e){if(typeof this.car!=="undefined"){return new Pair(e(this.car),this.cdr===_nil?_nil:this.cdr.map(e))}else{return _nil}};var repr=new Map;function is_plain_object(e){return e&&_typeof$1(e)==="object"&&e.constructor===Object}var props=Object.getOwnPropertyNames(Array.prototype);var array_methods=[];props.forEach(function(e){array_methods.push(Array[e],Array.prototype[e])});function is_array_method(e){e=unbind(e);return array_methods.includes(e)}function is_lips_function(e){return is_function(e)&&(is_lambda(e)||e.__doc__)}function user_repr(r){var e=r.constructor||Object;var n=is_plain_object(r);var i=is_function(r[Symbol.asyncIterator])||is_function(r[Symbol.iterator]);var a;if(repr.has(e)){a=repr.get(e)}else{repr.forEach(function(e,t){t=unbind(t);if(r.constructor===t&&(t===Object&&n&&!i||t!==Object)){a=e}})}return a}var str_mapping=new Map;[[true,"#t"],[false,"#f"],[null,"null"],[undefined,"#"]].forEach(function(e){var t=_slicedToArray(e,2),r=t[0],n=t[1];str_mapping.set(r,n)});function symbolize(r){if(r&&_typeof$1(r)==="object"){var n={};var e=Object.getOwnPropertySymbols(r);e.forEach(function(e){var t=e.toString().replace(/Symbol\(([^)]+)\)/,"$1");n[t]=toString(r[e])});var t=Object.getOwnPropertyNames(r);t.forEach(function(e){var t=r[e];if(t&&_typeof$1(t)==="object"&&t.constructor===Object){n[e]=symbolize(t)}else{n[e]=toString(t)}});return n}return r}function get_props(e){return Object.keys(e).concat(Object.getOwnPropertySymbols(e))}function has_own_function(e,t){return e.hasOwnProperty(t)&&is_function(e.toString)}function function_to_string(e){if(is_native_function(e)){return"#"}var t=e.prototype&&e.prototype.constructor;if(is_function(t)&&is_lambda(t)){if(e[__class__]&&t.hasOwnProperty("__name__")){var r=t.__name__;if(LString.isString(r)){r=r.toString();return"#")}return"#"}}if(e.hasOwnProperty("__name__")){var n=e.__name__;if(_typeof$1(n)==="symbol"){n=symbol_to_string(n)}if(typeof n==="string"){return"#")}}if(has_own_function(e,"toString")){return e.toString()}else if(e.name&&!is_lambda(e)){return"#")}else{return"#"}}var instances=new Map;[[Error,function(e){return e.message}],[Pair,function(e,t){var r=t.quote,n=t.skip_cycles,i=t.pair_args;if(!n){e.markCycles()}return e.toString.apply(e,[r].concat(_toConsumableArray(i)))}],[LCharacter,function(e,t){var r=t.quote;if(r){return e.toString()}return e.valueOf()}],[LString,function(e,t){var r=t.quote;e=e.toString();if(r){return JSON.stringify(e).replace(/\\n/g,"\n")}return e}],[RegExp,function(e){return"#"+e.toString()}]].forEach(function(e){var t=_slicedToArray(e,2),r=t[0],n=t[1];instances.set(r,n)});var native_types=[LSymbol,LNumber,Macro,Values,InputPort,OutputPort,Environment,QuotedPromise];function toString(e,t,r){if(typeof jQuery!=="undefined"&&e instanceof jQuery.fn.init){return"#"}if(str_mapping.has(e)){return str_mapping.get(e)}if(is_prototype(e)){return"#"}if(e){var n=e.constructor;if(instances.has(n)){for(var i=arguments.length,a=new Array(i>3?i-3:0),o=3;o"}if(e===null){return"null"}if(_typeof$1(e)==="object"){var l=e.constructor;if(!l){l=Object}var f;if(typeof l.__class__==="string"){f=l.__class__}else{var _=user_repr(e);if(_){if(is_function(_)){return _(e,t)}else{throw new Error("toString: Invalid repr value")}}f=l.name}if(is_function(e.toString)&&is_lambda(e.toString)){return e.toString().valueOf()}if(type(e)==="instance"){if(is_lambda(l)&&l.__name__){f=l.__name__.valueOf()}else if(!is_native_function(l)){f="instance"}}if(is_iterator(e,Symbol.iterator)){if(f){return"#")}return"#"}if(is_iterator(e,Symbol.asyncIterator)){if(f){return"#")}return"#"}if(f!==""){return"#<"+f+">"}return"#"}if(typeof e!=="string"){return e.toString()}return e}function is_prototype(e){return e&&_typeof$1(e)==="object"&&e.hasOwnProperty&&e.hasOwnProperty("constructor")&&typeof e.constructor==="function"&&e.constructor.prototype===e}Pair.prototype.markCycles=function(){markCycles(this);return this};Pair.prototype.haveCycles=function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:null;if(!e){return this.haveCycles("car")||this.haveCycles("cdr")}return!!(this[__cycles__]&&this[__cycles__][e])};function markCycles(e){var t=[];var i=[];var a=[];function o(e){if(!t.includes(e)){t.push(e)}}function u(e,t,r,n){if(r instanceof Pair){if(n.includes(r)){if(!a.includes(r)){a.push(r)}if(!e[__cycles__]){e[__cycles__]={}}e[__cycles__][t]=r;if(!i.includes(e)){i.push(e)}return true}}}var s=trampoline(function e(t,r){if(t instanceof Pair){delete t.ref;delete t[__cycles__];o(t);r.push(t);var n=u(t,"car",t.car,r);var i=u(t,"cdr",t.cdr,r);if(!n){s(t.car,r.slice())}if(!i){return new Thunk(function(){return e(t.cdr,r.slice())})}}});function r(e,t){if(e[__cycles__][t]instanceof Pair){var r=n.indexOf(e[__cycles__][t]);e[__cycles__][t]="#".concat(r,"#")}}s(e,[]);var n=t.filter(function(e){return a.includes(e)});n.forEach(function(e,t){e[__ref__]="#".concat(t,"=")});i.forEach(function(e){r(e,"car");r(e,"cdr")})}Pair.prototype.toString=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},r=t.nested,n=r===void 0?false:r;var i=[];if(this[__ref__]){i.push(this[__ref__]+"(")}else if(!n){i.push("(")}var a;if(this[__cycles__]&&this[__cycles__].car){a=this[__cycles__].car}else{a=toString(this.car,e,true)}if(a!==undefined){i.push(a)}if(this.cdr instanceof Pair){if(this[__cycles__]&&this[__cycles__].cdr){i.push(" . ");i.push(this[__cycles__].cdr)}else{if(this.cdr[__ref__]){i.push(" . ")}else{i.push(" ")}var o=this.cdr.toString(e,{nested:true});i.push(o)}}else if(this.cdr!==_nil){i=i.concat([" . ",toString(this.cdr,e,true)])}if(!n||this[__ref__]){i.push(")")}return i.join("")};Pair.prototype.set=function(e,t){this[e]=t;if(t instanceof Pair){this.markCycles()}};Pair.prototype.append=function(e){if(e instanceof Array){return this.append(Pair.fromArray(e))}var t=this;if(t.car===undefined){if(e instanceof Pair){this.car=e.car;this.cdr=e.cdr}else{this.car=e}}else if(e!==_nil){while(true){if(t instanceof Pair&&t.cdr!==_nil){t=t.cdr}else{break}}t.cdr=e}return this};Pair.prototype.serialize=function(){return[this.car,this.cdr]};Pair.prototype[Symbol.iterator]=function(){var r=this;return{next:function e(){var t=r;r=t.cdr;if(t===_nil){return{value:undefined,done:true}}else{return{value:t.car,done:false}}}}};function abs(e){return e<0?-e:e}function seq_compare(e,t){var r=_toArray(t),n=r[0],i=r.slice(1);while(i.length>0){var a=i,o=_slicedToArray(a,1),u=o[0];if(!e(n,u)){return false}var s=i;var c=_toArray(s);n=c[0];i=c.slice(1)}return true}function equal(e,t){if(is_function(e)){return is_function(t)&&unbind(e)===unbind(t)}else if(e instanceof LNumber){if(!(t instanceof LNumber)){return false}var r;if(e.__type__===t.__type__){if(e.__type__==="complex"){r=e.__im__.__type__===t.__im__.__type__&&e.__re__.__type__===t.__re__.__type__}else{r=true}if(r&&e.cmp(t)===0){if(e.valueOf()===0){return Object.is(e.valueOf(),t.valueOf())}return true}}return false}else if(typeof e==="number"){if(typeof t!=="number"){return false}if(Number.isNaN(e)){return Number.isNaN(t)}if(e===Number.NEGATIVE_INFINITY){return t===Number.NEGATIVE_INFINITY}if(e===Number.POSITIVE_INFINITY){return t===Number.POSITIVE_INFINITY}return equal(LNumber(e),LNumber(t))}else if(e instanceof LCharacter){if(!(t instanceof LCharacter)){return false}return e.__char__===t.__char__}else{return e===t}}function same_atom(e,t){if(type(e)!==type(t)){return false}if(!is_atom(e)){return false}if(e instanceof RegExp){return e.source===t.source}if(e instanceof LString){return e.valueOf()===t.valueOf()}return equal(e,t)}function is_atom(e){return e instanceof LSymbol||LString.isString(e)||e===_nil||e===null||e instanceof LCharacter||e instanceof LNumber||e===true||e===false}var truncate=function(){if(Math.trunc){return Math.trunc}else{return function(e){if(e===0){return 0}else if(e<0){return Math.ceil(e)}else{return Math.floor(e)}}}}();function Macro(e,t,r,n){if(typeof this!=="undefined"&&this.constructor!==Macro||typeof this==="undefined"){return new Macro(e,t)}typecheck("Macro",e,"string",1);typecheck("Macro",t,"function",2);if(r){if(n){this.__doc__=r}else{this.__doc__=trim_lines(r)}}this.__name__=e;this.__fn__=t}Macro.defmacro=function(e,t,r,n){var i=new Macro(e,t,r,n);i.__defmacro__=true;return i};Macro.prototype.invoke=function(e,t,r){var n=t.env,i=_objectWithoutProperties(t,_excluded2);var a=_objectSpread(_objectSpread({},i),{},{macro_expand:r});var o=this.__fn__.call(n,e,a,this.__name__);return o};Macro.prototype.toString=function(){return"#")};var macro="define-macro";var recur_guard=-1e4;function macro_expand(c){return function(){var r=_asyncToGenerator(_regeneratorRuntime.mark(function e(r,v){var a,g,n,i,o,b,w,D,x,E,L,A,u,S,s;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:s=function e(){s=_asyncToGenerator(_regeneratorRuntime.mark(function e(r,n,i){var a,o,u,s,c,l,f,_,p,h,d,m,y;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(!(r instanceof Pair&&r.car instanceof LSymbol)){t.next=50;break}if(!r[__data__]){t.next=3;break}return t.abrupt("return",r);case 3:a=r.car.valueOf();o=i.get(r.car,{throwError:false});u=b(r.car);s=u||w(o,r)||D(o);if(!(s&&r.cdr.car instanceof Pair)){t.next=28;break}if(!u){t.next=15;break}g=E(r.cdr.car);t.next=12;return A(r.cdr.car,n);case 12:c=t.sent;t.next=17;break;case 15:g=x(r.cdr.car);c=r.cdr.car;case 17:t.t0=Pair;t.t1=r.car;t.t2=Pair;t.t3=c;t.next=23;return S(r.cdr.cdr,n,i);case 23:t.t4=t.sent;t.t5=new t.t2(t.t3,t.t4);return t.abrupt("return",new t.t0(t.t1,t.t5));case 28:if(!L(a,o)){t.next=50;break}l=o instanceof Syntax?r:r.cdr;t.next=32;return o.invoke(l,_objectSpread(_objectSpread({},v),{},{env:i}),true);case 32:f=t.sent;if(!(o instanceof Syntax)){t.next=41;break}_=f,p=_.expr,h=_.scope;if(!(p instanceof Pair)){t.next=40;break}if(!(n!==-1&&n<=1||n")}return"#"};var SyntaxParameter=_createClass(function e(t){_classCallCheck(this,e);read_only(this,"_syntax",t,{hidden:true});read_only(this._syntax,"_param",true,{hidden:true})});Syntax.Parameter=SyntaxParameter;function extract_patterns(e,t,I,N){var r=arguments.length>4&&arguments[4]!==undefined?arguments[4]:{};var j={"...":{symbols:{},lists:[]},symbols:{}};var R=r.expansion,T=r.define;log(I);function $(t,e){var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:[];var n=arguments.length>3&&arguments[3]!==undefined?arguments[3]:false;log({code:e,pattern:t});if(is_atom(t)&&!(t instanceof LSymbol)){return same_atom(t,e)}if(t instanceof LSymbol&&I.includes(t.literal())){if(!LSymbol.is(e,t)){return false}var i=R.ref(t);return!i||i===T||i===global_env}if(Array.isArray(t)&&Array.isArray(e)){log("<<< a 1");if(t.length===0&&e.length===0){return true}if(LSymbol.is(t[1],N)){if(t[0]instanceof LSymbol){var a=t[0].valueOf();log("<<< a 2 "+n);if(n){var o=e.length-2;var u=o>0?e.slice(0,o):e;var s=Pair.fromArray(u,false);if(!j["..."].symbols[a]){j["..."].symbols[a]=new Pair(s,_nil)}else{j["..."].symbols[a].append(new Pair(s,_nil))}}else{j["..."].symbols[a]=Pair.fromArray(e,false)}}else if(Array.isArray(t[0])){log("<<< a 3");var c=_toConsumableArray(r);if(!e.every(function(e){return $(t[0],e,c,true)})){return false}}if(t.length>2){var l=t.slice(2);return $(l,e.slice(-l.length),r,n)}return true}var f=$(t[0],e[0],r,n);log({first:f,pattern:t[0],code:e[0]});var _=$(t.slice(1),e.slice(1),r,n);log({first:f,rest:_});return f&&_}if(t instanceof Pair&&t.car instanceof Pair&&t.car.cdr instanceof Pair&&LSymbol.is(t.car.cdr.car,N)){log(">> 0");if(e===_nil){log({pattern:t});if(t.car.car instanceof LSymbol){var p=t.car.car.valueOf();if(j["..."].symbols[p]){throw new Error("syntax: named ellipsis can only "+"appear onces")}j["..."].symbols[p]=e}}}if(t instanceof Pair&&t.cdr instanceof Pair&&LSymbol.is(t.cdr.car,N)){if(t.cdr.cdr!==_nil){if(t.cdr.cdr instanceof Pair){var h=t.cdr.cdr.length();if(!is_pair(e)){return false}var d=e.length();var m=e;while(d-1>h){m=m.cdr;d--}var y=m.cdr;m.cdr=_nil;if(!$(t.cdr.cdr,y,r,n)){return false}}}if(t.car instanceof LSymbol){var v=t.car.__name__;if(j["..."].symbols[v]&&!r.includes(v)&&!n){throw new Error("syntax: named ellipsis can only appear onces")}log(">> 1");if(e===_nil){log(">> 2");if(n){log("NIL");j["..."].symbols[v]=_nil}else{log("NULL");j["..."].symbols[v]=null}}else if(e instanceof Pair&&(e.car instanceof Pair||e.car===_nil)){log(">> 3 "+n);if(n){if(j["..."].symbols[v]){var g=j["..."].symbols[v];if(g===_nil){g=new Pair(_nil,new Pair(e,_nil))}else{g=g.append(new Pair(e,_nil))}j["..."].symbols[v]=g}else{j["..."].symbols[v]=new Pair(e,_nil)}}else{log(">> 4");j["..."].symbols[v]=new Pair(e,_nil)}}else{log(">> 6");if(e instanceof Pair){if(!(e.cdr instanceof Pair)&&e.cdr!==_nil){log(">> 7 (b)");if(t.cdr.cdr===_nil){return false}else if(!j["..."].symbols[v]){j["..."].symbols[v]=new Pair(e.car,_nil);return $(t.cdr.cdr,e.cdr)}}var b=e.last_pair();if(b.cdr!==_nil){if(t.cdr.cdr===_nil){return false}else{var w=e.clone();w.last_pair().cdr=_nil;j["..."].symbols[v]=w;return $(t.cdr.cdr,b.cdr)}}log(">> 7 "+n);r.push(v);if(!j["..."].symbols[v]){j["..."].symbols[v]=new Pair(e,_nil)}else{var D=j["..."].symbols[v];j["..."].symbols[v]=D.append(new Pair(e,_nil))}log({IIIIII:j["..."].symbols[v]})}else if(t.car instanceof LSymbol&&t.cdr instanceof Pair&&LSymbol.is(t.cdr.car,N)){log(">> 8");j["..."].symbols[v]=null;return $(t.cdr.cdr,e)}else{log(">> 9");return false}}return true}else if(t.car instanceof Pair){var x=_toConsumableArray(r);if(e===_nil){log(">> 10");j["..."].lists.push(_nil);return true}log(">> 11");var E=e;while(E instanceof Pair){if(!$(t.car,E.car,x,true)){return false}E=E.cdr}return true}if(Array.isArray(t.car)){var x=_toConsumableArray(r);var L=e;while(L instanceof Pair){if(!$(t.car,L.car,x,true)){return false}L=L.cdr}return true}return false}if(t instanceof LSymbol){if(LSymbol.is(t,N)){throw new Error("syntax: invalid usage of ellipsis")}log(">> 12");var A=t.__name__;if(I.includes(A)){return true}if(n){var S,F;log(j["..."].symbols[A]);(F=(S=j["..."].symbols)[A])!==null&&F!==void 0?F:S[A]=[];j["..."].symbols[A].push(e)}else{j.symbols[A]=e}return true}if(t instanceof Pair&&e instanceof Pair){log(">> 13");log({a:13,code:e,pattern:t});if(e.cdr===_nil){var k=t.car instanceof LSymbol&&t.cdr instanceof LSymbol;if(k){if(!$(t.car,e.car,r,n)){return false}log(">> 14");var P=t.cdr.valueOf();if(!(P in j.symbols)){j.symbols[P]=_nil}P=t.car.valueOf();if(!(P in j.symbols)){j.symbols[P]=e.car}return true}}log({pattern:t,code:e});if(t.cdr instanceof Pair&&t.cdr.cdr instanceof Pair&&t.cdr.car instanceof LSymbol&&LSymbol.is(t.cdr.cdr.car,N)&&t.cdr.cdr.cdr instanceof Pair&&!LSymbol.is(t.cdr.cdr.cdr.car,N)&&$(t.car,e.car,r,n)&&$(t.cdr.cdr.cdr,e.cdr,r,n)){var C=t.cdr.car.__name__;log({pattern:t,code:e,name:C});if(I.includes(C)){return true}j["..."].symbols[C]=null;return true}log("recur");log({pattern:t,code:e});var B=$(t.car,e.car,r,n);log({car:B,pattern:t.car,code:e.car});var O=$(t.cdr,e.cdr,r,n);log({car:B,cdr:O});if(B&&O){return true}}else if(t===_nil&&(e===_nil||e===undefined)){return true}else if(t.car instanceof Pair&&LSymbol.is(t.car.car,N)){throw new Error("syntax: invalid usage of ellipsis")}else{return false}}if($(e,t)){return j}}function clear_gensyms(e,i){function a(t){if(t instanceof Pair){if(!i.length){return t}var e=a(t.car);var r=a(t.cdr);return new Pair(e,r)}else if(t instanceof LSymbol){var n=i.find(function(e){return e.gensym===t});if(n){return LSymbol(n.name)}return t}else{return t}}return a(e)}function transform_syntax(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};var B=e.bindings,t=e.expr,O=e.scope,o=e.symbols,l=e.names,I=e.ellipsis;var f={};function u(e){if(e instanceof LSymbol){return true}return["string","symbol"].includes(_typeof$1(e))}function N(e){if(!u(e)){var t=type(e);throw new Error("syntax: internal error, need symbol got ".concat(t))}var r=e.valueOf();if(r===I){throw new Error("syntax: internal error, ellipis not transformed")}var n=_typeof$1(r);if(["string","symbol"].includes(n)){if(r in B.symbols){return B.symbols[r]}else if(n==="string"&&r.match(/\./)){var i=r.split(".");var a=i[0];if(a in B.symbols){return Pair.fromArray([LSymbol("."),B.symbols[a]].concat(i.slice(1).map(function(e){return LString(e)})))}}}if(o.includes(r)){return e}return s(r,e)}function s(e,t){if(!f[e]){var r=O.ref(e);if(_typeof$1(e)==="symbol"&&!r){e=t.literal()}if(f[e]){return f[e]}var n=gensym(e);if(r){var i=O.get(e);O.set(n,i)}else{var a=O.get(e,{throwError:false});if(typeof a!=="undefined"){O.set(n,a)}}l.push({name:e,gensym:n});f[e]=n;if(typeof e==="string"&&e.match(/\./)){var o=e.split(".").filter(Boolean),u=_toArray(o),s=u[0],c=u.slice(1);if(f[s]){hidden_prop(n,"__object__",[f[s]].concat(_toConsumableArray(c)))}}}return f[e]}function j(e,t,r){var n=arguments.length>3&&arguments[3]!==undefined?arguments[3]:function(){};var i=r.nested;log({bindings:t,expr:e});if(Array.isArray(e)&&!e.length){return e}if(e instanceof LSymbol){var a=e.valueOf();if(is_gensym(e)&&!t[a]);log("[t 1");if(t[a]){if(t[a]instanceof Pair){var o=t[a],u=o.car,s=o.cdr;if(i){var c=u.car,l=u.cdr;if(l!==_nil){n(a,new Pair(l,_nil))}return c}if(s!==_nil){n(a,s)}return u}else if(t[a]instanceof Array){n(a,t[a].slice(1));return t[a][0]}}return N(e)}var f=Array.isArray(e);if(e instanceof Pair||f){var _=f?e[0]:e.car;var p=f?e[1]:is_pair(e.cdr)&&e.cdr.car;if(_ instanceof LSymbol&&LSymbol.is(p,I)){f?e.slice(2):e.cdr.cdr;log("[t 2");var h=_.valueOf();var d=t[h];if(d===null){return}else if(d){log({name:h,binding:t[h]});if(d instanceof Pair){log("[t 2 Pair "+i);var m=d.car,y=d.cdr;var v=f?e.slice(2):e.cdr.cdr;if(i){if(y!==_nil){log("|| next 1");n(h,y)}if(f&&v.length||v!==_nil&&!f){var g=j(v,t,r,n);if(f){return m.concat(g)}else if(is_pair(m)){return m.append(g)}else{log("UNKNOWN")}}return m}else if(m instanceof Pair){if(m.cdr!==_nil){log("|| next 2");n(h,new Pair(m.cdr,y))}return m.car}else if(y===_nil){return m}else{var b=e.last_pair();if(b.cdr instanceof LSymbol){log("|| next 3");n(h,d.last_pair());return m}}}else if(d instanceof Array){log("[t 2 Array "+i);if(i){n(h,d.slice(1));return Pair.fromArray(d)}else{var w=d.slice(1);if(w.length){n(h,w)}return d[0]}}else{return d}}}log("[t 3 recur ",e);var D=f?e.slice(1):e.cdr;var x=j(_,t,r,n);var E=j(D,t,r,n);log({head:x,rest:E});if(f){return[x].concat(E)}return new Pair(x,E)}return e}function R(t,r){var e=Object.values(t);var n=Object.getOwnPropertySymbols(t);if(n.length){e.push.apply(e,_toConsumableArray(n.map(function(e){return t[e]})))}return e.length&&e.every(function(e){if(e===null){return!r}return e instanceof Pair||e===_nil||e instanceof Array&&e.length})}function T(e){return Object.keys(e).concat(Object.getOwnPropertySymbols(e))}function $(i){var e=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},t=e.disabled;log("traverse>> ",i);var a=Array.isArray(i);if(a&&i.length===0){return i}if(i instanceof Pair||a){var r=a?i[0]:i.car;var n,o;if(a){n=i[1];o=i.slice(2)}else if(is_pair(i.cdr)){n=i.cdr.car;o=i.cdr.cdr}log({first:r,second:n,rest_second:o});if(!t&&is_pair(r)&&LSymbol.is(r.car,I)){return $(r.cdr,{disabled:true})}if(n&&LSymbol.is(n,I)&&!t){log(">> 1");var u=B["..."].symbols;var s=Object.values(u);if(s.length&&s.every(function(e){return e===null})){log(">>> 1 (a)");return $(o,{disabled:t})}var c=T(u);var l=r instanceof LSymbol&&LSymbol.is(o.car,I);if(is_pair(r)||l){log(">>> 1 (b)");if(B["..."].lists[0]===_nil){if(!l){return $(o,{disabled:t})}log(o);return _nil}var f=r;if(l){log(">>> 1 (c)");f=new Pair(r,new Pair(n,_nil))}log(">> 2");var _;if(c.length){log(">> 2 (a)");var p=_objectSpread({},u);_=a?[]:_nil;var h=function e(){log({bind:p});if(!R(p)){return 1}var n={};var t=function e(t,r){n[t]=r};var r=j(f,p,{nested:true},t);if(r!==undefined){if(l){if(a){if(Array.isArray(r)){var i;(i=_).push.apply(i,_toConsumableArray(r))}else{log("ZONK {1}")}}else{if(_===_nil){_=r}else{_=_.append(r)}}}else if(a){_.push(r)}else{_=new Pair(r,_)}}p=n};while(true){if(h())break}if(_!==_nil&&!l&&!a){_=_.reverse()}if(a){if(o){log({rest_second:o,expr:i});var d=$(o,{disabled:t});return _.concat(d)}return _}if(i.cdr.cdr!==_nil&&!LSymbol.is(i.cdr.cdr.car,I)){var m=$(i.cdr.cdr,{disabled:t});return _.append(m)}return _}else{log(">> 3");var y=j(r,u,{nested:true});if(y){return new Pair(y,_nil)}return _nil}}else if(r instanceof LSymbol){log(">> 4");if(LSymbol.is(o.car,I)){log(">> 4 (a)")}else{log(">> 4 (b)")}var v=r.__name__;var g=_defineProperty({},v,u[v]);log({bind:g});var b=u[v]===null;var w=a?[]:_nil;var D=function e(){if(!R(g,true)){log({bind:g});return 1}var n={};var t=function e(t,r){n[t]=r};var r=j(i,g,{nested:false},t);log({value:r});if(typeof r!=="undefined"){if(a){w.push(r)}else{w=new Pair(r,w)}}g=n};while(true){if(D())break}if(w!==_nil&&!a){w=w.reverse()}if(i.cdr instanceof Pair){if(i.cdr.cdr instanceof Pair||i.cdr.cdr instanceof LSymbol){var x=$(i.cdr.cdr,{disabled:t});log({node:x});if(b){return x}if(w===_nil){w=x}else{w.append(x)}log({result:w,node:x})}}log("<<<< 2");return w}}var E=$(r,{disabled:t});var L;var A;if(r instanceof LSymbol){var S=O.get(r,{throwError:false});A=S instanceof Macro&&S.__name__==="syntax-rules"}if(A){if(i.cdr.car instanceof LSymbol){L=new Pair($(i.cdr.car,{disabled:t}),new Pair(i.cdr.cdr.car,$(i.cdr.cdr.cdr,{disabled:t})))}else{L=new Pair(i.cdr.car,$(i.cdr.cdr,{disabled:t}))}log("REST >>>> ",L)}else{L=$(i.cdr,{disabled:t})}log({a:true,car:toString(i.car),cdr:toString(i.cdr),head:toString(E),rest:toString(L)});return new Pair(E,L)}if(i instanceof LSymbol){if(t&&LSymbol.is(i,I)){return i}var F=Object.keys(B["..."].symbols);var k=i.literal();if(F.includes(k)){var P="missing ellipsis symbol next to name `".concat(k,"'");throw new Error("syntax-rules: ".concat(P))}var C=N(i);if(typeof C!=="undefined"){return C}}return i}return $(t,{})}function is_null(e){return is_undef(e)||e===_nil||e===null}function is_function(e){return typeof e==="function"&&typeof e.bind==="function"}function is_continuation(e){return e instanceof Continuation}function is_context(e){return e instanceof LambdaContext}function is_parameter(e){return e instanceof Parameter}function is_pair(e){return e instanceof Pair}function is_env(e){return e instanceof Environment}function is_callable(e){return is_function(e)||is_continuation(e)||is_parameter(e)||is_macro(e)}function is_macro(e){return e instanceof Macro||e instanceof SyntaxParameter}function is_promise(e){if(e instanceof QuotedPromise){return false}if(e instanceof Promise){return true}return!!e&&is_function(e.then)}function is_undef(e){return typeof e==="undefined"}function is_iterator(e,t){if(has_own_symbol(e,t)||has_own_symbol(e.__proto__,t)){return is_function(e[t])}}function is_instance(e){if(!e){return false}if(_typeof$1(e)!=="object"){return false}if(e.__instance__){e.__instance__=false;return e.__instance__}return false}function self_evaluated(e){var t=_typeof$1(e);return["string","function"].includes(t)||_typeof$1(e)==="symbol"||e instanceof QuotedPromise||e instanceof LSymbol||e instanceof LNumber||e instanceof LString||e instanceof RegExp}function is_native(e){return e instanceof LNumber||e instanceof LString||e instanceof LCharacter}function has_own_symbol(e,t){if(e===null){return false}return _typeof$1(e)==="object"&&t in Object.getOwnPropertySymbols(e)}function box(e){switch(_typeof$1(e)){case"string":return LString(e);case"bigint":return LNumber(e);case"number":if(Number.isNaN(e)){return nan}else{return LNumber(e)}}return e}function map_object(r,n){var e=Object.getOwnPropertyNames(r);var t=Object.getOwnPropertySymbols(r);var i={};e.concat(t).forEach(function(e){var t=n(r[e]);i[e]=t});return i}function unbox(t){var e=[LString,LNumber].some(function(e){return t instanceof e});if(e){return t.valueOf()}if(t instanceof Array){return t.map(unbox)}if(t instanceof QuotedPromise){delete t.then}if(is_plain_object(t)){return map_object(t,unbox)}return t}function patch_value(e,t){if(e instanceof Pair){e.markCycles();return quote(e)}if(is_function(e)){if(t){return bind(e,t)}}return box(e)}function unbind(e){if(is_bound(e)){return e[__fn__]}return e}function bind(e,t){if(e[Symbol["for"]("__bound__")]){return e}var r=e.bind(t);var n=Object.getOwnPropertyNames(e);var i=_createForOfIteratorHelper(n),a;try{for(i.s();!(a=i.n()).done;){var o=a.value;if(filter_fn_names(o)){try{r[o]=e[o]}catch(e){}}}}catch(e){i.e(e)}finally{i.f()}hidden_prop(r,"__fn__",e);hidden_prop(r,"__context__",t);hidden_prop(r,"__bound__",true);if(is_native_function(e)){hidden_prop(r,"__native__",true)}if(is_plain_object(t)&&is_lambda(e)){hidden_prop(r,"__method__",true)}r.valueOf=function(){return e};return r}function is_object_bound(e){return is_bound(e)&&e[Symbol["for"]("__context__")]===Object}function is_bound(e){return!!(is_function(e)&&e[__fn__])}function lips_context(e){if(is_function(e)){var t=e[__context__];if(t&&(t===lips||t.constructor&&t.constructor.__class__)){return true}}return false}function is_port(e){return e instanceof InputPort||e instanceof OutputPort}function is_port_method(e){if(is_function(e)){if(is_port(e[__context__])){return true}}return false}var __context__=Symbol["for"]("__context__");var __fn__=Symbol["for"]("__fn__");var __data__=Symbol["for"]("__data__");var __ref__=Symbol["for"]("__ref__");var __cycles__=Symbol["for"]("__cycles__");var __class__=Symbol["for"]("__class__");var __method__=Symbol["for"]("__method__");var __prototype__=Symbol["for"]("__prototype__");var __lambda__=Symbol["for"]("__lambda__");var exluded_names=["name","length","caller","callee","arguments","prototype"];function filter_fn_names(e){return!exluded_names.includes(e)}function hidden_prop(e,t,r){Object.defineProperty(e,Symbol["for"](t),{get:function e(){return r},set:function e(){},configurable:false,enumerable:false})}function set_fn_length(t,r){try{Object.defineProperty(t,"length",{get:function e(){return r}});return t}catch(e){var n=new Array(r).fill(0).map(function(e,t){return"a"+t}).join(",");var i=new Function("f","return function(".concat(n,") {\n return f.apply(this, arguments);\n };"));return i(t)}}function is_lambda(e){return e&&e[__lambda__]}function is_method(e){return e&&e[__method__]}function is_raw_lambda(e){return is_lambda(e)&&!e[__prototype__]&&!is_method(e)&&!is_port_method(e)}function is_native_function(e){var t=Symbol["for"]("__native__");return is_function(e)&&e.toString().match(/\{\s*\[native code\]\s*\}/)&&(e.name.match(/^bound /)&&e[t]===true||!e.name.match(/^bound /)&&!e[t])}function let_macro(e){var b;switch(e){case Symbol["for"]("letrec"):b="letrec";break;case Symbol["for"]("let"):b="let";break;case Symbol["for"]("let*"):b="let*";break;default:throw new Error("Invalid let_macro value")}return Macro.defmacro(b,function(t,e){var l=e.dynamic_env;var f=e.error,r=e.macro_expand,_=e.use_dynamic;var p;if(t.car instanceof LSymbol){if(!(t.cdr.car instanceof Pair||t.cdr.car===_nil)){throw new Error("let require list of pairs")}var n;if(t.cdr.car===_nil){p=_nil;n=_nil}else{n=t.cdr.car.map(function(e){return e.car});p=t.cdr.car.map(function(e){return e.cdr.car})}return Pair.fromArray([LSymbol("letrec"),[[t.car,Pair(LSymbol("lambda"),Pair(n,t.cdr.cdr))]],Pair(t.car,p)])}else if(r){return}var h=this;p=global_env.get("list->array")(t.car);var d=h.inherit(b);var m,y;if(b==="let*"){y=d}else if(b==="let"){m=[]}var v=0;function g(){var e=new Pair(new LSymbol("begin"),t.cdr);return _evaluate(e,{env:d,dynamic_env:d,use_dynamic:_,error:f})}return function t(){var r=p[v++];l=b==="let*"?d:h;if(!r){if(m&&m.length){var e=m.map(function(e){return e.value});var n=e.filter(is_promise);if(n.length){return promise_all(e).then(function(e){for(var t=0,r=e.length;t1&&arguments[1]!==undefined?arguments[1]:{},r=t.use_dynamic,n=t.error;var i=this;var a=this;var o=[];var u=e;while(u instanceof Pair){o.push(_evaluate(u.car,{env:i,dynamic_env:a,use_dynamic:r,error:n}));u=u.cdr}var s=o.filter(is_promise).length;if(s){return promise_all(o).then(c.bind(this))}else{return c.call(this,o)}})}function guard_math_call(e){for(var t=arguments.length,r=new Array(t>1?t-1:0),n=1;n2?n-2:0),a=2;a1&&arguments[1]!==undefined?arguments[1]:null;return function(){for(var e=arguments.length,t=new Array(e),r=0;r1?e-1:0),r=1;r=o){return a.apply(this,n)}else{return i}}return i.apply(this,arguments)}}function limit(n,i){typecheck("limit",i,"function",2);return function(){for(var e=arguments.length,t=new Array(e),r=0;r1){e=e.toLowerCase();if(LCharacter.__names__[e]){t=e;e=LCharacter.__names__[e]}else{throw new Error("Internal: Unknown named character")}}else{t=LCharacter.__rev_names__[e]}Object.defineProperty(this,"__char__",{value:e,enumerable:true});if(t){Object.defineProperty(this,"__name__",{value:t,enumerable:true})}}LCharacter.__names__=characters;LCharacter.__rev_names__={};Object.keys(LCharacter.__names__).forEach(function(e){var t=LCharacter.__names__[e];LCharacter.__rev_names__[t]=e});LCharacter.prototype.toUpperCase=function(){return LCharacter(this.__char__.toUpperCase())};LCharacter.prototype.toLowerCase=function(){return LCharacter(this.__char__.toLowerCase())};LCharacter.prototype.toString=function(){return"#\\"+(this.__name__||this.__char__)};LCharacter.prototype.valueOf=LCharacter.prototype.serialize=function(){return this.__char__};function LString(e){if(typeof this!=="undefined"&&!(this instanceof LString)||typeof this==="undefined"){return new LString(e)}if(e instanceof Array){this.__string__=e.map(function(e,t){typecheck("LString",e,"character",t+1);return e.toString()}).join("")}else{this.__string__=e.valueOf()}}{var ignore=["length","constructor"];var _keys=Object.getOwnPropertyNames(String.prototype).filter(function(e){return!ignore.includes(e)});var wrap=function e(n){return function(){for(var e=arguments.length,t=new Array(e),r=0;r0){r.push(this.__string__.substring(0,e))}r.push(t);if(e1&&arguments[1]!==undefined?arguments[1]:false;if(e instanceof LNumber){return e}if(typeof this!=="undefined"&&!(this instanceof LNumber)||typeof this==="undefined"){return new LNumber(e,t)}if(typeof e==="undefined"){throw new Error("Invalid LNumber constructor call")}var r=LNumber.getType(e);if(LNumber.types[r]){return LNumber.types[r](e,t)}var n=e instanceof Array&&LString.isString(e[0])&&LNumber.isNumber(e[1]);if(e instanceof LNumber){return LNumber(e.value)}if(!LNumber.isNumber(e)&&!n){throw new Error("You can't create LNumber from ".concat(type(e)))}if(e===null){e=0}var i;if(n){var a=e,o=_slicedToArray(a,2),u=o[0],s=o[1];if(u instanceof LString){u=u.valueOf()}if(s instanceof LNumber){s=s.valueOf()}var c=u.match(/^([+-])/);var l=false;if(c){u=u.replace(/^[+-]/,"");if(c[1]==="-"){l=true}}}if(Number.isNaN(e)){return LFloat(e)}else if(typeof BigInt!=="undefined"){if(typeof e!=="bigint"){if(n){var f;switch(s){case 8:f="0o";break;case 16:f="0x";break;case 2:f="0b";break;case 10:f="";break}if(typeof f==="undefined"){var _=BigInt(s);i=_toConsumableArray(u).map(function(e,t){return BigInt(parseInt(e,s))*pow(_,BigInt(t))}).reduce(function(e,t){return e+t})}else{i=BigInt(f+u)}}else{i=BigInt(e)}if(l){i*=BigInt(-1)}}else{i=e}return LBigInteger(i,true)}else if(typeof BN!=="undefined"&&!(e instanceof BN)){if(e instanceof Array){return LBigInteger(_construct(BN,_toConsumableArray(e)))}return LBigInteger(new BN(e))}else if(n){this.constant(parseInt(u,s),"integer")}else{this.constant(e,"integer")}}LNumber.prototype.constant=function(e,t){Object.defineProperty(this,"__value__",{value:e,enumerable:true});Object.defineProperty(this,"__type__",{value:t,enumerable:true})};LNumber.types={float:function e(t){return new LFloat(t)},complex:function e(t){var r=arguments.length>1&&arguments[1]!==undefined?arguments[1]:false;if(!LNumber.isComplex(t)){t={im:0,re:t}}return new LComplex(t,r)},rational:function e(t){var r=arguments.length>1&&arguments[1]!==undefined?arguments[1]:false;if(!LNumber.isRational(t)){t={num:t,denom:1}}return new LRational(t,r)}};LNumber.prototype.serialize=function(){return this.__value__};LNumber.prototype.isNaN=function(){return Number.isNaN(this.__value__)};LNumber.prototype.gcd=function(e){var t=this.abs();e=e.abs();if(e.cmp(t)===1){var r=t;t=e;e=r}while(true){t=t.rem(e);if(t.cmp(0)===0){return e}e=e.rem(t);if(e.cmp(0)===0){return t}}};LNumber.isFloat=function e(t){return t instanceof LFloat||Number(t)===t&&t%1!==0};LNumber.isNumber=function(e){return e instanceof LNumber||LNumber.isNative(e)||LNumber.isBN(e)};LNumber.isComplex=function(e){if(!e){return false}var t=e instanceof LComplex||(LNumber.isNumber(e.im)||LNumber.isRational(e.im)||Number.isNaN(e.im))&&(LNumber.isNumber(e.re)||LNumber.isRational(e.re)||Number.isNaN(e.re));return t};LNumber.isRational=function(e){if(!e){return false}return e instanceof LRational||LNumber.isNumber(e.num)&&LNumber.isNumber(e.denom)};LNumber.isInteger=function(e){if(!(LNumber.isNative(e)||e instanceof LNumber)){return false}if(LNumber.isFloat(e)){return false}if(LNumber.isRational(e)){return false}if(LNumber.isComplex(e)){return false}return true};LNumber.isNative=function(e){return typeof e==="bigint"||typeof e==="number"};LNumber.isBigInteger=function(e){return e instanceof LBigInteger||typeof e==="bigint"||LNumber.isBN(e)};LNumber.isBN=function(e){return typeof BN!=="undefined"&&e instanceof BN};LNumber.getArgsType=function(e,t){if(e instanceof LFloat||t instanceof LFloat){return LFloat}if(e instanceof LBigInteger||t instanceof LBigInteger){return LBigInteger}return LNumber};LNumber.prototype.toString=function(e){if(Number.isNaN(this.__value__)){return"+nan.0"}if(e>=2&&e<36){return this.__value__.toString(e)}return this.__value__.toString()};LNumber.prototype.asType=function(e){var t=LNumber.getType(this);return LNumber.types[t]?LNumber.types[t](e):LNumber(e)};LNumber.prototype.isBigNumber=function(){return typeof this.__value__==="bigint"||typeof BN!=="undefined"&&!(this.value instanceof BN)};["floor","ceil","round"].forEach(function(e){LNumber.prototype[e]=function(){if(this["float"]||LNumber.isFloat(this.__value__)){return LNumber(Math[e](this.__value__))}else{return LNumber(Math[e](this.valueOf()))}}});LNumber.prototype.valueOf=function(){if(LNumber.isNative(this.__value__)){return Number(this.__value__)}else if(LNumber.isBN(this.__value__)){return this.__value__.toNumber()}};var matrix=function(){var e=function e(t,r){return[t,r]};return{bigint:{bigint:e,float:function e(t,r){return[LFloat(t.valueOf()),r]},rational:function e(t,r){return[{num:t,denom:1},r]},complex:function e(t,r){return[{im:0,re:t},r]}},integer:{integer:e,float:function e(t,r){return[LFloat(t.valueOf()),r]},rational:function e(t,r){return[{num:t,denom:1},r]},complex:function e(t,r){return[{im:0,re:t},r]}},float:{bigint:function e(t,r){return[t,r&&LFloat(r.valueOf())]},integer:function e(t,r){return[t,r&&LFloat(r.valueOf())]},float:e,rational:function e(t,r){return[t,r&&LFloat(r.valueOf())]},complex:function e(t,r){return[{re:t,im:LFloat(0)},r]}},complex:{bigint:t("bigint"),integer:t("integer"),float:t("float"),rational:t("rational"),complex:function e(t,r){var n=LNumber.coerce(t.__re__,r.__re__),i=_slicedToArray(n,2),a=i[0],o=i[1];var u=LNumber.coerce(t.__im__,r.__im__),s=_slicedToArray(u,2),c=s[0],l=s[1];return[{im:c,re:a},{im:l,re:o}]}},rational:{bigint:function e(t,r){return[t,r&&{num:r,denom:1}]},integer:function e(t,r){return[t,r&&{num:r,denom:1}]},float:function e(t,r){return[LFloat(t.valueOf()),r]},rational:e,complex:function e(t,r){return[{im:coerce(t.__type__,r.__im__.__type__,0)[0],re:coerce(t.__type__,r.__re__.__type__,t)[0]},{im:coerce(t.__type__,r.__im__.__type__,r.__im__)[0],re:coerce(t.__type__,r.__re__.__type__,r.__re__)[0]}]}}};function t(r){return function(e,t){return[{im:coerce(r,e.__im__.__type__,0,e.__im__)[1],re:coerce(r,e.__re__.__type__,0,e.__re__)[1]},{im:coerce(r,e.__im__.__type__,0,0)[1],re:coerce(r,t.__type__,0,t)[1]}]}}}();function coerce(e,t,r,n){return matrix[e][t](r,n)}LNumber.coerce=function(e,t){var r=LNumber.getType(e);var n=LNumber.getType(t);if(!matrix[r]){throw new Error("LNumber::coerce unknown lhs type ".concat(r))}else if(!matrix[r][n]){throw new Error("LNumber::coerce unknown rhs type ".concat(n))}var i=matrix[r][n](e,t);return i.map(function(e){return LNumber(e,true)})};LNumber.prototype.coerce=function(e){if(!(typeof e==="number"||e instanceof LNumber)){throw new Error("LNumber: you can't coerce ".concat(type(e)))}if(typeof e==="number"){e=LNumber(e)}return LNumber.coerce(this,e)};LNumber.getType=function(e){if(e instanceof LNumber){return e.__type__}if(LNumber.isFloat(e)){return"float"}if(LNumber.isComplex(e)){return"complex"}if(LNumber.isRational(e)){return"rational"}if(typeof e==="number"){return"integer"}if(typeof BigInt!=="undefined"&&typeof e!=="bigint"||typeof BN!=="undefined"&&!(e instanceof BN)){return"bigint"}};LNumber.prototype.isFloat=function(){return!!(LNumber.isFloat(this.__value__)||this["float"])};var mapping={add:"+",sub:"-",mul:"*",div:"/",rem:"%",or:"|",and:"&",neg:"~",shl:">>",shr:"<<"};var rev_mapping={};Object.keys(mapping).forEach(function(t){rev_mapping[mapping[t]]=t;LNumber.prototype[t]=function(e){return this.op(mapping[t],e)}});LNumber._ops={"*":function e(t,r){return t*r},"+":function e(t,r){return t+r},"-":function e(t,r){if(typeof r==="undefined"){return-t}return t-r},"/":function e(t,r){return t/r},"%":function e(t,r){return t%r},"|":function e(t,r){return t|r},"&":function e(t,r){return t&r},"~":function e(t){return~t},">>":function e(t,r){return t>>r},"<<":function e(t,r){return t<1&&arguments[1]!==undefined?arguments[1]:false;if(typeof this!=="undefined"&&!(this instanceof LComplex)||typeof this==="undefined"){return new LComplex(e,t)}if(e instanceof LComplex){return LComplex({im:e.__im__,re:e.__re__})}if(LNumber.isNumber(e)&&t){if(!t){return Number(e)}}else if(!LNumber.isComplex(e)){var r="Invalid constructor call for LComplex expect &(:im :re ) object but got ".concat(toString(e));throw new Error(r)}var n=e.im instanceof LNumber?e.im:LNumber(e.im);var i=e.re instanceof LNumber?e.re:LNumber(e.re);this.constant(n,i)}LComplex.prototype=Object.create(LNumber.prototype);LComplex.prototype.constructor=LComplex;LComplex.prototype.constant=function(e,t){Object.defineProperty(this,"__im__",{value:e,enumerable:true});Object.defineProperty(this,"__re__",{value:t,enumerable:true});Object.defineProperty(this,"__type__",{value:"complex",enumerable:true})};LComplex.prototype.serialize=function(){return{re:this.__re__,im:this.__im__}};LComplex.prototype.toRational=function(e){if(LNumber.isFloat(this.__im__)&&LNumber.isFloat(this.__re__)){var t=LFloat(this.__im__).toRational(e);var r=LFloat(this.__re__).toRational(e);return LComplex({im:t,re:r})}return this};LComplex.prototype.pow=function(e){e.cmp(0);if(e===0){return LNumber(1)}var t=LNumber(Math.atan2(this.__im__.valueOf(),this.__re__.valueOf()));var r=LNumber(this.modulus());if(LNumber.isComplex(e)&&e.__im__.cmp(0)!==0){var n=e.mul(Math.log(r.valueOf())).add(LComplex.i.mul(t).mul(e));var i=LFloat(Math.E).pow(n.__re__.valueOf());return LComplex({re:i.mul(Math.cos(n.__im__.valueOf())),im:i.mul(Math.sin(n.__im__.valueOf()))})}var a=e.__re__.cmp(0)>0;e=e.__re__.valueOf();if(LNumber.isInteger(e)&&a){var o=this;while(--e){o=o.mul(this)}return o}var u=r.pow(e);var s=t.mul(e);return LComplex({re:u.mul(Math.cos(s)),im:u.mul(Math.sin(s))})};LComplex.prototype.add=function(e){return this.complex_op("add",e,function(e,t,r,n){return{re:e.add(t),im:r.add(n)}})};LComplex.prototype.factor=function(){if(this.__im__ instanceof LFloat||this.__im__ instanceof LFloat){var e=this.__re__,t=this.__im__;var r,n;if(e instanceof LFloat){r=e.toRational().mul(e.toRational())}else{r=e.mul(e)}if(t instanceof LFloat){n=t.toRational().mul(t.toRational())}else{n=t.mul(t)}return r.add(n)}else{return this.__re__.mul(this.__re__).add(this.__im__.mul(this.__im__))}};LComplex.prototype.modulus=function(){return this.factor().sqrt()};LComplex.prototype.conjugate=function(){return LComplex({re:this.__re__,im:this.__im__.sub()})};LComplex.prototype.sqrt=function(){var e=this.modulus();var t,r;if(e.cmp(0)===0){t=r=e}else if(this.__re__.cmp(0)===1){t=LFloat(.5).mul(e.add(this.__re__)).sqrt();r=this.__im__.div(t).div(2)}else{r=LFloat(.5).mul(e.sub(this.__re__)).sqrt();if(this.__im__.cmp(0)===-1){r=r.sub()}t=this.__im__.div(r).div(2)}return LComplex({im:r,re:t})};LComplex.prototype.div=function(e){if(LNumber.isNumber(e)&&!LNumber.isComplex(e)){if(!(e instanceof LNumber)){e=LNumber(e)}var t=this.__re__.div(e);var r=this.__im__.div(e);return LComplex({re:t,im:r})}else if(!LNumber.isComplex(e)){throw new Error("[LComplex::div] Invalid value")}if(this.cmp(e)===0){var n=this.coerce(e),i=_slicedToArray(n,2),a=i[0],o=i[1];var u=a.__im__.div(o.__im__);return u.coerce(o.__re__)[0]}var s=this.coerce(e),c=_slicedToArray(s,2),l=c[0],f=c[1];var _=f.factor();var p=f.conjugate();var h=l.mul(p);if(!LNumber.isComplex(h)){return h.div(_)}var d=h.__re__.op("/",_);var m=h.__im__.op("/",_);return LComplex({re:d,im:m})};LComplex.prototype.sub=function(e){return this.complex_op("sub",e,function(e,t,r,n){return{re:e.sub(t),im:r.sub(n)}})};LComplex.prototype.mul=function(e){return this.complex_op("mul",e,function(e,t,r,n){var i={re:e.mul(t).sub(r.mul(n)),im:e.mul(n).add(t.mul(r))};return i})};LComplex.prototype.complex_op=function(e,t,i){var a=this;var r=function e(t,r){var n=i(a.__re__,t,a.__im__,r);if("im"in n&&"re"in n){if(n.im.cmp(0)===0){return n.re}return LComplex(n,true)}return n};if(typeof t==="undefined"){return r()}if(LNumber.isNumber(t)&&!LNumber.isComplex(t)){if(!(t instanceof LNumber)){t=LNumber(t)}var n=t.asType(0);t={__im__:n,__re__:t}}else if(!LNumber.isComplex(t)){throw new Error("[LComplex::".concat(e,"] Invalid value"))}var o=t.__re__ instanceof LNumber?t.__re__:this.__re__.asType(t.__re__);var u=t.__im__ instanceof LNumber?t.__im__:this.__im__.asType(t.__im__);return r(o,u)};LComplex._op={"+":"add","-":"sub","*":"mul","/":"div"};LComplex.prototype._op=function(e,t){var r=LComplex._op[e];return this[r](t)};LComplex.prototype.cmp=function(e){var t=this.coerce(e),r=_slicedToArray(t,2),n=r[0],i=r[1];var a=n.__re__.coerce(i.__re__),o=_slicedToArray(a,2),u=o[0],s=o[1];var c=u.cmp(s);if(c!==0){return c}else{var l=n.__im__.coerce(i.__im__),f=_slicedToArray(l,2),_=f[0],p=f[1];return _.cmp(p)}};LComplex.prototype.valueOf=function(){return[this.__re__,this.__im__].map(function(e){return e.valueOf()})};LComplex.prototype.toString=function(){var e;if(this.__re__.cmp(0)!==0){e=[toString(this.__re__)]}else{e=[]}var t=this.__im__.valueOf();var r=[Number.NEGATIVE_INFINITY,Number.POSITIVE_INFINITY].includes(t);var n=toString(this.__im__);if(!r&&!Number.isNaN(t)){var i=this.__im__.cmp(0);if(i<0||i===0&&this.__im__._minus){e.push("-")}else{e.push("+")}n=n.replace(/^-/,"")}e.push(n);e.push("i");return e.join("")};function LFloat(e){if(typeof this!=="undefined"&&!(this instanceof LFloat)||typeof this==="undefined"){return new LFloat(e)}if(!LNumber.isNumber(e)){throw new Error("Invalid constructor call for LFloat")}if(e instanceof LNumber){return LFloat(e.valueOf())}if(typeof e==="number"){if(Object.is(e,-0)){Object.defineProperty(this,"_minus",{value:true})}this.constant(e,"float")}}LFloat.prototype=Object.create(LNumber.prototype);LFloat.prototype.constructor=LFloat;LFloat.prototype.toString=function(){if(this.__value__===Number.NEGATIVE_INFINITY){return"-inf.0"}if(this.__value__===Number.POSITIVE_INFINITY){return"+inf.0"}if(Number.isNaN(this.__value__)){return"+nan.0"}var e=this.__value__.toString();if(!e.match(/e/i)){var t=this.__value__.toString().replace(/^-/,"");var r=this.__value__<0?"-":"";if(e.match(/^-?0\.0{3}/)){var n=t.match(/^[.0]+/g)[0].length-1;var i=t.replace(/^[.0]+/,"").replace(/^([0-9])/,"$1.");return"".concat(r).concat(i,"e-").concat(n)}if(e.match(/^-?[0-9]{7,}\.?/)){var a=t.match(/^[0-9]+/g)[0].length-1;var o=t.replace(/\./,"").replace(/^([0-9])/,"$1.").replace(/0+$/,"").replace(/\.$/,".0");return"".concat(r).concat(o,"e").concat(a)}if(!LNumber.isFloat(this.__value__)){var u=e+".0";return this._minus?"-"+u:u}}return e.replace(/^([0-9]+)e/,"$1.0e")};LFloat.prototype._op=function(e,t){if(t instanceof LNumber){t=t.__value__}var r=LNumber._ops[e];if(e==="/"&&this.__value__===0&&t===0){return NaN}return LFloat(r(this.__value__,t))};LFloat.prototype.toRational=function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:null;if(e===null){return toRational(this.__value__.valueOf())}return approxRatio(e.valueOf())(this.__value__.valueOf())};LFloat.prototype.sqrt=function(){var e=this.valueOf();if(this.cmp(0)<0){var t=LFloat(Math.sqrt(-e));return LComplex({re:0,im:t})}return LFloat(Math.sqrt(e))};LFloat.prototype.abs=function(){var e=this.valueOf();if(e<0){e=-e}return LFloat(e)};var toRational=approxRatio(1e-10);function approxRatio(n){return function(e){var t=function e(n,t,r){var i=function e(t,r){return r0){i=simplest_rational2(n,r)}else if(n.cmp(r)<=0){i=r}else if(r.cmp(0)>0){i=simplest_rational2(r,n)}else if(t.cmp(0)<0){i=LNumber(simplest_rational2(n.sub(),r.sub())).sub()}else{i=LNumber(0)}if(LNumber.isFloat(t)||LNumber.isFloat(e)){return LFloat(i)}return i}function simplest_rational2(e,t){var r=LNumber(e).floor();var n=LNumber(t).floor();if(e.cmp(r)<1){return r}else if(r.cmp(n)===0){var i=LNumber(1).div(t.sub(n));var a=LNumber(1).div(e.sub(r));return r.add(LNumber(1).div(simplest_rational2(i,a)))}else{return r.add(LNumber(1))}}function LRational(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:false;if(typeof this!=="undefined"&&!(this instanceof LRational)||typeof this==="undefined"){return new LRational(e,t)}if(!LNumber.isRational(e)){throw new Error("Invalid constructor call for LRational")}var r,n;if(e instanceof LRational){r=LNumber(e.__num__);n=LNumber(e.__denom__)}else{r=LNumber(e.num);n=LNumber(e.denom)}if(!t&&n.cmp(0)!==0){var i=r.op("%",n).cmp(0)===0;if(i){return LNumber(r.div(n))}}this.constant(r,n)}LRational.prototype=Object.create(LNumber.prototype);LRational.prototype.constructor=LRational;LRational.prototype.constant=function(e,t){Object.defineProperty(this,"__num__",{value:e,enumerable:true});Object.defineProperty(this,"__denom__",{value:t,enumerable:true});Object.defineProperty(this,"__type__",{value:"rational",enumerable:true})};LRational.prototype.serialize=function(){return{num:this.__num__,denom:this.__denom__}};LRational.prototype.pow=function(e){if(LNumber.isRational(e)){return pow(this.valueOf(),e.valueOf())}var t=e.cmp(0);if(t===0){return LNumber(1)}if(t===-1){e=e.sub();var r=this.__denom__.pow(e);var n=this.__num__.pow(e);return LRational({num:r,denom:n})}var i=this;e=e.valueOf();while(e>1){i=i.mul(this);e--}return i};LRational.prototype.sqrt=function(){var e=this.__num__.sqrt();var t=this.__denom__.sqrt();if(e instanceof LFloat||t instanceof LFloat){return e.div(t)}return LRational({num:e,denom:t})};LRational.prototype.abs=function(){var e=this.__num__;var t=this.__denom__;if(e.cmp(0)===-1){e=e.sub()}if(t.cmp(0)!==1){t=t.sub()}return LRational({num:e,denom:t})};LRational.prototype.cmp=function(e){return LNumber(this.valueOf(),true).cmp(e)};LRational.prototype.toString=function(){var e=this.__num__.gcd(this.__denom__);var t,r;if(e.cmp(1)!==0){t=this.__num__.div(e);if(t instanceof LRational){t=LNumber(t.valueOf(true))}r=this.__denom__.div(e);if(r instanceof LRational){r=LNumber(r.valueOf(true))}}else{t=this.__num__;r=this.__denom__}var n=this.cmp(0)<0;if(n){if(t.abs().cmp(r.abs())===0){return t.toString()}}else if(t.cmp(r)===0){return t.toString()}return t.toString()+"/"+r.toString()};LRational.prototype.valueOf=function(e){if(this.__denom__.cmp(0)===0){if(this.__num__.cmp(0)<0){return Number.NEGATIVE_INFINITY}return Number.POSITIVE_INFINITY}if(e){return LNumber._ops["/"](this.__num__.value,this.__denom__.value)}return LFloat(this.__num__.valueOf()).div(this.__denom__.valueOf())};LRational.prototype.mul=function(e){if(!(e instanceof LNumber)){e=LNumber(e)}if(LNumber.isRational(e)){var t=this.__num__.mul(e.__num__);var r=this.__denom__.mul(e.__denom__);return LRational({num:t,denom:r})}var n=LNumber.coerce(this,e),i=_slicedToArray(n,2),a=i[0],o=i[1];return a.mul(o)};LRational.prototype.div=function(e){if(!(e instanceof LNumber)){e=LNumber(e)}if(LNumber.isRational(e)){var t=this.__num__.mul(e.__denom__);var r=this.__denom__.mul(e.__num__);return LRational({num:t,denom:r})}var n=LNumber.coerce(this,e),i=_slicedToArray(n,2),a=i[0],o=i[1];var u=a.div(o);return u};LRational.prototype._op=function(e,t){return this[rev_mapping[e]](t)};LRational.prototype.sub=function(e){if(typeof e==="undefined"){return this.mul(-1)}if(!(e instanceof LNumber)){e=LNumber(e)}if(LNumber.isRational(e)){var t=e.__num__.sub();var r=e.__denom__;return this.add(LRational({num:t,denom:r}))}if(!(e instanceof LNumber)){e=LNumber(e).sub()}else{e=e.sub()}var n=LNumber.coerce(this,e),i=_slicedToArray(n,2),a=i[0],o=i[1];return a.add(o)};LRational.prototype.add=function(e){if(!(e instanceof LNumber)){e=LNumber(e)}if(LNumber.isRational(e)){var t=this.__denom__;var r=e.__denom__;var n=this.__num__;var i=e.__num__;var a,o;if(t!==r){o=r.mul(n).add(i.mul(t));a=t.mul(r)}else{o=n.add(i);a=t}return LRational({num:o,denom:a})}if(LNumber.isFloat(e)){return LFloat(this.valueOf()).add(e)}var u=LNumber.coerce(this,e),s=_slicedToArray(u,2),c=s[0],l=s[1];return c.add(l)};function LBigInteger(e,t){if(typeof this!=="undefined"&&!(this instanceof LBigInteger)||typeof this==="undefined"){return new LBigInteger(e,t)}if(e instanceof LBigInteger){return LBigInteger(e.__value__,e._native)}if(!LNumber.isBigInteger(e)){throw new Error("Invalid constructor call for LBigInteger")}this.constant(e,"bigint");Object.defineProperty(this,"_native",{value:t})}LBigInteger.prototype=Object.create(LNumber.prototype);LBigInteger.prototype.constructor=LBigInteger;LBigInteger.bn_op={"+":"iadd","-":"isub","*":"imul","/":"idiv","%":"imod","|":"ior","&":"iand","~":"inot","<<":"ishrn",">>":"ishln"};LBigInteger.prototype.serialize=function(){return this.__value__.toString()};LBigInteger.prototype._op=function(e,t){if(typeof t==="undefined"){if(LNumber.isBN(this.__value__)){e=LBigInteger.bn_op[e];return LBigInteger(this.__value__.clone()[e](),false)}return LBigInteger(LNumber._ops[e](this.__value__),true)}if(LNumber.isBN(this.__value__)&&LNumber.isBN(t.__value__)){e=LBigInteger.bn_op[e];return LBigInteger(this.__value__.clone()[e](t),false)}var r=LNumber._ops[e](this.__value__,t.__value__);if(e==="/"){var n=this.op("%",t).cmp(0)===0;if(n){return LNumber(r)}return LRational({num:this,denom:t})}return LBigInteger(r,true)};LBigInteger.prototype.sqrt=function(){var e;var t=this.cmp(0)<0;if(LNumber.isNative(this.__value__)){e=LNumber(Math.sqrt(t?-this.valueOf():this.valueOf()))}else if(LNumber.isBN(this.__value__)){e=t?this.__value__.neg().sqrt():this.__value__.sqrt()}if(t){return LComplex({re:0,im:e})}return e};LNumber.NaN=LNumber(NaN);LComplex.i=LComplex({im:1,re:0});function InputPort(e){var n=this;if(typeof this!=="undefined"&&!(this instanceof InputPort)||typeof this==="undefined"){return new InputPort(e)}typecheck("InputPort",e,"function");read_only(this,"__type__",text_port);var i;Object.defineProperty(this,"__parser__",{enumerable:true,get:function e(){return i},set:function e(t){typecheck("InputPort::__parser__",t,"parser");i=t}});this._read=e;this._with_parser=this._with_init_parser.bind(this,_asyncToGenerator(_regeneratorRuntime.mark(function e(){var r;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(n.char_ready()){t.next=5;break}t.next=3;return n._read();case 3:r=t.sent;i=new Parser(r,{env:n});case 5:return t.abrupt("return",n.__parser__);case 6:case"end":return t.stop()}},e)})));this.char_ready=function(){return!!this.__parser__&&this.__parser__.__lexer__.peek()!==eof};this._make_defaults()}InputPort.prototype._make_defaults=function(){this.read=this._with_parser(function(e){return e.read_object()});this.read_line=this._with_parser(function(e){return e.__lexer__.read_line()});this.read_char=this._with_parser(function(e){return e.__lexer__.read_char()});this.read_string=this._with_parser(function(e,t){if(!LNumber.isInteger(t)){var r=LNumber.getType(t);typeErrorMessage("read-string",r,"integer")}return e.__lexer__.read_string(t.valueOf())});this.peek_char=this._with_parser(function(e){return e.__lexer__.peek_char()})};InputPort.prototype._with_init_parser=function(u,s){var c=this;return _asyncToGenerator(_regeneratorRuntime.mark(function e(){var r,n,i,a,o=arguments;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:t.next=2;return u.call(c);case 2:r=t.sent;for(n=o.length,i=new Array(n),a=0;a"};function OutputPort(e){if(typeof this!=="undefined"&&!(this instanceof OutputPort)||typeof this==="undefined"){return new OutputPort(e)}typecheck("OutputPort",e,"function");read_only(this,"__type__",text_port);this.write=e}OutputPort.prototype.is_open=function(){return this._closed!==true};OutputPort.prototype.close=function(){Object.defineProperty(this,"_closed",{get:function e(){return true},set:function e(){},configurable:false,enumerable:false});this.write=function(){throw new Error("output-port: port is closed")}};OutputPort.prototype.flush=function(){};OutputPort.prototype.toString=function(){return"#"};var BufferedOutputPort=function(e){_inherits(r,e);function r(e){var t;_classCallCheck(this,r);t=_callSuper(this,r,[function(){var e;return(e=t)._write.apply(e,arguments)}]);typecheck("BufferedOutputPort",e,"function");read_only(_assertThisInitialized(t),"_fn",e,{hidden:true});read_only(_assertThisInitialized(t),"_buffer",[],{hidden:true});return t}_createClass(r,[{key:"flush",value:function e(){if(this._buffer.length){this._fn(this._buffer.join(""));this._buffer.length=0}}},{key:"_write",value:function e(){var t=this;for(var r=arguments.length,n=new Array(r),i=0;i"};OutputStringPort.prototype.valueOf=function(){return this.__buffer__.map(function(e){return e.valueOf()}).join("")};function OutputFilePort(e,t){var r=this;if(typeof this!=="undefined"&&!(this instanceof OutputFilePort)||typeof this==="undefined"){return new OutputFilePort(e,t)}typecheck("OutputFilePort",e,"string");read_only(this,"__filename__",e);read_only(this,"_fd",t.valueOf(),{hidden:true});read_only(this,"__type__",text_port);this.write=function(e){if(!LString.isString(e)){e=toString(e)}else{e=e.valueOf()}r.fs().write(r._fd,e,function(e){if(e){throw e}})}}OutputFilePort.prototype=Object.create(OutputPort.prototype);OutputFilePort.prototype.constructor=OutputFilePort;OutputFilePort.prototype.fs=function(){if(!this._fs){this._fs=this.internal("fs")}return this._fs};OutputFilePort.prototype.internal=function(e){return user_env.get("**internal-env**").get(e)};OutputFilePort.prototype.close=function(){var n=this;return new Promise(function(t,r){n.fs().close(n._fd,function(e){if(e){r(e)}else{read_only(n,"_fd",null,{hidden:true});OutputPort.prototype.close.call(n);t()}})})};OutputFilePort.prototype.toString=function(){return"#")};function InputStringPort(e,t){var r=this;if(typeof this!=="undefined"&&!(this instanceof InputStringPort)||typeof this==="undefined"){return new InputStringPort(e)}typecheck("InputStringPort",e,"string");t=t||global_env;e=e.valueOf();this._with_parser=this._with_init_parser.bind(this,function(){if(!r.__parser__){r.__parser__=new Parser(e,{env:t})}return r.__parser__});read_only(this,"__type__",text_port);this._make_defaults()}InputStringPort.prototype.char_ready=function(){return true};InputStringPort.prototype=Object.create(InputPort.prototype);InputStringPort.prototype.constructor=InputStringPort;InputStringPort.prototype.toString=function(){return"#"};function InputByteVectorPort(e){if(typeof this!=="undefined"&&!(this instanceof InputByteVectorPort)||typeof this==="undefined"){return new InputByteVectorPort(e)}typecheck("InputByteVectorPort",e,"uint8array");read_only(this,"__vector__",e);read_only(this,"__type__",binary_port);var r=0;Object.defineProperty(this,"__index__",{enumerable:true,get:function e(){return r},set:function e(t){typecheck("InputByteVectorPort::__index__",t,"number");if(t instanceof LNumber){t=t.valueOf()}if(typeof t==="bigint"){t=Number(t)}if(Math.floor(t)!==t){throw new Error("InputByteVectorPort::__index__ value is "+"not integer")}r=t}})}InputByteVectorPort.prototype=Object.create(InputPort.prototype);InputByteVectorPort.prototype.constructor=InputByteVectorPort;InputByteVectorPort.prototype.toString=function(){return"#"};InputByteVectorPort.prototype.close=function(){var t=this;read_only(this,"__vector__",_nil);var r=function e(){throw new Error("Input-binary-port: port is closed")};["read_u8","close","peek_u8","read_u8_vector"].forEach(function(e){t[e]=r});this.u8_ready=this.char_ready=function(){return false}};InputByteVectorPort.prototype.u8_ready=function(){return true};InputByteVectorPort.prototype.peek_u8=function(){if(this.__index__>=this.__vector__.length){return eof}return this.__vector__[this.__index__]};InputByteVectorPort.prototype.skip=function(){if(this.__index__<=this.__vector__.length){++this.__index__}};InputByteVectorPort.prototype.read_u8=function(){var e=this.peek_u8();this.skip();return e};InputByteVectorPort.prototype.read_u8_vector=function(e){if(typeof e==="undefined"){e=this.__vector__.length}else if(e>this.__index__+this.__vector__.length){e=this.__index__+this.__vector__.length}if(this.peek_u8()===eof){return eof}return this.__vector__.slice(this.__index__,e)};function OutputByteVectorPort(){if(typeof this!=="undefined"&&!(this instanceof OutputByteVectorPort)||typeof this==="undefined"){return new OutputByteVectorPort}read_only(this,"__type__",binary_port);read_only(this,"_buffer",[],{hidden:true});this.write=function(e){typecheck("write",e,["number","uint8array"]);if(LNumber.isNumber(e)){this._buffer.push(e.valueOf())}else{var t;(t=this._buffer).push.apply(t,_toConsumableArray(Array.from(e)))}};Object.defineProperty(this,"__buffer__",{enumerable:true,get:function e(){return Uint8Array.from(this._buffer)}})}OutputByteVectorPort.prototype=Object.create(OutputPort.prototype);OutputByteVectorPort.prototype.constructor=OutputByteVectorPort;OutputByteVectorPort.prototype.close=function(){OutputPort.prototype.close.call(this);read_only(this,"_buffer",null,{hidden:true})};OutputByteVectorPort.prototype._close_guard=function(){if(this._closed){throw new Error("output-port: binary port is closed")}};OutputByteVectorPort.prototype.write_u8=function(e){typecheck("OutputByteVectorPort::write_u8",e,"number");this.write(e)};OutputByteVectorPort.prototype.write_u8_vector=function(e){typecheck("OutputByteVectorPort::write_u8_vector",e,"uint8array");this.write(e)};OutputByteVectorPort.prototype.toString=function(){return"#"};OutputByteVectorPort.prototype.valueOf=function(){return this.__buffer__};function InputFilePort(e,t){if(typeof this!=="undefined"&&!(this instanceof InputFilePort)||typeof this==="undefined"){return new InputFilePort(e,t)}InputStringPort.call(this,e);typecheck("InputFilePort",t,"string");read_only(this,"__filename__",t)}InputFilePort.prototype=Object.create(InputStringPort.prototype);InputFilePort.prototype.constructor=InputFilePort;InputFilePort.prototype.toString=function(){return"#")};function InputBinaryFilePort(e,t){if(typeof this!=="undefined"&&!(this instanceof InputBinaryFilePort)||typeof this==="undefined"){return new InputBinaryFilePort(e,t)}InputByteVectorPort.call(this,e);typecheck("InputBinaryFilePort",t,"string");read_only(this,"__filename__",t)}InputBinaryFilePort.prototype=Object.create(InputByteVectorPort.prototype);InputBinaryFilePort.prototype.constructor=InputBinaryFilePort;InputBinaryFilePort.prototype.toString=function(){return"#")};function OutputBinaryFilePort(e,t){var i=this;if(typeof this!=="undefined"&&!(this instanceof OutputBinaryFilePort)||typeof this==="undefined"){return new OutputBinaryFilePort(e,t)}typecheck("OutputBinaryFilePort",e,"string");read_only(this,"__filename__",e);read_only(this,"_fd",t.valueOf(),{hidden:true});read_only(this,"__type__",binary_port);var a;this.write=function(e){typecheck("write",e,["number","uint8array"]);var n;if(!a){a=i.internal("fs")}if(LNumber.isNumber(e)){n=new Uint8Array([e.valueOf()])}else{n=new Uint8Array(Array.from(e))}return new Promise(function(t,r){a.write(i._fd,n,function(e){if(e){r(e)}else{t()}})})}}OutputBinaryFilePort.prototype=Object.create(OutputFilePort.prototype);OutputBinaryFilePort.prototype.constructor=OutputBinaryFilePort;OutputBinaryFilePort.prototype.write_u8=function(e){typecheck("OutputByteVectorPort::write_u8",e,"number");this.write(e)};OutputBinaryFilePort.prototype.write_u8_vector=function(e){typecheck("OutputByteVectorPort::write_u8_vector",e,"uint8array");this.write(e)};var binary_port=Symbol["for"]("binary");var text_port=Symbol["for"]("text");var eof=new EOF;function EOF(){}EOF.prototype.toString=function(){return"#"};function Interpreter(e){var t=this;var r=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},n=r.stderr,i=r.stdin,a=r.stdout,o=r.command_line,u=o===void 0?null:o,s=_objectWithoutProperties(r,_excluded3);if(typeof this!=="undefined"&&!(this instanceof Interpreter)||typeof this==="undefined"){return new Interpreter(e,_objectSpread({stdin:i,stdout:a,stderr:n,command_line:u},s))}if(typeof e==="undefined"){e="anonymous"}this.__env__=user_env.inherit(e,s);this.__env__.set("parent.frame",doc("parent.frame",function(){return t.__env__},global_env.__env__["parent.frame"].__doc__));var c="**interaction-environment-defaults**";this.set(c,get_props(s).concat(c));var l=internal_env.inherit("internal-".concat(e));if(is_port(i)){l.set("stdin",i)}if(is_port(n)){l.set("stderr",n)}if(is_port(a)){l.set("stdout",a)}l.set("command-line",u);set_interaction_env(this.__env__,l)}Interpreter.prototype.exec=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};var r=t.use_dynamic,n=r===void 0?false:r,i=t.dynamic_env,a=t.env;typecheck("Interpreter::exec",e,["string","array"],1);typecheck("Interpreter::exec",n,"boolean",2);if(!a){a=this.__env__}if(!i){i=a}global_env.set("**interaction-environment**",this.__env__);return exec(e,{env:a,dynamic_env:i,use_dynamic:n})};Interpreter.prototype.get=function(e){var t=this.__env__.get(e);if(is_function(t)){var r=new LambdaContext({env:this.__env__});return t.bind(r)}return t};Interpreter.prototype.set=function(e,t){return this.__env__.set(e,t)};Interpreter.prototype.constant=function(e,t){return this.__env__.constant(e,t)};function LipsError(e,t){this.name="LipsError";this.message=e;this.args=t;this.stack=(new Error).stack}LipsError.prototype=new Error;LipsError.prototype.constructor=LipsError;var IgnoreException=function(e){_inherits(t,e);function t(){_classCallCheck(this,t);return _callSuper(this,t,arguments)}return _createClass(t)}(_wrapNativeSuper(Error));function Environment(e,t,r){if(arguments.length===1){if(_typeof$1(arguments[0])==="object"){e=arguments[0];t=null}else if(typeof arguments[0]==="string"){e={};t=null;r=arguments[0]}}this.__docs__=new Map;this.__env__=e;this.__parent__=t;this.__name__=r||"anonymous"}Environment.prototype.list=function(){return get_props(this.__env__)};Environment.prototype.fs=function(){return this.get("**fs**")};Environment.prototype.unset=function(e){if(e instanceof LSymbol){e=e.valueOf()}if(e instanceof LString){e=e.valueOf()}delete this.__env__[e]};Environment.prototype.inherit=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};if(_typeof$1(e)==="object"){t=e}if(!e||_typeof$1(e)==="object"){e="child of "+(this.__name__||"unknown")}return new Environment(t||{},this,e)};Environment.prototype.doc=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:null;var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:false;if(e instanceof LSymbol){e=e.__name__}if(e instanceof LString){e=e.valueOf()}if(t){if(!r){t=trim_lines(t)}this.__docs__.set(e,t);return this}if(this.__docs__.has(e)){return this.__docs__.get(e)}if(this.__parent__){return this.__parent__.doc(e)}};Environment.prototype.new_frame=function(e,t){var n=this.inherit("__frame__");n.set("parent.frame",doc("parent.frame",function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:1;e=e.valueOf();var t=n.__parent__;if(!is_env(t)){return _nil}if(e<=0){return t}var r=t.get("parent.frame");return r(e-1)},global_env.__env__["parent.frame"].__doc__));t.callee=e;n.set("arguments",t);return n};Environment.prototype._lookup=function(e){if(e instanceof LSymbol){e=e.__name__}if(e instanceof LString){e=e.valueOf()}if(this.__env__.hasOwnProperty(e)){return Value(this.__env__[e])}if(this.__parent__){return this.__parent__._lookup(e)}};Environment.prototype.toString=function(){return"#"};Environment.prototype.clone=function(){var t=this;var r={};Object.keys(this.__env__).forEach(function(e){r[e]=t.__env__[e]});return new Environment(r,this.__parent__,this.__name__)};Environment.prototype.merge=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:"merge";typecheck("Environment::merge",e,"environment");return this.inherit(t,e.__env__)};function Value(e){if(typeof this!=="undefined"&&!(this instanceof Value)||typeof this==="undefined"){return new Value(e)}this.value=e}Value.isUndefined=function(e){return e instanceof Value&&typeof e.value==="undefined"};Value.prototype.valueOf=function(){return this.value};function Values(e){if(e.length){if(e.length===1){return e[0]}}if(typeof this!=="undefined"&&!(this instanceof Values)||typeof this==="undefined"){return new Values(e)}this.__values__=e}Values.prototype.toString=function(){return this.__values__.map(function(e){return toString(e)}).join("\n")};Values.prototype.valueOf=function(){return this.__values__};Environment.prototype.get=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};typecheck("Environment::get",e,["symbol","string"]);var r=t.throwError,n=r===void 0?true:r;var i=e;if(i instanceof LSymbol||i instanceof LString){i=i.valueOf()}var a=this._lookup(i);if(a instanceof Value){if(Value.isUndefined(a)){return undefined}return patch_value(a.valueOf())}var o;if(e instanceof LSymbol&&e[LSymbol.object]){o=e[LSymbol.object]}else if(typeof i==="string"){o=i.split(".").filter(Boolean)}if(o&&o.length>0){var u=o,s=_toArray(u),c=s[0],l=s.slice(1);a=this._lookup(c);if(l.length){try{if(a instanceof Value){a=a.valueOf()}else{a=get(root,c);if(is_function(a)){a=unbind(a)}}if(typeof a!=="undefined"){return get.apply(void 0,[a].concat(_toConsumableArray(l)))}}catch(e){throw e}}else if(a instanceof Value){return patch_value(a.valueOf())}a=get(root,i)}if(typeof a!=="undefined"){return a}if(n){throw new Error("Unbound variable `"+i.toString()+"'")}};Environment.prototype.set=function(e,t){var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:null;typecheck("Environment::set",e,["string","symbol"]);if(LNumber.isNumber(t)){t=LNumber(t)}if(e instanceof LSymbol){e=e.__name__}if(e instanceof LString){e=e.valueOf()}this.__env__[e]=t;if(r){this.doc(e,r,true)}return this};Environment.prototype.constant=function(t,e){var r=this;if(this.__env__.hasOwnProperty(t)){throw new Error("Environment::constant: ".concat(t," already exists"))}if(arguments.length===1&&is_plain_object(arguments[0])){var n=arguments[0];Object.keys(n).forEach(function(e){r.constant(t,n[e])})}else{Object.defineProperty(this.__env__,t,{value:e,enumerable:true})}return this};Environment.prototype.has=function(e){return this.__env__.hasOwnProperty(e)};Environment.prototype.ref=function(e){var t=this;while(true){if(!t){break}if(t.has(e)){return t}t=t.__parent__}};Environment.prototype.parents=function(){var e=this;var t=[];while(e){t.unshift(e);e=e.__parent__}return t};function quote(e){if(is_promise(e)){return e.then(quote)}if(e instanceof Pair||e instanceof LSymbol){e[__data__]=true}return e}var native_lambda=_parse(tokenize('(lambda ()\n "[native code]"\n (throw "Invalid Invocation"))'))[0];var get=doc("get",function e(t){var r;for(var n=arguments.length,i=new Array(n>1?n-1:0),a=1;a0&&arguments[0]!==undefined?arguments[0]:null;if(e===null){e=internal(this,"stdin")}typecheck_text_port("peek-char",e,"input-port");return e.peek_char()},"(peek-char port)\n\n This function reads and returns a character from the string\n port, or, if there is no more data in the string port, it\n returns an EOF."),"read-line":doc("read-line",function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:null;if(e===null){e=internal(this,"stdin")}typecheck_text_port("read-line",e,"input-port");return e.read_line()},"(read-line port)\n\n This function reads and returns the next line from the input\n port."),"read-char":doc("read-char",function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:null;if(e===null){e=internal(this,"stdin")}typecheck_text_port("read-char",e,"input-port");return e.read_char()},"(read-char port)\n\n This function reads and returns the next character from the\n input port."),read:doc("read",function(){var e=_asyncToGenerator(function(){var l=this;var f=arguments.length>0&&arguments[0]!==undefined?arguments[0]:null;return _regeneratorRuntime.mark(function e(){var r,n,i,a,o,u,s,c;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:r=l.env;if(!LString.isString(f)){t.next=30;break}n=false;i=false;t.prev=4;o=_asyncIterator(_parse(f,r));case 6:t.next=8;return o.next();case 8:if(!(n=!(u=t.sent).done)){t.next=14;break}s=u.value;return t.abrupt("return",s);case 11:n=false;t.next=6;break;case 14:t.next=20;break;case 16:t.prev=16;t.t0=t["catch"](4);i=true;a=t.t0;case 20:t.prev=20;t.prev=21;if(!(n&&o["return"]!=null)){t.next=25;break}t.next=25;return o["return"]();case 25:t.prev=25;if(!i){t.next=28;break}throw a;case 28:return t.finish(25);case 29:return t.finish(20);case 30:if(f===null){c=internal(r,"stdin")}else{c=f}typecheck_text_port("read",c,"input-port");return t.abrupt("return",c.read.call(r));case 33:case"end":return t.stop()}},e,null,[[4,16,20,30],[21,,25,29]])})()});function t(){return e.apply(this,arguments)}return t}(),"(read [string])\n\n This function, if used with a string, will parse it and\n return the LIPS code, if there is any. If called with a\n port, it will parse the next item from the port. If called\n without an input, it will read a string from standard input\n (using the browser's prompt or a user defined input method)\n and calls itself with that string. This function can be used\n together with `eval` to evaluate code from a string."),pprint:doc("pprint",function e(t){if(t instanceof Pair){t=new lips.Formatter(t.toString(true))["break"]().format();global_env.get("display").call(global_env,t)}else{global_env.get("write").call(global_env,t)}global_env.get("newline").call(global_env)},"(pprint expression)\n\n This function will pretty print its input to stdout. If it is called\n with a non-list, it will just call the print function on its\n input."),print:doc("print",function e(){var t=global_env.get("display");var r=global_env.get("newline");var n=this.use_dynamic;var i=global_env;var a=global_env;for(var o=arguments.length,u=new Array(o),s=0;s1?r-1:0),i=1;in.length){throw new Error("Not enough arguments")}var u=0;var s=global_env.get("repr");t=t.replace(a,function(e){var t=e[1];if(t==="~"){return"~"}else if(t==="%"){return"\n"}else{var r=n[u++];if(t==="a"){return s(r)}else{return s(r,true)}}});o=t.match(/~([\S])/);if(o){throw new Error("format: Unrecognized escape sequence ".concat(o[1]))}return t},"(format string n1 n2 ...)\n\n This function accepts a string template and replaces any\n escape sequences in its inputs:\n\n * ~a value as if printed with `display`\n * ~s value as if printed with `write`\n * ~% newline character\n * ~~ literal tilde '~'\n\n If there are missing inputs or other escape characters it\n will error."),display:doc("display",function e(t){var r=arguments.length>1&&arguments[1]!==undefined?arguments[1]:null;if(r===null){r=internal(this,"stdout")}else{typecheck("display",r,"output-port")}var n=t;if(!(r instanceof OutputBinaryFilePort)){n=global_env.get("repr")(t)}r.write.call(global_env,n)},"(display string [port])\n\n This function outputs the string to the standard output or\n the port if given. No newline."),"display-error":doc("display-error",function e(){var t=internal(this,"stderr");var r=global_env.get("repr");for(var n=arguments.length,i=new Array(n),a=0;a1&&arguments[1]!==undefined?arguments[1]:{},r=t.use_dynamic,n=_objectWithoutProperties(t,_excluded4);var i=this;var o=this;var u;var s=_objectSpread(_objectSpread({},n),{},{env:this,dynamic_env:i,use_dynamic:r});var c=_evaluate(e.cdr.car,s);c=resolve_promises(c);function l(t,r,n){if(is_promise(t)){return t.then(function(e){return l(t,e,n)})}if(is_promise(r)){return r.then(function(e){return l(t,e,n)})}if(is_promise(n)){return n.then(function(e){return l(t,r,e)})}o.get("set-obj!").call(o,t,r,n);return n}if(e.car instanceof Pair&&LSymbol.is(e.car.car,".")){var f=e.car.cdr.car;var _=e.car.cdr.cdr.car;var p=_evaluate(f,s);var h=_evaluate(_,s);return l(p,h,c)}if(!(e.car instanceof LSymbol)){throw new Error("set! first argument need to be a symbol or "+"dot accessor that evaluate to object.")}var d=e.car.valueOf();u=this.ref(e.car.__name__);return unpromise(c,function(e){if(!u){var t=d.split(".");if(t.length>1){var r=t.pop();var n=t.join(".");var i=a.get(n,{throwError:false});if(i){l(i,r,e);return}}throw new Error("Unbound variable `"+d+"'")}u.set(d,e)})}),"(set! name value)\n\n Macro that can be used to set the value of the variable or slot (mutate it).\n set! searches the scope chain until it finds first non empty slot and sets it."),"unset!":doc(new Macro("set!",function(e){if(!(e.car instanceof LSymbol)){throw new Error("unset! first argument need to be a symbol or "+"dot accessor that evaluate to object.")}var t=e.car;var r=this.ref(t);if(r){delete r.__env__[t.__name__]}}),"(unset! name)\n\n Function to delete the specified name from environment.\n Trying to access the name afterwards will error."),"set-car!":doc("set-car!",function(e,t){typecheck("set-car!",e,"pair");e.car=t},"(set-car! obj value)\n\n Function that sets the car (first item) of the list/pair to specified value.\n The old value is lost."),"set-cdr!":doc("set-cdr!",function(e,t){typecheck("set-cdr!",e,"pair");e.cdr=t},"(set-cdr! obj value)\n\n Function that sets the cdr (tail) of the list/pair to specified value.\n It will destroy the list. The old tail is lost."),"empty?":doc("empty?",function(e){return typeof e==="undefined"||e===_nil},"(empty? object)\n\n Function that returns #t if value is nil (an empty list) or undefined."),gensym:doc("gensym",gensym,"(gensym)\n\n Generates a unique symbol that is not bound anywhere,\n to use with macros as meta name."),load:doc("load",function e(u,t){typecheck("load",u,"string");var s=this;if(s.__name__==="__frame__"){s=s.__parent__}if(!(t instanceof Environment)){if(s===global_env){t=s}else{t=this.get("**interaction-environment**")}}var c="**module-path**";var l=global_env.get(c,{throwError:false});u=u.valueOf();if(!u.match(/.[^.]+$/)){u+=".scm"}var r=u.match(/\.xcb$/);function f(e){if(r){e=unserialize_bin(e)}else{if(type(e)==="buffer"){e=e.toString()}e=e.replace(/^#!.*/,"");if(e.match(/^\{/)){e=unserialize(e)}}return exec(e,{env:t})}function n(e){return root.fetch(e).then(function(e){return r?e.arrayBuffer():e.text()}).then(function(e){if(r){e=new Uint8Array(e)}return e})}if(is_node()){return new Promise(function(){var r=_asyncToGenerator(_regeneratorRuntime.mark(function e(r,n){var i,a,o;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:i=nodeRequire("path");if(!l){t.next=6;break}l=l.valueOf();u=i.join(l,u);t.next=12;break;case 6:a=s.get("command-line",{throwError:false});if(!a){t.next=11;break}t.next=10;return a();case 10:o=t.sent;case 11:if(o&&o!==_nil){process.cwd();u=i.join(i.dirname(o.car.valueOf()),u)}case 12:global_env.set(c,i.dirname(u));nodeRequire("fs").readFile(u,function(e,t){if(e){n(e);global_env.set(c,l)}else{try{f(t).then(function(){r();global_env.set(c,l)})["catch"](n)}catch(e){n(e)}}});case 14:case"end":return t.stop()}},e)}));return function(e,t){return r.apply(this,arguments)}}())}if(l){l=l.valueOf();u=l+"/"+u.replace(/^\.?\/?/,"")}return n(u).then(function(e){global_env.set(c,u.replace(/\/[^/]*$/,""));return f(e)}).then(function(){})["finally"](function(){global_env.set(c,l)})},"(load filename)\n (load filename environment)\n\n Fetches the file (from disk or network) and evaluates its content as LIPS code.\n If the second argument is provided and it's an environment the evaluation\n will happen in that environment."),while:doc(new Macro("while",function(e,t){var r=e.car;var n=_objectSpread(_objectSpread({},t),{},{env:this});var i=new Pair(new LSymbol("begin"),e.cdr);return function t(){return unpromise(_evaluate(r,n),function(e){if(e){return unpromise(_evaluate(i,n),t)}})}()}),"(while cond body)\n\n Creates a loop, it executes cond and body until cond expression is false."),do:doc(new Macro("do",function(){var r=_asyncToGenerator(function(_,e){var p=this;var h=e.use_dynamic,d=e.error;return _regeneratorRuntime.mark(function e(){var r,n,u,s,i,c,l,a,o,f;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:r=p;n=r;u=r.inherit("do");s=_.car;i=_.cdr.car;c=_.cdr.cdr;if(c!==_nil){c=new Pair(LSymbol("begin"),c)}l={env:r,dynamic_env:n,use_dynamic:h,error:d};a=s;case 9:if(!(a!==_nil)){t.next=20;break}o=a.car;t.t0=u;t.t1=o.car;t.next=15;return _evaluate(o.cdr.car,l);case 15:t.t2=t.sent;t.t0.set.call(t.t0,t.t1,t.t2);a=a.cdr;t.next=9;break;case 20:l={env:u,dynamic_env:n,error:d};f=_regeneratorRuntime.mark(function e(){var r,n,i,a,o;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(!(c!==_nil)){t.next=3;break}t.next=3;return lips.evaluate(c,l);case 3:r=s;n={};case 5:if(!(r!==_nil)){t.next=15;break}i=r.car;if(!(i.cdr.cdr!==_nil)){t.next=12;break}t.next=10;return _evaluate(i.cdr.cdr.car,l);case 10:a=t.sent;n[i.car.valueOf()]=a;case 12:r=r.cdr;t.next=5;break;case 15:o=Object.getOwnPropertySymbols(n);Object.keys(n).concat(o).forEach(function(e){u.set(e,n[e])});case 17:case"end":return t.stop()}},e)});case 22:t.next=24;return _evaluate(i.car,l);case 24:t.t3=t.sent;if(!(t.t3===false)){t.next=29;break}return t.delegateYield(f(),"t4",27);case 27:t.next=22;break;case 29:if(!(i.cdr!==_nil)){t.next=33;break}t.next=32;return _evaluate(i.cdr.car,l);case 32:return t.abrupt("return",t.sent);case 33:case"end":return t.stop()}},e)})()});return function(e,t){return r.apply(this,arguments)}}()),"(do (( )) (test return) . body)\n\n Iteration macro that evaluates the expression body in scope of the variables.\n On each loop it changes the variables according to the expression and runs\n test to check if the loop should continue. If test is a single value, the macro\n will return undefined. If the test is a pair of expressions the macro will\n evaluate and return the second expression after the loop exits."),if:doc(new Macro("if",function(r,e){var t=e.error,n=e.use_dynamic;var i=this;var a=this;var o={env:a,dynamic_env:i,use_dynamic:n,error:t};var u=function e(t){if(t===false){return _evaluate(r.cdr.cdr.car,o)}else{return _evaluate(r.cdr.car,o)}};if(r===_nil){throw new Error("too few expressions for `if`")}var s=_evaluate(r.car,o);return unpromise(s,u)}),"(if cond true-expr false-expr)\n\n Macro that evaluates cond expression and if the value is true, it\n evaluates and returns true-expression, if not it evaluates and returns\n false-expression."),"let-env":new Macro("let-env",function(t){var e=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};var r=e.dynamic_env,n=e.use_dynamic,i=e.error;typecheck("let-env",t,"pair");var a=_evaluate(t.car,{env:this,dynamic_env:r,error:i,use_dynamic:n});return unpromise(a,function(e){typecheck("let-env",e,"environment");return _evaluate(Pair(LSymbol("begin"),t.cdr),{env:e,dynamic_env:r,error:i})})},"(let-env env . body)\n\n Special macro that evaluates body in context of given environment\n object."),letrec:doc(let_macro(Symbol["for"]("letrec")),"(letrec ((a value-a) (b value-b) ...) . body)\n\n Macro that creates a new environment, then evaluates and assigns values to\n names and then evaluates the body in context of that environment.\n Values are evaluated sequentially and the next value can access the\n previous values/names."),"letrec*":doc(let_macro(Symbol["for"]("letrec")),"(letrec* ((a value-a) (b value-b) ...) . body)\n\n Same as letrec but the order of execution of the binding is guaranteed,\n so you can use recursive code as well as referencing the previous binding.\n\n In LIPS both letrec and letrec* behave the same."),"let*":doc(let_macro(Symbol["for"]("let*")),"(let* ((a value-a) (b value-b) ...) . body)\n\n Macro similar to `let`, but the subsequent bindings after the first\n are evaluated in the environment including the previous let variables,\n so you can define one variable, and use it in the next's definition."),let:doc(let_macro(Symbol["for"]("let")),"(let ((a value-a) (b value-b) ...) . body)\n\n Macro that creates a new environment, then evaluates and assigns values to names,\n and then evaluates the body in context of that environment. Values are evaluated\n sequentially but you can't access previous values/names when the next are\n evaluated. You can only get them in the body of the let expression. (If you want\n to define multiple variables and use them in each other's definitions, use\n `let*`.)"),"begin*":doc(parallel("begin*",function(e){return e.pop()}),"(begin* . body)\n\n This macro is a parallel version of begin. It evaluates each expression\n in the body and if it's a promise it will await it in parallel and return\n the value of the last expression (i.e. it uses Promise.all())."),shuffle:doc("shuffle",function(e){typecheck("shuffle",e,["pair","nil","array"]);var t=global_env.get("random");if(e===_nil){return _nil}if(Array.isArray(e)){return shuffle(e.slice(),t)}var r=global_env.get("list->array")(e);r=shuffle(r,t);return global_env.get("array->list")(r)},"(shuffle obj)\n\n Order items in vector or list in random order."),begin:doc(new Macro("begin",function(e,t){var n=_objectSpread(_objectSpread({},t),{},{env:this});var i=global_env.get("list->array")(e);var a;return function t(){if(i.length){var e=i.shift();var r=_evaluate(e,n);return unpromise(r,function(e){a=e;return t()})}else{return a}}()}),"(begin . args)\n\n Macro that runs a list of expressions in order and returns the value\n of the last one. It can be used in places where you can only have a\n single expression, like (if)."),ignore:new Macro("ignore",function(e,t){var r=_objectSpread(_objectSpread({},t),{},{env:this,dynamic_env:this});_evaluate(new Pair(new LSymbol("begin"),e),r)},"(ignore . body)\n\n Macro that will evaluate the expression and swallow any promises that may\n be created. It will discard any value that may be returned by the last body\n expression. The code should have side effects and/or when it's promise\n it should resolve to undefined."),"call/cc":doc(Macro.defmacro("call/cc",function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};var r=_objectSpread({env:this},t);return unpromise(_evaluate(e.car,r),function(e){if(is_function(e)){return e(new Continuation(null))}})}),"(call/cc proc)\n\n Call-with-current-continuation.\n\n NOT SUPPORTED BY LIPS RIGHT NOW"),parameterize:doc(new Macro("parameterize",function(t,e){var i=e.dynamic_env;var a=i.inherit("parameterize").new_frame(null,{});var o=_objectSpread(_objectSpread({},e),{},{env:this});var u=t.car;if(!is_pair(u)){var r=type(u);throw new Error("Invalid syntax for parameterize expecting pair got ".concat(r))}function s(){var e=new Pair(new LSymbol("begin"),t.cdr);return _evaluate(e,_objectSpread(_objectSpread({},o),{},{dynamic_env:a}))}return function r(){var e=u.car;var n=e.car.valueOf();return unpromise(_evaluate(e.cdr.car,o),function(e){var t=i.get(n,{throwError:false});if(!is_parameter(t)){throw new Error("Unknown parameter ".concat(n))}a.set(n,t.inherit(e));if(!is_null(u.cdr)){u=u.cdr;return r()}else{return s()}})}()}),"(parameterize ((name value) ...)\n\n Macro that change the dynamic variable created by make-parameter."),"make-parameter":doc(new Macro("make-parameter",function(e,t){t.dynamic_env;var r=_evaluate(e.car,t);var n;if(e.cdr.car instanceof Pair){n=_evaluate(e.cdr.car,t)}return new Parameter(r,n)}),"(make-parameter init converter)\n\n Function creates new dynamic variable that can be custimized with parameterize\n macro. The value should be assigned to a variable e.g.:\n\n (define radix (make-parameter 10))\n\n The result value is a procedure that return the value of dynamic variable."),"define-syntax-parameter":doc(new Macro("define-syntax-parameter",function(e,t){var r=e.car;var n=this;if(!(r instanceof LSymbol)){throw new Error("define-syntax-parameter: invalid syntax expecting symbol got ".concat(type(r)))}var i=_evaluate(e.cdr.car,_objectSpread({env:n},t));typecheck("define-syntax-parameter",i,"syntax",2);i.__name__=r.valueOf();if(i.__name__ instanceof LString){i.__name__=i.__name__.valueOf()}var a;if(e.cdr.cdr instanceof Pair&&LString.isString(e.cdr.cdr.car)){a=e.cdr.cdr.car.valueOf()}n.set(e.car,new SyntaxParameter(i),a,true)}),"(define-syntax-parameter name syntax [__doc__])\n\n Binds to the transformer obtained by evaluating .\n The transformer provides the default expansion for the syntax parameter,\n and in the absence of syntax-parameterize, is functionally equivalent to\n define-syntax."),"syntax-parameterize":doc(new Macro("syntax-parameterize",function(e,t){var r=global_env.get("list->array")(e.car);var n=this.inherit("syntax-parameterize");while(r.length){var i=r.shift();if(!(is_pair(i)||i.car instanceof LSymbol)){var a="invalid syntax for syntax-parameterize: ".concat(repr(e,true));throw new Error("syntax-parameterize: ".concat(a))}var o=_evaluate(i.cdr.car,_objectSpread(_objectSpread({},t),{},{env:this}));var u=i.car;typecheck("syntax-parameterize",o,["syntax"]);typecheck("syntax-parameterize",u,"symbol");o.__name__=u.valueOf();if(o.__name__ instanceof LString){o.__name__=o.__name__.valueOf()}var s=new SyntaxParameter(o);if(u.is_gensym()){var c=u.literal();var l=this.get(c,{throwError:false});if(l instanceof SyntaxParameter){n.set(c,s)}}n.set(u,s)}var f=new Pair(new LSymbol("begin"),e.cdr);return _evaluate(f,_objectSpread(_objectSpread({},t),{},{env:n}))}),"(syntax-parameterize (bindings) body)\n\n Macro work similar to let-syntax but the the bindnds will be exposed to the user.\n With syntax-parameterize you can define anaphoric macros."),define:doc(Macro.defmacro("define",function(r,e){var n=this;if(r.car instanceof Pair&&r.car.car instanceof LSymbol){var t=new Pair(new LSymbol("define"),new Pair(r.car.car,new Pair(new Pair(new LSymbol("lambda"),new Pair(r.car.cdr,r.cdr)))));return t}else if(e.macro_expand){return}e.dynamic_env=this;e.env=n;var i=r.cdr.car;var a;if(i instanceof Pair){i=_evaluate(i,e);a=true}else if(i instanceof LSymbol){i=n.get(i)}typecheck("define",r.car,"symbol");return unpromise(i,function(e){if(n.__name__===Syntax.__merge_env__){n=n.__parent__}if(a&&(is_function(e)&&is_lambda(e)||e instanceof Syntax||is_parameter(e))){e.__name__=r.car.valueOf();if(e.__name__ instanceof LString){e.__name__=e.__name__.valueOf()}}var t;if(r.cdr.cdr instanceof Pair&&LString.isString(r.cdr.cdr.car)){t=r.cdr.cdr.car.valueOf()}n.set(r.car,e,t,true)})}),'(define name expression)\n (define name expression "doc string")\n (define (function-name . args) . body)\n\n Macro for defining values. It can be used to define variables,\n or functions. If the first argument is list it will create a function\n with name being first element of the list. This form expands to\n `(define function-name (lambda args body))`'),"set-obj!":doc("set-obj!",function(e,t,r){var n=arguments.length>3&&arguments[3]!==undefined?arguments[3]:null;var i=_typeof$1(e);if(is_null(e)||i!=="object"&&i!=="function"){var a=typeErrorMessage("set-obj!",type(e),["object","function"]);throw new Error(a)}typecheck("set-obj!",t,["string","symbol","number"]);e=unbind(e);t=t.valueOf();if(arguments.length===2){delete e[t]}else if(is_prototype(e)&&is_function(r)){e[t]=unbind(r);e[t][__prototype__]=true}else if(is_function(r)||is_native(r)||r===_nil){e[t]=r}else{e[t]=r&&!is_prototype(r)?r.valueOf():r}if(props){var o=e[t];Object.defineProperty(e,t,_objectSpread(_objectSpread({},n),{},{value:o}))}},"(set-obj! obj key value)\n (set-obj! obj key value props)\n\n Function set a property of a JavaScript object. props should be a vector of pairs,\n passed to Object.defineProperty."),"null-environment":doc("null-environment",function(){return global_env.inherit("null")},"(null-environment)\n\n Returns a clean environment with only the standard library."),values:doc("values",function e(){for(var t=arguments.length,r=new Array(t),n=0;n1&&arguments[1]!==undefined?arguments[1]:{},y=e.use_dynamic,v=e.error;var g=this;var b;if(m.cdr instanceof Pair&&LString.isString(m.cdr.car)&&m.cdr.cdr!==_nil){b=m.cdr.car.valueOf()}function w(){var e=is_context(this)?this:{dynamic_env:g},r=e.dynamic_env;var n=g.inherit("lambda");r=r.inherit("lambda");if(this&&!is_context(this)){if(this&&!this.__instance__){Object.defineProperty(this,"__instance__",{enumerable:false,get:function e(){return true},set:function e(){},configurable:false})}n.set("this",this)}for(var t=arguments.length,i=new Array(t),a=0;a> SYNTAX");log(e);log(v);var n=w.inherit("syntax");var i=n;var a=this;if(a.__name__===Syntax.__merge_env__){var o=Object.getOwnPropertySymbols(a.__env__);o.forEach(function(e){a.__parent__.set(e,a.__env__[e])});a=a.__parent__}var u={env:n,dynamic_env:i,use_dynamic:g,error:b};var s,c,l;if(v.car instanceof LSymbol){s=v.car;l=D(v.cdr.car);c=v.cdr.cdr}else{s="...";l=D(v.car);c=v.cdr}try{while(c!==_nil){var f=c.car.car;var _=c.car.cdr.car;log("[[[ RULE");log(f);var p=extract_patterns(f,e,l,s,{expansion:this,define:w});if(p){if(is_debug()){console.log(JSON.stringify(symbolize(p),true,2));console.log("PATTERN: "+f.toString(true));console.log("MACRO: "+e.toString(true))}var h=[];var d=transform_syntax({bindings:p,expr:_,symbols:l,scope:n,lex_scope:a,names:h,ellipsis:s});log("OUPUT>>> ",d);if(d){_=d}var m=a.merge(n,Syntax.__merge_env__);if(r){return{expr:_,scope:m}}var y=_evaluate(_,_objectSpread(_objectSpread({},u),{},{env:m}));return clear_gensyms(y,h)}c=c.cdr}}catch(e){e.message+="\nin macro:\n ".concat(v.toString(true));throw e}throw new Error("syntax-rules: no matching syntax in macro ".concat(e.toString(true)))},w);r.__code__=v;return r},"(syntax-rules () (pattern expression) ...)\n\n Base of hygienic macros, it will return a new syntax expander\n that works like Lisp macros."),quote:doc(new Macro("quote",function(e){return quote(e.car)}),"(quote expression) or 'expression\n\n Macro that returns a single LIPS expression as data (it won't evaluate the\n argument). It will return a list if put in front of LIPS code.\n And if put in front of a symbol it will return the symbol itself, not the value\n bound to that name."),"unquote-splicing":doc("unquote-splicing",function(){throw new Error("You can't call `unquote-splicing` outside of quasiquote")},"(unquote-splicing code) or ,@code\n\n Special form used in the quasiquote macro. It evaluates the expression inside and\n splices the list into quasiquote's result. If it is not the last element of the\n expression, the computed value must be a pair."),unquote:doc("unquote",function(){throw new Error("You can't call `unquote` outside of quasiquote")},"(unquote code) or ,code\n\n Special form used in the quasiquote macro. It evaluates the expression inside and\n substitutes the value into quasiquote's result."),quasiquote:Macro.defmacro("quasiquote",function(e,t){var u=t.use_dynamic,s=t.error;var c=this;var l=c;function a(e){return e instanceof Pair||is_plain_object(e)||Array.isArray(e)}function f(e,t){var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:a;if(e instanceof Pair){var n=e.car;var i=e.cdr;if(r(n)){n=t(n)}if(r(i)){i=t(i)}if(is_promise(n)||is_promise(i)){return promise_all([n,i]).then(function(e){var t=_slicedToArray(e,2),r=t[0],n=t[1];return new Pair(r,n)})}else{return new Pair(n,i)}}return e}function o(e,t){if(e instanceof Pair){if(t!==_nil){e.append(t)}}else{e=new Pair(e,t)}return e}function r(e){return!!e.filter(function(e){return e instanceof Pair&&LSymbol.is(e.car,/^(unquote|unquote-splicing)$/)}).length}function _(e,n,i){return e.reduce(function(e,t){if(!(t instanceof Pair)){e.push(t);return e}if(LSymbol.is(t.car,"unquote-splicing")){var r;if(n+11){var t="You can't splice multiple atoms inside list";throw new Error(t)}if(!(i.cdr instanceof Pair&&r[0]===_nil)){return r[0]}}r=r.map(function(e){if(d.has(e)){return e.clone()}else{d.add(e);return e}});var n=m(i.cdr,0,1);if(n===_nil&&r[0]===_nil){return undefined}return unpromise(n,function(e){if(r[0]===_nil){return e}if(r.length===1){return o(r[0],e)}var t=r.reduce(function(e,t){return o(e,t)});return o(t,e)})})}(i.car.cdr)}var d=new Set;function m(e,t,r){if(e instanceof Pair){if(e.car instanceof Pair){if(LSymbol.is(e.car.car,"unquote-splicing")){return h(e,t+1,r)}if(LSymbol.is(e.car.car,"unquote")){if(t+2===r&&e.car.cdr instanceof Pair&&e.car.cdr.car instanceof Pair&&LSymbol.is(e.car.cdr.car.car,"unquote-splicing")){var n=e.car.cdr;return new Pair(new Pair(new LSymbol("unquote"),h(n,t+2,r)),_nil)}else if(e.car.cdr instanceof Pair&&e.car.cdr.cdr!==_nil){if(e.car.cdr.car instanceof Pair){var i=[];return function t(r){if(r===_nil){return Pair.fromArray(i)}return unpromise(_evaluate(r.car,{env:c,dynamic_env:l,use_dynamic:u,error:s}),function(e){i.push(e);return t(r.cdr)})}(e.car.cdr)}else{return e.car.cdr}}}}if(LSymbol.is(e.car,"quasiquote")){var a=m(e.cdr,t,r+1);return new Pair(e.car,a)}if(LSymbol.is(e.car,"quote")){return new Pair(e.car,m(e.cdr,t,r))}if(LSymbol.is(e.car,"unquote")){t++;if(tr){throw new Error("You can't call `unquote` outside "+"of quasiquote")}if(e.cdr instanceof Pair){if(e.cdr.cdr!==_nil){if(e.cdr.car instanceof Pair){var o=[];return function t(r){if(r===_nil){return Pair.fromArray(o)}return unpromise(_evaluate(r.car,{env:c,dynamic_env:l,use_dynamic:u,error:s}),function(e){o.push(e);return t(r.cdr)})}(e.cdr)}else{return e.cdr}}else{return _evaluate(e.cdr.car,{env:c,dynamic_env:l,error:s})}}else{return e.cdr}}return f(e,function(e){return m(e,t,r)})}else if(is_plain_object(e)){return p(e,t,r)}else if(e instanceof Array){return _(e,t,r)}return e}function n(e){if(e instanceof Pair){delete e[__data__];if(!e.haveCycles("car")){n(e.car)}if(!e.haveCycles("cdr")){n(e.cdr)}}}if(is_plain_object(e.car)&&!r(Object.values(e.car))){return quote(e.car)}if(Array.isArray(e.car)&&!r(e.car)){return quote(e.car)}if(e.car instanceof Pair&&!e.car.find("unquote")&&!e.car.find("unquote-splicing")&&!e.car.find("quasiquote")){return quote(e.car)}var i=m(e.car,0,1);return unpromise(i,function(e){n(e);return quote(e)})},"(quasiquote list)\n\n Similar macro to `quote` but inside it you can use special expressions (unquote\n x) abbreviated to ,x that will evaluate x and insert its value verbatim or\n (unquote-splicing x) abbreviated to ,@x that will evaluate x and splice the value\n into the result. Best used with macros but it can be used outside."),clone:doc("clone",function e(t){typecheck("clone",t,"pair");return t.clone()},"(clone list)\n\n Function that returns a clone of the list, that does not share any pairs with the\n original, so the clone can be safely mutated without affecting the original."),append:doc("append",function e(){var t;for(var r=arguments.length,n=new Array(r),i=0;iarray")(t).reverse();return global_env.get("array->list")(r)}else if(Array.isArray(t)){return t.reverse()}else{throw new Error(typeErrorMessage("reverse",type(t),"array or pair"))}},"(reverse list)\n\n Function that reverses the list or array. If value is not a list\n or array it will error."),nth:doc("nth",function e(t,r){typecheck("nth",t,"number");typecheck("nth",r,["array","pair"]);if(r instanceof Pair){var n=r;var i=0;while(iarray")(r).join(t)},"(join separator list)\n\n Function that returns a string by joining elements of the list using separator."),split:doc("split",function e(t,r){typecheck("split",t,["regex","string"]);typecheck("split",r,"string");return global_env.get("array->list")(r.split(t))},"(split separator string)\n\n Function that creates a list by splitting string by separator which can\n be a string or regular expression."),replace:doc("replace",function e(t,r,n){typecheck("replace",t,["regex","string"]);typecheck("replace",r,["string","function"]);typecheck("replace",n,"string");return n.replace(t,r)},"(replace pattern replacement string)\n\n Function that changes pattern to replacement inside string. Pattern can be a\n string or regex and replacement can be function or string. See Javascript\n String.replace()."),match:doc("match",function e(t,r){typecheck("match",t,["regex","string"]);typecheck("match",r,"string");var n=r.match(t);return n?global_env.get("array->list")(n):false},"(match pattern string)\n\n Function that returns a match object from JavaScript as a list or #f if\n no match."),search:doc("search",function e(t,r){typecheck("search",t,["regex","string"]);typecheck("search",r,"string");return r.search(t)},"(search pattern string)\n\n Function that returns the first found index of the pattern inside a string."),repr:doc("repr",function e(t,r){return toString(t,r)},"(repr obj)\n\n Function that returns a LIPS code representation of the object as a string."),"escape-regex":doc("escape-regex",function(e){typecheck("escape-regex",e,"string");return escape_regex(e.valueOf())},"(escape-regex string)\n\n Function that returns a new string where all special operators used in regex,\n are escaped with backslashes so they can be used in the RegExp constructor\n to match a literal string."),env:doc("env",function e(e){e=e||this.env;var t=Object.keys(e.__env__).map(LSymbol);var r;if(t.length){r=Pair.fromArray(t)}else{r=_nil}if(e.__parent__ instanceof Environment){return global_env.get("env").call(this,e.__parent__).append(r)}return r},"(env)\n (env obj)\n\n Function that returns a list of names (functions, macros and variables)\n that are bound in the current environment or one of its parents."),new:doc("new",function(e){for(var t=arguments.length,r=new Array(t>1?t-1:0),n=1;n2&&arguments[2]!==undefined?arguments[2]:specials.LITERAL;typecheck("set-special!",e,"string",1);typecheck("set-special!",t,"symbol",2);specials.append(e.valueOf(),t,r)},'(set-special! symbol name [type])\n\n Add a special symbol to the list of transforming operators by the parser.\n e.g.: `(add-special! "#" \'x)` will allow to use `#(1 2 3)` and it will be\n transformed into (x (1 2 3)) so you can write x macro that will process\n the list. 3rd argument is optional, and it can be one of two values:\n lips.specials.LITERAL, which is the default behavior, or\n lips.specials.SPLICE which causes the value to be unpacked into the expression.\n This can be used for e.g. to make `#(1 2 3)` into (x 1 2 3) that is needed\n by # that defines vectors.'),get:get,".":get,unbind:doc(unbind,"(unbind fn)\n\n Function that removes the weak 'this' binding from a function so you\n can get properties from the actual function object."),type:doc(type,"(type object)\n\n Function that returns the type of an object as string."),debugger:doc("debugger",function(){debugger},'(debugger)\n\n Function that triggers the JavaScript debugger (e.g. the browser devtools)\n using the "debugger;" statement. If a debugger is not running this\n function does nothing.'),in:doc("in",function(e,t){if(e instanceof LSymbol||e instanceof LString||e instanceof LNumber){e=e.valueOf()}return e in unbox(t)},'(in key value)\n\n Function that uses the Javascript "in" operator to check if key is\n a valid property in the value.'),"instance?":doc("instance?",function(e){return is_instance(e)},"(instance? obj)\n\n Checks if object is an instance, created with a new operator"),instanceof:doc("instanceof",function(e,t){return t instanceof unbind(e)},"(instanceof type obj)\n\n Predicate that tests if the obj is an instance of type."),"prototype?":doc("prototype?",is_prototype,"(prototype? obj)\n\n Predicate that tests if value is a valid JavaScript prototype,\n i.e. calling (new) with it will not throw ' is not a constructor'."),"macro?":doc("macro?",function(e){return e instanceof Macro},"(macro? expression)\n\n Predicate that tests if value is a macro."),"continuation?":doc("continuation?",is_continuation,"(continuation? expression)\n\n Predicate that tests if value is a callable continuation."),"function?":doc("function?",is_function,"(function? expression)\n\n Predicate that tests if value is a callable function."),"real?":doc("real?",function(e){if(type(e)!=="number"){return false}if(e instanceof LNumber){return e.isFloat()}return LNumber.isFloat(e)},"(real? number)\n\n Predicate that tests if value is a real number (not complex)."),"number?":doc("number?",function(e){return Number.isNaN(e)||LNumber.isNumber(e)},"(number? expression)\n\n Predicate that tests if value is a number or NaN value."),"string?":doc("string?",function(e){return LString.isString(e)},"(string? expression)\n\n Predicate that tests if value is a string."),"pair?":doc("pair?",function(e){return e instanceof Pair},"(pair? expression)\n\n Predicate that tests if value is a pair or list structure."),"regex?":doc("regex?",function(e){return e instanceof RegExp},"(regex? expression)\n\n Predicate that tests if value is a regular expression."),"null?":doc("null?",function(e){return is_null(e)},"(null? expression)\n\n Predicate that tests if value is null-ish (i.e. undefined, nil, or\n Javascript null)."),"boolean?":doc("boolean?",function(e){return typeof e==="boolean"},"(boolean? expression)\n\n Predicate that tests if value is a boolean (#t or #f)."),"symbol?":doc("symbol?",function(e){return e instanceof LSymbol},"(symbol? expression)\n\n Predicate that tests if value is a LIPS symbol."),"array?":doc("array?",function(e){return e instanceof Array},"(array? expression)\n\n Predicate that tests if value is an array."),"object?":doc("object?",function(e){return e!==_nil&&e!==null&&!(e instanceof LCharacter)&&!(e instanceof RegExp)&&!(e instanceof LString)&&!(e instanceof Pair)&&!(e instanceof LNumber)&&_typeof$1(e)==="object"&&!(e instanceof Array)},"(object? expression)\n\n Predicate that tests if value is an plain object (not another LIPS type)."),flatten:doc("flatten",function e(t){typecheck("flatten",t,"pair");return t.flatten()},"(flatten list)\n\n Returns a shallow list from tree structure (pairs)."),"array->list":doc("array->list",function(e){typecheck("array->list",e,"array");return Pair.fromArray(e)},"(array->list array)\n\n Function that converts a JavaScript array to a LIPS cons list."),"tree->array":doc("tree->array",to_array("tree->array",true),"(tree->array list)\n\n Function that converts a LIPS cons tree structure into a JavaScript array."),"list->array":doc("list->array",to_array("list->array"),"(list->array list)\n\n Function that converts a LIPS list into a JavaScript array."),apply:doc("apply",function e(t){for(var r=arguments.length,n=new Array(r>1?r-1:0),i=1;iarray").call(this,a));return t.apply(this,prepare_fn_args(t,n))},"(apply fn list)\n\n Function that calls fn with the list of arguments."),length:doc("length",function e(t){if(!t||t===_nil){return 0}if(t instanceof Pair){return t.length()}if("length"in t){return t.length}},'(length expression)\n\n Function that returns the length of the object. The object can be a LIPS\n list or any object that has a "length" property. Returns undefined if the\n length could not be found.'),"string->number":doc("string->number",function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:10;typecheck("string->number",e,"string",1);typecheck("string->number",t,"number",2);e=e.valueOf();t=t.valueOf();if(e.match(rational_bare_re)||e.match(rational_re)){return parse_rational(e,t)}else if(e.match(complex_bare_re)||e.match(complex_re)){return parse_complex(e,t)}else{var r=t===10&&!e.match(/e/i)||t===16;if(e.match(int_bare_re)&&r||e.match(int_re)){return parse_integer(e,t)}if(e.match(float_re)){return parse_float(e)}}return false},"(string->number number [radix])\n\n Function that parses a string into a number."),try:doc(new Macro("try",function(r,e){var f=this;var _=e.use_dynamic;e.error;return new Promise(function(t,u){var s,n;if(LSymbol.is(r.cdr.car.car,"catch")){s=r.cdr.car;if(r.cdr.cdr instanceof Pair&&LSymbol.is(r.cdr.cdr.car.car,"finally")){n=r.cdr.cdr.car}}else if(LSymbol.is(r.cdr.car.car,"finally")){n=r.cdr.car}if(!(n||s)){throw new Error("try: invalid syntax")}function c(e){t(e);throw new IgnoreException("[CATCH]")}var l=function e(t,r){r(t)};if(n){l=function e(t,r){l=u;i.error=function(e){throw e};unpromise(_evaluate(new Pair(new LSymbol("begin"),n.cdr),i),function(){r(t)})}}var i={env:f,use_dynamic:_,dynamic_env:f,error:function e(t){if(t instanceof IgnoreException){throw t}var r=f.inherit("try");if(s){var n=s.cdr.car.car;if(!(n instanceof LSymbol)){throw new Error("try: invalid syntax: catch require variable name")}r.set(n,t);var i;var a={env:r,use_dynamic:_,dynamic_env:f,error:function e(t){i=true;u(t);throw new IgnoreException("[CATCH]")}};var o=_evaluate(new Pair(new LSymbol("begin"),s.cdr.cdr),a);unpromise(o,function e(t){if(!i){l(t,c)}})}else{l(undefined,function(){throw t})}}};var e=_evaluate(r.car,i);unpromise(e,function(e){l(e,t)},i.error)})}),"(try expr (catch (e) code))\n (try expr (catch (e) code) (finally code))\n (try expr (finally code))\n\n Macro that executes expr and catches any exceptions thrown. If catch is provided\n it's executed when an error is thrown. If finally is provided it's always\n executed at the end."),raise:doc("raise",function(e){throw e},"(raise obj)\n\n Throws the object verbatim (no wrapping an a new Error)."),throw:doc("throw",function(e){throw new Error(e)},"(throw string)\n\n Throws a new exception."),find:doc("find",function t(r,n){typecheck("find",r,["regex","function"]);typecheck("find",n,["pair","nil"]);if(is_null(n)){return _nil}var e=matcher("find",r);return unpromise(e(n.car),function(e){if(e&&e!==_nil){return n.car}return t(r,n.cdr)})},"(find fn list)\n (find regex list)\n\n Higher-order function that finds the first value for which fn return true.\n If called with a regex it will create a matcher function."),"for-each":doc("for-each",function(e){var t;typecheck("for-each",e,"function");for(var r=arguments.length,n=new Array(r>1?r-1:0),i=1;i1?t-1:0),a=1;a3?n-3:0),a=3;a3?i-3:0),o=3;oarray")(r);var a=[];var o=matcher("filter",t);return function t(r){function e(e){if(e&&e!==_nil){a.push(n)}return t(++r)}if(r===i.length){return Pair.fromArray(a)}var n=i[r];return unpromise(o(n),e)}(0)},"(filter fn list)\n (filter regex list)\n\n Higher-order function that calls `fn` for each element of the list\n and return a new list for only those elements for which fn returns\n a truthy value. If called with a regex it will create a matcher function."),compose:doc(compose,"(compose . fns)\n\n Higher-order function that creates a new function that applies all functions\n from right to left and returns the last value. Reverse of pipe.\n e.g.:\n ((compose (curry + 2) (curry * 3)) 10) --\x3e (+ 2 (* 3 10)) --\x3e 32"),pipe:doc(pipe,"(pipe . fns)\n\n Higher-order function that creates a new function that applies all functions\n from left to right and returns the last value. Reverse of compose.\n e.g.:\n ((pipe (curry + 2) (curry * 3)) 10) --\x3e (* 3 (+ 2 10)) --\x3e 36"),curry:doc(curry,"(curry fn . args)\n\n Higher-order function that creates a curried version of the function.\n The result function will have partially applied arguments and it\n will keep returning one-argument functions until all arguments are provided,\n then it calls the original function with the accumulated arguments.\n\n e.g.:\n (define (add a b c d) (+ a b c d))\n (define add1 (curry add 1))\n (define add12 (add 2))\n (display (add12 3 4))"),gcd:doc("gcd",function e(){for(var t=arguments.length,r=new Array(t),n=0;nu?a%=u:u%=a}a=abs(s*r[o])/(a+u)}return LNumber(a)},"(lcm n1 n2 ...)\n\n Function that returns the least common multiple of the arguments."),"odd?":doc("odd?",single_math_op(function(e){return LNumber(e).isOdd()}),"(odd? number)\n\n Checks if number is odd."),"even?":doc("even?",single_math_op(function(e){return LNumber(e).isEven()}),"(even? number)\n\n Checks if number is even."),"*":doc("*",reduce_math_op(function(e,t){return LNumber(e).mul(t)},LNumber(1)),"(* . numbers)\n\n Multiplies all numbers passed as arguments. If single value is passed\n it will return that value."),"+":doc("+",reduce_math_op(function(e,t){return LNumber(e).add(t)},LNumber(0)),"(+ . numbers)\n\n Sums all numbers passed as arguments. If single value is passed it will\n return that value."),"-":doc("-",function(){for(var e=arguments.length,t=new Array(e),r=0;r":doc(">",function(){for(var e=arguments.length,t=new Array(e),r=0;r",t,["bigint","float","rational"]);return seq_compare(function(e,t){return LNumber(e).cmp(t)===1},t)},"(> x1 x2 x3 ...)\n\n Function that compares its numerical arguments and checks if they are\n monotonically decreasing, i.e. x1 > x2 and x2 > x3 and so on."),"<":doc("<",function(){for(var e=arguments.length,t=new Array(e),r=0;r=":doc(">=",function(){for(var e=arguments.length,t=new Array(e),r=0;r=",t,["bigint","float","rational"]);return seq_compare(function(e,t){return[0,1].includes(LNumber(e).cmp(t))},t)},"(>= x1 x2 ...)\n\n Function that compares its numerical arguments and checks if they are\n monotonically nonincreasing, i.e. x1 >= x2 and x2 >= x3 and so on."),"eq?":doc("eq?",equal,"(eq? a b)\n\n Function that compares two values if they are identical."),or:doc(new Macro("or",function(e,t){var i=t.use_dynamic,a=t.error;var o=global_env.get("list->array")(e);var u=this;var s=u;if(!o.length){return false}var c;return function t(){function e(e){c=e;if(c!==false){return c}else{return t()}}if(!o.length){if(c!==false){return c}else{return false}}else{var r=o.shift();var n=_evaluate(r,{env:u,dynamic_env:s,use_dynamic:i,error:a});return unpromise(n,e)}}()}),"(or . expressions)\n\n Macro that executes the values one by one and returns the first that is\n a truthy value. If there are no expressions that evaluate to true it\n returns false."),and:doc(new Macro("and",function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},r=t.use_dynamic,n=t.error;var i=global_env.get("list->array")(e);var a=this;var o=a;if(!i.length){return true}var u;var s={env:a,dynamic_env:o,use_dynamic:r,error:n};return function t(){function e(e){u=e;if(u===false){return false}else{return t()}}if(!i.length){if(u!==false){return u}else{return false}}else{var r=i.shift();return unpromise(_evaluate(r,s),e)}}()}),"(and . expressions)\n\n Macro that evaluates each expression in sequence and if any value returns false\n it will stop and return false. If each value returns true it will return the\n last value. If it's called without arguments it will return true."),"|":doc("|",function(e,t){return LNumber(e).or(t)},"(| a b)\n\n Function that calculates the bitwise or operation."),"&":doc("&",function(e,t){return LNumber(e).and(t)},"(& a b)\n\n Function that calculates the bitwise and operation."),"~":doc("~",function(e){return LNumber(e).neg()},"(~ number)\n\n Function that calculates the bitwise inverse (flip all the bits)."),">>":doc(">>",function(e,t){return LNumber(e).shr(t)},"(>> a b)\n\n Function that right shifts the value a by value b bits."),"<<":doc("<<",function(e,t){return LNumber(e).shl(t)},"(<< a b)\n\n Function that left shifts the value a by value b bits."),not:doc("not",function e(t){if(is_null(t)){return true}return!t},"(not object)\n\n Function that returns the Boolean negation of its argument.")},undefined,"global");var user_env=global_env.inherit("user-env");function set_interaction_env(e,t){e.constant("**internal-env**",t);e.doc("**internal-env**","**internal-env**\n\n Constant used to hide stdin, stdout and stderr so they don't interfere\n with variables with the same name. Constants are an internal type\n of variable that can't be redefined, defining a variable with the same name\n will throw an error.");global_env.set("**interaction-environment**",e)}set_interaction_env(user_env,internal_env);global_env.doc("**interaction-environment**","**interaction-environment**\n\n Internal dynamic, global variable used to find interpreter environment.\n It's used so the read and write functions can locate **internal-env**\n that contains the references to stdin, stdout and stderr.");function set_fs(e){user_env.get("**internal-env**").set("fs",e)}(function(){var e={ceil:"ceiling"};["floor","round","ceil"].forEach(function(t){var r=e[t]?e[t]:t;global_env.set(r,doc(r,function(e){typecheck(r,e,"number");if(e instanceof LNumber){return e[t]()}},"(".concat(r," number)\n\n Function that calculates the ").concat(r," of a number.")))})})();function allPossibleCases(e){if(e.length===1){return e[0]}else{var t=[];var r=allPossibleCases(e.slice(1));for(var n=0;n3&&arguments[3]!==undefined?arguments[3]:null;var i=e?" in expression `".concat(e,"`"):"";if(n!==null){i+=" (argument ".concat(n,")")}if(is_function(r)){return"Invalid type: got ".concat(t).concat(i)}if(r instanceof Array){if(r.length===1){var a=r[0].toLowerCase();r="a"+("aeiou".includes(a)?"n ":" ")+r[0]}else{r=new Intl.ListFormat("en",{style:"long",type:"disjunction"}).format(r)}}return"Expecting ".concat(r," got ").concat(t).concat(i)}function typecheck_number(e,t,r){var n=arguments.length>3&&arguments[3]!==undefined?arguments[3]:null;typecheck(e,t,"number",n);var i=t.__type__;var a;if(r instanceof Pair){r=r.to_array()}if(r instanceof Array){r=r.map(function(e){return e.valueOf()})}if(r instanceof Array){r=r.map(function(e){return e.valueOf().toLowerCase()});if(r.includes(i)){a=true}}else{r=r.valueOf().toLowerCase()}if(!a&&i!==r){throw new Error(typeErrorMessage(e,i,r,n))}}function typecheck_numbers(r,e,n){e.forEach(function(e,t){typecheck_number(r,e,n,t+1)})}function typecheck_args(r,e,n){e.forEach(function(e,t){typecheck(r,e,n,t+1)})}function typecheck_text_port(e,t,r){typecheck(e,t,r);if(t.__type__===binary_port){throw new Error(typeErrorMessage(e,"binary-port","textual-port"))}}function typecheck(e,t,r){var n=arguments.length>3&&arguments[3]!==undefined?arguments[3]:null;e=e.valueOf();var i=type(t).toLowerCase();if(is_function(r)){if(!r(t)){throw new Error(typeErrorMessage(e,i,r,n))}return}var a=false;if(r instanceof Pair){r=r.to_array()}if(r instanceof Array){r=r.map(function(e){return e.valueOf()})}if(r instanceof Array){r=r.map(function(e){return e.valueOf().toLowerCase()});if(r.includes(i)){a=true}}else{r=r.valueOf().toLowerCase()}if(!a&&i!==r){throw new Error(typeErrorMessage(e,i,r,n))}}function memoize(r){var n=new WeakMap;return function(e){var t=n.get(e);if(!t){t=r(e)}return t}}type=memoize(type);function type(e){var t=type_constants.get(e);if(t){return t}if(_typeof$1(e)==="object"){for(var r=0,n=Object.entries(type_mapping);r2&&arguments[2]!==undefined?arguments[2]:{},n=r.env,i=r.dynamic_env,a=r.use_dynamic;var o=n===null||n===void 0?void 0:n.new_frame(e,t);var u=i===null||i===void 0?void 0:i.new_frame(e,t);var s=new LambdaContext({env:o,use_dynamic:a,dynamic_env:u});return resolve_promises(e.apply(s,t))}function apply(n,e){var t=arguments.length>2&&arguments[2]!==undefined?arguments[2]:{},i=t.env,a=t.dynamic_env,o=t.use_dynamic,r=t.error,u=r===void 0?function(){}:r;e=evaluate_args(e,{env:i,dynamic_env:a,error:u,use_dynamic:o});return unpromise(e,function(e){if(is_raw_lambda(n)){n=unbind(n)}e=prepare_fn_args(n,e);var t=e.slice();var r=call_function(n,t,{env:i,dynamic_env:a,use_dynamic:o});return unpromise(r,function(e){if(e instanceof Pair){e.markCycles();return quote(e)}return box(e)},u)})}var _p_name__=new WeakMap;var Parameter=function(){function n(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:null;var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:null;_classCallCheck(this,n);_defineProperty(this,"__value__",void 0);_defineProperty(this,"__fn__",void 0);_classPrivateFieldInitSpec(this,_p_name__,{writable:true,value:void 0});this.__value__=e;if(t){if(!is_function(t)){throw new Error("Section argument to Parameter need to be function "+"".concat(type(t)," given"))}this.__fn__=t}if(r){_classPrivateFieldSet(this,_p_name__,r)}}_createClass(n,[{key:"__name__",get:function e(){return _classPrivateFieldGet(this,_p_name__)},set:function e(t){_classPrivateFieldSet(this,_p_name__,t);if(this.__fn__){this.__fn__.__name__="fn-".concat(t)}}},{key:"invoke",value:function e(){if(is_function(this.__fn__)){return this.__fn__(this.__value__)}return this.__value__}},{key:"inherit",value:function e(t){return new n(t,this.__fn__,this.__name__)}}]);return n}();var LambdaContext=function(){function t(e){_classCallCheck(this,t);_defineProperty(this,"env",void 0);_defineProperty(this,"dynamic_env",void 0);_defineProperty(this,"use_dynamic",void 0);Object.assign(this,e)}_createClass(t,[{key:"__name__",get:function e(){return this.env.__name__}},{key:"__parent__",get:function e(){return this.env.__parent__}},{key:"get",value:function e(){var t;return(t=this.env).get.apply(t,arguments)}}]);return t}();function search_param(e,t){var r=e.get(t.__name__,{throwError:false});if(is_parameter(r)&&r!==t){return r}var n=user_env.get("**interaction-environment**");while(true){var i=e.get("parent.frame",{throwError:false});e=i(0);if(e===n){break}r=e.get(t.__name__,{throwError:false});if(is_parameter(r)&&r!==t){return r}}return t}var Continuation=function(){function t(e){_classCallCheck(this,t);_defineProperty(this,"__value__",void 0);this.__value__=e}_createClass(t,[{key:"invoke",value:function e(){if(this.__value__===null){throw new Error("Continuations are not implemented yet")}}}]);return t}();function _evaluate(u){var e=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},s=e.env,c=e.dynamic_env,l=e.use_dynamic,t=e.error,f=t===void 0?noop:t,r=_objectWithoutProperties(e,_excluded6);return function(e){try{if(!is_env(c)){c=s===true?user_env:s||user_env}if(l){s=c}else if(s===true){s=user_env}else{s=s||global_env}var t={env:s,dynamic_env:c,use_dynamic:l,error:f};var r;if(is_null(u)){return u}if(u instanceof LSymbol){return s.get(u)}if(!(u instanceof Pair)){return u}var n=u.car;var e=u.cdr;if(n instanceof Pair){r=resolve_promises(_evaluate(n,t));if(is_promise(r)){return r.then(function(e){if(!is_callable(e)){throw new Error(type(e)+" "+s.get("repr")(e)+" is not callable while evaluating "+u.toString())}return _evaluate(new Pair(e,u.cdr),t)})}else if(!is_callable(r)){throw new Error(type(r)+" "+s.get("repr")(r)+" is not callable while evaluating "+u.toString())}}if(n instanceof LSymbol){r=s.get(n)}else if(is_function(n)){r=n}var i;if(r instanceof Syntax){i=evaluate_syntax(r,u,t)}else if(r instanceof Macro){i=evaluate_macro(r,e,t)}else if(is_function(r)){i=apply(r,e,t)}else if(r instanceof SyntaxParameter){i=evaluate_syntax(r._syntax,u,t)}else if(is_parameter(r)){var a=search_param(c,r);if(is_null(u.cdr)){i=a.invoke()}else{return unpromise(_evaluate(u.cdr.car,t),function(e){a.__value__=e})}}else if(is_continuation(r)){i=r.invoke()}else if(u instanceof Pair){r=n&&n.toString();throw new Error("".concat(type(n)," ").concat(r," is not a function"))}else{return u}var o=s.get(Symbol["for"]("__promise__"),{throwError:false});if(o===true&&is_promise(i)){i=i.then(function(e){if(e instanceof Pair&&!r[__data__]){return _evaluate(e,t)}return e});return new QuotedPromise(i)}return i}catch(e){f&&f.call(s,e,u)}}(r)}var compile=exec_collect(function(e){return e});var exec=exec_collect(function(e,t){return t});function exec_with_stacktrace(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},r=t.env,n=t.dynamic_env,i=t.use_dynamic;return _evaluate(e,{env:r,dynamic_env:n,use_dynamic:i,error:function e(t,r){if(t&&t.message){if(t.message.match(/^Error:/)){var n=/^(Error:)\s*([^:]+:\s*)/;t.message=t.message.replace(n,"$1 $2")}if(r){if(!(t.__code__ instanceof Array)){t.__code__=[]}t.__code__.push(r.toString(true))}}if(!(t instanceof IgnoreException)){throw t}}})}function exec_collect(d){return function(){var t=_asyncToGenerator(function(f){var e=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},_=e.env,p=e.dynamic_env,h=e.use_dynamic;return _regeneratorRuntime.mark(function e(){var r,n,i,a,o,u,s,c,l;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(!is_env(p)){p=_===true?user_env:_||user_env}if(_===true){_=user_env}else{_=_||user_env}r=[];if(!is_pair(f)){t.next=8;break}t.next=6;return exec_with_stacktrace(code,{env:_,dynamic_env:p,use_dynamic:h});case 6:t.t0=t.sent;return t.abrupt("return",[t.t0]);case 8:n=Array.isArray(f)?f:_parse(f);i=false;a=false;t.prev=11;u=_asyncIterator(n);case 13:t.next=15;return u.next();case 15:if(!(i=!(s=t.sent).done)){t.next=31;break}c=s.value;t.next=19;return exec_with_stacktrace(c,{env:_,dynamic_env:p,use_dynamic:h});case 19:l=t.sent;t.t1=r;t.t2=d;t.t3=c;t.next=25;return l;case 25:t.t4=t.sent;t.t5=(0,t.t2)(t.t3,t.t4);t.t1.push.call(t.t1,t.t5);case 28:i=false;t.next=13;break;case 31:t.next=37;break;case 33:t.prev=33;t.t6=t["catch"](11);a=true;o=t.t6;case 37:t.prev=37;t.prev=38;if(!(i&&u["return"]!=null)){t.next=42;break}t.next=42;return u["return"]();case 42:t.prev=42;if(!a){t.next=45;break}throw o;case 45:return t.finish(42);case 46:return t.finish(37);case 47:return t.abrupt("return",r);case 48:case"end":return t.stop()}},e,null,[[11,33,37,47],[38,,42,46]])})()});function e(e){return t.apply(this,arguments)}return e}()}function balanced(e){var t={"[":"]","(":")"};var r;if(typeof e==="string"){r=tokenize(e)}else{r=e.map(function(e){return e&&e.token?e.token:e})}var n=Object.keys(t);var i=Object.values(t).concat(n);r=r.filter(function(e){return i.includes(e)});var a=new Stack;var o=_createForOfIteratorHelper(r),u;try{for(o.s();!(u=o.n()).done;){var s=u.value;if(n.includes(s)){a.push(s)}else if(!a.is_empty()){var c=a.top();var l=t[c];if(s===l){a.pop()}else{throw new Error("Syntax error: missing closing ".concat(l))}}else{throw new Error("Syntax error: not matched closing ".concat(s))}}}catch(e){o.e(e)}finally{o.f()}return a.is_empty()}function fworker(e){var t="("+e.toString()+")()";var r=window.URL||window.webkitURL;var n;try{n=new Blob([t],{type:"application/javascript"})}catch(e){var i=window.BlobBuilder||window.WebKitBlobBuilder||window.MozBlobBuilder;n=new i;n.append(t);n=n.getBlob()}return new root.Worker(r.createObjectURL(n))}function is_dev(){return lips.version.match(/^(\{\{VER\}\}|DEV)$/)}function get_current_script(){if(is_node()){return}var e;if(document.currentScript){e=document.currentScript}else{var t=document.querySelectorAll("script");if(!t.length){return}e=t[t.length-1]}var r=e.getAttribute("src");return r}var current_script=get_current_script();function bootstrap(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:"";var t="dist/std.xcb";if(e===""){if(current_script){e=current_script.replace(/[^/]*$/,"std.xcb")}else if(is_dev()){e="https://cdn.jsdelivr.net/gh/jcubic/lips@devel/".concat(t)}else{e="https://cdn.jsdelivr.net/npm/@jcubic/lips@".concat(lips.version,"/").concat(t)}}var r=global_env.get("load");return r.call(user_env,e,global_env)}function Worker(e){this.url=e;var o=this.worker=fworker(function(){var o;var u;self.addEventListener("message",function(e){var r=e.data;var t=r.id;if(r.type!=="RPC"||t===null){return}function n(e){self.postMessage({id:t,type:"RPC",result:e})}function i(e){self.postMessage({id:t,type:"RPC",error:e})}if(r.method==="eval"){if(!u){i("Worker RPC: LIPS not initialized, call init first");return}u.then(function(){var e=r.params[0];var t=r.params[1];o.exec(e,{use_dynamic:t}).then(function(e){e=e.map(function(e){return e&&e.valueOf()});n(e)})["catch"](function(e){i(e)})})}else if(r.method==="init"){var a=r.params[0];if(typeof a!=="string"){i("Worker RPC: url is not a string")}else{importScripts("".concat(a,"/dist/lips.min.js"));o=new lips.Interpreter("worker");u=bootstrap(a);u.then(function(){n(true)})}}})});this.rpc=function(){var n=0;return function e(t,r){var a=++n;return new Promise(function(n,i){o.addEventListener("message",function e(t){var r=t.data;if(r&&r.type==="RPC"&&r.id===a){if(r.error){i(r.error)}else{n(r.result)}o.removeEventListener("message",e)}});o.postMessage({type:"RPC",method:t,id:a,params:r})})}}();this.rpc("init",[e])["catch"](function(e){console.error(e)});this.exec=function(e,t){var r=t.use_dynamic,n=r===void 0?false:r;return this.rpc("eval",[e,n])}}var serialization_map={pair:function e(t){var r=_slicedToArray(t,2),n=r[0],i=r[1];return Pair(n,i)},number:function e(t){if(LString.isString(t)){return LNumber([t,10])}return LNumber(t)},regex:function e(t){var r=_slicedToArray(t,2),n=r[0],i=r[1];return new RegExp(n,i)},nil:function e(){return _nil},symbol:function e(t){if(LString.isString(t)){return LSymbol(t)}else if(Array.isArray(t)){return LSymbol(Symbol["for"](t[0]))}},string:LString,character:LCharacter};var available_class=Object.keys(serialization_map);var class_map={};for(var _i6=0,_Object$entries3=Object.entries(available_class);_i6<_Object$entries3.length;_i6++){var _Object$entries3$_i=_slicedToArray(_Object$entries3[_i6],2),i=_Object$entries3$_i[0],cls=_Object$entries3$_i[1];class_map[cls]=+i}function mangle_name(e){return class_map[e]}function resolve_name(e){return available_class[e]}function serialize(e){return JSON.stringify(e,function(e,t){var r=this[e];if(r){if(r instanceof RegExp){return{"@":mangle_name("regex"),"#":[r.source,r.flags]}}var n=mangle_name(r.constructor.__class__);if(!is_undef(n)){return{"@":n,"#":r.serialize()}}}return t})}function unserialize(e){return JSON.parse(e,function(e,t){if(t&&_typeof$1(t)==="object"){if(!is_undef(t["@"])){var r=resolve_name(t["@"]);if(serialization_map[r]){return serialization_map[r](t["#"])}}}return t})}var cbor=function(){var e={pair:Pair,symbol:LSymbol,number:LNumber,string:LString,character:LCharacter,nil:_nil.constructor,regex:RegExp};function t(e,t){return{deserialize:t,Class:e}}var r=new Encoder;var a={};for(var n=0,i=Object.entries(serialization_map);n1){var n=t.reduce(function(e,t){return e+t.length},0);var i=new Uint8Array(n);var a=0;t.forEach(function(e){i.set(e,a);a+=e.length});return i}else if(t.length){return t[0]}}function encode_magic(){var e=1;var t=new TextEncoder("utf-8");return t.encode("LIPS".concat(e.toString().padStart(3," ")))}var MAGIC_LENGTH=7;function decode_magic(e){var t=new TextDecoder("utf-8");var r=t.decode(e.slice(0,MAGIC_LENGTH));var n=r.substring(0,4);if(n==="LIPS"){var i=r.match(/^(....).*([0-9]+)$/);if(i){return{type:i[1],version:Number(i[2])}}}return{type:"unknown"}}function serialize_bin(e){var t=encode_magic();var r=cbor.encode(e);return merge_uint8_array(t,pack_1(r,{magic:false}))}function unserialize_bin(e){var t=decode_magic(e),r=t.type,n=t.version;if(r==="LIPS"&&n===1){var i=unpack_1(e.slice(MAGIC_LENGTH),{magic:false});return cbor.decode(i)}else{throw new Error("Invalid file format ".concat(r))}}function execError(e){console.error(e.message||e);if(Array.isArray(e.code)){console.error(e.code.map(function(e,t){return"[".concat(t+1,"]: ").concat(e)}))}}function init(){var u=["text/x-lips","text/x-scheme"];var s;function c(r){return new Promise(function(t){var e=r.getAttribute("src");if(e){return fetch(e).then(function(e){return e.text()}).then(exec).then(t)["catch"](function(e){execError(e);t()})}else{return exec(r.innerHTML).then(t)["catch"](function(e){execError(e);t()})}})}function e(){return new Promise(function(a){var o=Array.from(document.querySelectorAll("script"));return function e(){var t=o.shift();if(!t){a()}else{var r=t.getAttribute("type");if(u.includes(r)){var n;var i=(n=t.getAttribute("bootstrap"))!==null&&n!==void 0?n:t.getAttribute("data-bootstrap");if(!s&&typeof i==="string"){return bootstrap(i).then(function(){return c(t)}).then(e)}else{return c(t).then(e)}}else if(r&&r.match(/lips|lisp/)){console.warn("Expecting "+u.join(" or ")+" found "+r)}return e()}}()})}if(!window.document){return Promise.resolve()}else if(currentScript){var t=currentScript;var r=t.getAttribute("bootstrap");if(typeof r==="string"){return bootstrap(r).then(function(){s=true;return e()})}}return e()}var currentScript=typeof window!=="undefined"&&window.document&&document.currentScript;if(typeof window!=="undefined"){contentLoaded(window,init)}var banner=function(){var e=LString("Mon, 12 Feb 2024 12:58:05 +0000").valueOf();var t=e==="{{"+"DATE}}"?new Date:new Date(e);var r=function e(t){return t.toString().padStart(2,"0")};var n=t.getFullYear();var i=[n,r(t.getMonth()+1),r(t.getDate())].join("-");var a="\n __ __ __\n / / \\ \\ _ _ ___ ___ \\ \\\n| | \\ \\ | | | || . \\/ __> | |\n| | > \\ | |_ | || _/\\__ \\ | |\n| | / ^ \\ |___||_||_| <___/ | |\n \\_\\ /_/ \\_\\ /_/\n\nLIPS Interpreter DEV (".concat(i,") \nCopyright (c) 2018-").concat(n," Jakub T. Jankiewicz\n\nType (env) to see environment with functions macros and variables. You can also\nuse (help name) to display help for specific function or macro, (apropos name)\nto display list of matched names in environment and (dir object) to list\nproperties of an object.\n").replace(/^.*\n/,"");return a}();read_only(Ahead,"__class__","ahead");read_only(Pair,"__class__","pair");read_only(Nil,"__class__","nil");read_only(Pattern,"__class__","pattern");read_only(Formatter,"__class__","formatter");read_only(Macro,"__class__","macro");read_only(Syntax,"__class__","syntax");read_only(Syntax.Parameter,"__class__","syntax-parameter");read_only(Environment,"__class__","environment");read_only(InputPort,"__class__","input-port");read_only(OutputPort,"__class__","output-port");read_only(BufferedOutputPort,"__class__","output-port");read_only(OutputStringPort,"__class__","output-string-port");read_only(InputStringPort,"__class__","input-string-port");read_only(InputFilePort,"__class__","input-file-port");read_only(OutputFilePort,"__class__","output-file-port");read_only(LipsError,"__class__","lips-error");[LNumber,LComplex,LRational,LFloat,LBigInteger].forEach(function(e){read_only(e,"__class__","number")});read_only(LCharacter,"__class__","character");read_only(LSymbol,"__class__","symbol");read_only(LString,"__class__","string");read_only(QuotedPromise,"__class__","promise");read_only(Parameter,"__class__","parameter");var version="DEV";var date="Mon, 12 Feb 2024 12:58:05 +0000";var parse=compose(uniterate_async,_parse);var lips={version:version,banner:banner,date:date,exec:exec,parse:parse,tokenize:tokenize,evaluate:_evaluate,compile:compile,serialize:serialize,unserialize:unserialize,serialize_bin:serialize_bin,unserialize_bin:unserialize_bin,bootstrap:bootstrap,Environment:Environment,env:user_env,Worker:Worker,Interpreter:Interpreter,balanced_parenthesis:balanced,balancedParenthesis:balanced,balanced:balanced,Macro:Macro,Syntax:Syntax,Pair:Pair,Values:Values,QuotedPromise:QuotedPromise,Error:LipsError,quote:quote,InputPort:InputPort,OutputPort:OutputPort,BufferedOutputPort:BufferedOutputPort,InputFilePort:InputFilePort,OutputFilePort:OutputFilePort,InputStringPort:InputStringPort,OutputStringPort:OutputStringPort,InputByteVectorPort:InputByteVectorPort,OutputByteVectorPort:OutputByteVectorPort,InputBinaryFilePort:InputBinaryFilePort,OutputBinaryFilePort:OutputBinaryFilePort,set_fs:set_fs,Formatter:Formatter,Parser:Parser,Lexer:Lexer,specials:specials,repr:repr,nil:_nil,eof:eof,LSymbol:LSymbol,LNumber:LNumber,LFloat:LFloat,LComplex:LComplex,LRational:LRational,LBigInteger:LBigInteger,LCharacter:LCharacter,LString:LString,Parameter:Parameter,rationalize:rationalize};global_env.set("lips",lips);var empty={};var empty$1=Object.freeze({__proto__:null,default:empty});function normalizeArray(e,t){var r=0;for(var n=e.length-1;n>=0;n--){var i=e[n];if(i==="."){e.splice(n,1)}else if(i===".."){e.splice(n,1);r++}else if(r){e.splice(n,1);r--}}if(t){for(;r--;r){e.unshift("..")}}return e}var splitPathRe=/^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/;var splitPath=function(e){return splitPathRe.exec(e).slice(1)};function resolve(){var e="",t=false;for(var r=arguments.length-1;r>=-1&&!t;r--){var n=r>=0?arguments[r]:"/";if(typeof n!=="string"){throw new TypeError("Arguments to path.resolve must be strings")}else if(!n){continue}e=n+"/"+e;t=n.charAt(0)==="/"}e=normalizeArray(filter(e.split("/"),function(e){return!!e}),!t).join("/");return(t?"/":"")+e||"."}function normalize(e){var t=isAbsolute(e),r=substr(e,-1)==="/";e=normalizeArray(filter(e.split("/"),function(e){return!!e}),!t).join("/");if(!e&&!t){e="."}if(e&&r){e+="/"}return(t?"/":"")+e}function isAbsolute(e){return e.charAt(0)==="/"}function join(){var e=Array.prototype.slice.call(arguments,0);return normalize(filter(e,function(e,t){if(typeof e!=="string"){throw new TypeError("Arguments to path.join must be strings")}return e}).join("/"))}function relative(e,t){e=resolve(e).substr(1);t=resolve(t).substr(1);function r(e){var t=0;for(;t=0;r--){if(e[r]!=="")break}if(t>r)return[];return e.slice(t,r-t+1)}var n=r(e.split("/"));var i=r(t.split("/"));var a=Math.min(n.length,i.length);var o=a;for(var u=0;ur-MATCH_MAX){t[i++]=e[n++];continue}l=(e[n]+13^e[n+1]-13^e[n+2])&LEMPEL_SIZE-1;c=n-f[l]&OFFSET_MASK;f[l]=n;a=n-c;if(a>=0&&a!=n&&e[n]==e[a]&&e[n+1]==e[a+1]&&e[n+2]==e[a+2]){t[o]|=u;for(s=MATCH_MIN;s>NBBY;t[i++]=c;n+=s}else{t[i++]=e[n++]}}console.assert(e.length>=n);return i}function decompress(e,t,r){t=t|0;var n=0,i=0,a=0,o=0,u=1<<(NBBY-1|0),s=0,c=0;while(n>(NBBY-MATCH_BITS|0))+MATCH_MIN|0;c=(e[n]<4){r[i]=r[a];i=i+1|0;a=a+1|0;r[i]=r[a];i=i+1|0;a=a+1|0;r[i]=r[a];i=i+1|0;a=a+1|0;r[i]=r[a];i=i+1|0;a=a+1|0;s=s-4|0}while(s>0){r[i]=r[a];i=i+1|0;a=a+1|0;s=s-1|0}}}else{r[i]=e[n];i=i+1|0;n=n+1|0}}return i}function encode_magic$1(){const e=new TextEncoder("utf-8");return e.encode(MAGIC_STRING)}const MAGIC_STRING="@lzjb";const MAGIC=encode_magic$1();function merge_uint8_array$1(...e){if(e.length>1){const r=e.reduce((e,t)=>e+t.length,0);const n=new Uint8Array(r);let t=0;e.forEach(e=>{n.set(e,t);t+=e.length});return n}else if(e.length){return e[0]}}function number_to_bytes(t){const e=Math.ceil(Math.log2(t)/8);const r=new Uint8Array(e);for(let e=0;e=0;e--){r=r*256+t[e]}return r}function pack(e,{magic:t=true}={}){const r=new Uint8Array(Math.max(e.length*1.5|0,16*1024));const n=compress(e,r);const i=number_to_bytes(e.length);const a=[Uint8Array.of(i.length),i,r.slice(0,n)];if(t){a.unshift(MAGIC)}return merge_uint8_array$1(...a)}function unpack(t,{magic:e=true}={}){if(e){const e=new TextDecoder("utf-8");const s=e.decode(t.slice(0,MAGIC.length));if(s!==MAGIC_STRING){throw new Error("Invalid magic value")}}const r=e?MAGIC.length:0;const n=t[r];const i=r+1;const a=r+n+1;const o=bytes_to_number(t.slice(i,a));t=t.slice(a);const u=new Uint8Array(o);decompress(t,t.length,u);return u}var pack_1=lzjbPack.pack=pack;var unpack_1=lzjbPack.unpack=unpack;function unfetch(s,c){return c=c||{},new Promise(function(e,t){var r=new XMLHttpRequest,n=[],i=[],a={},o=function(){return{ok:2==(r.status/100|0),statusText:r.statusText,status:r.status,url:r.responseURL,text:function(){return Promise.resolve(r.responseText)},json:function(){return Promise.resolve(r.responseText).then(JSON.parse)},blob:function(){return Promise.resolve(new Blob([r.response]))},clone:o,headers:{keys:function(){return n},entries:function(){return i},get:function(e){return a[e.toLowerCase()]},has:function(e){return e.toLowerCase()in a}}}};for(var u in r.open(c.method||"get",s,!0),r.onload=function(){r.getAllResponseHeaders().replace(/^(.*?):[^\S\n]*([\s\S]*?)$/gm,function(e,t,r){n.push(t=t.toLowerCase()),i.push([t,r]),a[t]=a[t]?a[t]+","+r:r}),e(o())},r.onerror=t,r.withCredentials="include"==c.credentials,c.headers)r.setRequestHeader(u,c.headers[u]);r.send(c.body||null)})}var _excluded=["token"],_excluded2=["env"],_excluded3=["stderr","stdin","stdout","command_line"],_excluded4=["use_dynamic"],_excluded5=["use_dynamic"],_excluded6=["env","dynamic_env","use_dynamic","error"];function _classPrivateFieldInitSpec(e,t,r){_checkPrivateRedeclaration(e,t);t.set(e,r)}function _checkPrivateRedeclaration(e,t){if(t.has(e)){throw new TypeError("Cannot initialize the same private elements twice on an object")}}function _callSuper(e,t,r){return t=_getPrototypeOf(t),_possibleConstructorReturn(e,_isNativeReflectConstruct()?Reflect.construct(t,r||[],_getPrototypeOf(e).constructor):t.apply(e,r))}function _isNativeReflectConstruct(){try{var t=!Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){}))}catch(t){}return(_isNativeReflectConstruct=function e(){return!!t})()}function _createForOfIteratorHelper(t,e){var r=typeof Symbol!=="undefined"&&t[Symbol.iterator]||t["@@iterator"];if(!r){if(Array.isArray(t)||(r=_unsupportedIterableToArray(t))||e&&t&&typeof t.length==="number"){if(r)t=r;var n=0;var i=function e(){};return{s:i,n:function e(){if(n>=t.length)return{done:true};return{done:false,value:t[n++]}},e:function e(t){throw t},f:i}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var a=true,o=false,u;return{s:function e(){r=r.call(t)},n:function e(){var t=r.next();a=t.done;return t},e:function e(t){o=true;u=t},f:function e(){try{if(!a&&r["return"]!=null)r["return"]()}finally{if(o)throw u}}}}function _unsupportedIterableToArray(e,t){if(!e)return;if(typeof e==="string")return _arrayLikeToArray(e,t);var r=Object.prototype.toString.call(e).slice(8,-1);if(r==="Object"&&e.constructor)r=e.constructor.name;if(r==="Map"||r==="Set")return Array.from(e);if(r==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r))return _arrayLikeToArray(e,t)}function _arrayLikeToArray(e,t){if(t==null||t>e.length)t=e.length;for(var r=0,n=new Array(t);r1?r-1:0),i=1;i0&&arguments[0]!==undefined?arguments[0]:null;var t=user_env&&user_env.get("DEBUG",{throwError:false});if(e===null){return t===true}return(t===null||t===void 0?void 0:t.valueOf())===e.valueOf()}function num_mnemicic_re(e){return e?"(?:#".concat(e,"(?:#[ie])?|#[ie]#").concat(e,")"):"(?:#[ie])?"}function gen_rational_re(e,t){return"".concat(num_mnemicic_re(e),"[+-]?").concat(t,"+/").concat(t,"+")}function gen_complex_re(e,t){return"".concat(num_mnemicic_re(e),"(?:[+-]?(?:").concat(t,"+/").concat(t,"+|nan.0|inf.0|").concat(t,"+))?(?:[+-]i|[+-]?(?:").concat(t,"+/").concat(t,"+|").concat(t,"+|nan.0|inf.0)i)(?=[()[\\]\\s]|$)")}function gen_integer_re(e,t){return"".concat(num_mnemicic_re(e),"[+-]?").concat(t,"+")}var re_re=/^#\/((?:\\\/|[^/]|\[[^\]]*\/[^\]]*\])+)\/([gimyus]*)$/;var float_stre="(?:[-+]?(?:[0-9]+(?:[eE][-+]?[0-9]+)|(?:\\.[0-9]+|[0-9]+\\.[0-9]+)(?:[eE][-+]?[0-9]+)?)|[0-9]+\\.)";var complex_float_stre="(?:#[ie])?(?:[+-]?(?:[0-9]+/[0-9]+|nan.0|inf.0|".concat(float_stre,"|[+-]?[0-9]+))?(?:").concat(float_stre,"|[+-](?:[0-9]+/[0-9]+|[0-9]+|nan.0|inf.0))i");var float_re=new RegExp("^(#[ie])?".concat(float_stre,"$"),"i");function make_complex_match_re(e,t){var r=e==="x"?"(?!\\+|".concat(t,")"):"(?!\\.|".concat(t,")");var n="";if(e===""){n="(?:[-+]?(?:[0-9]+(?:[eE][-+]?[0-9]+)|(?:\\.[0-9]+|[0-9]+\\.[0-9]+(?![0-9]))(?:[eE][-+]?[0-9]+)?))"}return new RegExp("^((?:(?:".concat(n,"|[-+]?inf.0|[-+]?nan.0|[+-]?").concat(t,"+/").concat(t,"+(?!").concat(t,")|[+-]?").concat(t,"+)").concat(r,")?)(").concat(n,"|[-+]?inf.0|[-+]?nan.0|[+-]?").concat(t,"+/").concat(t,"+|[+-]?").concat(t,"+|[+-])i$"),"i")}var complex_list_re=function(){var a={};[[10,"","[0-9]"],[16,"x","[0-9a-fA-F]"],[8,"o","[0-7]"],[2,"b","[01]"]].forEach(function(e){var t=_slicedToArray(e,3),r=t[0],n=t[1],i=t[2];a[r]=make_complex_match_re(n,i)});return a}();var characters={alarm:"",backspace:"\b",delete:"",escape:"",newline:"\n",null:"\0",return:"\r",space:" ",tab:"\t",dle:"",soh:"",dc1:"",stx:"",dc2:"",etx:"",dc3:"",eot:"",dc4:"",enq:"",nak:"",ack:"",syn:"",bel:"",etb:"",bs:"\b",can:"",ht:"\t",em:"",lf:"\n",sub:"",vt:"\v",esc:"",ff:"\f",fs:"",cr:"\r",gs:"",so:"",rs:"",si:"",us:"",del:""};function ucs2decode(e){var t=[];var r=0;var n=e.length;while(r=55296&&i<=56319&&r1&&arguments[1]!==undefined?arguments[1]:10;var r=num_pre_parse(e);var n=r.number.split("/");var i=LRational({num:LNumber([n[0],r.radix||t]),denom:LNumber([n[1],r.radix||t])});if(r.inexact){return i.valueOf()}else{return i}}function parse_integer(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:10;var r=num_pre_parse(e);if(r.inexact){return LFloat(parseInt(r.number,r.radix||t))}return LNumber([r.number,r.radix||t])}function parse_character(e){var t=e.match(/#\\x([0-9a-f]+)$/i);var r;if(t){var n=parseInt(t[1],16);r=String.fromCodePoint(n)}else{t=e.match(/#\\([\s\S]+)$/);if(t){r=t[1]}}if(r){return LCharacter(r)}throw new Error("Parse: invalid character")}function parse_complex(e){var i=arguments.length>1&&arguments[1]!==undefined?arguments[1]:10;function t(e){var t;if(e==="+"){t=LNumber(1)}else if(e==="-"){t=LNumber(-1)}else if(e.match(int_bare_re)){t=LNumber([e,i])}else if(e.match(rational_bare_re)){var r=e.split("/");t=LRational({num:LNumber([r[0],i]),denom:LNumber([r[1],i])})}else if(e.match(float_re)){var n=parse_float(e);if(a.exact){return n.toRational()}return n}else if(e.match(/nan.0$/)){return LNumber(NaN)}else if(e.match(/inf.0$/)){if(e[0]==="-"){return LNumber(Number.NEGATIVE_INFINITY)}return LNumber(Number.POSITIVE_INFINITY)}else{throw new Error("Internal Parser Error")}if(a.inexact){return LFloat(t.valueOf())}return t}var a=num_pre_parse(e);i=a.radix||i;var r;var n=a.number.match(complex_bare_match_re);if(i!==10&&n){r=n}else{r=a.number.match(complex_list_re[i])}var o,u;u=t(r[2]);if(r[1]){o=t(r[1])}else{o=LNumber(0)}if(u.cmp(0)===0&&u.__type__==="bigint"){return o}return LComplex({im:u,re:o})}function is_int(e){return parseInt(e.toString(),10)===e}function parse_big_int(e){var t=e.match(/^(([-+]?[0-9]*)(?:\.([0-9]+))?)e([-+]?[0-9]+)/i);if(t){var r=parseInt(t[4],10);var n;var i=t[1].replace(/[-+]?([0-9]*)\..+$/,"$1").length;var a=t[3]&&t[3].length;if(i0&&(t.exact||!t.number.match(/\./))){return LNumber(a).mul(u)}}}r=LFloat(r);if(t.exact){return r.toRational()}return r}function parse_string(e){e=e.replace(/\\x([0-9a-f]+);/gi,function(e,t){return"\\u"+t.padStart(4,"0")}).replace(/\n/g,"\\n");var t=e.match(/(\\*)(\\x[0-9A-F])/i);if(t&&t[1].length%2===0){throw new Error("Invalid string literal, unclosed ".concat(t[2]))}try{var r=LString(JSON.parse(e));r.freeze();return r}catch(e){var n=e.message.replace(/in JSON /,"").replace(/.*Error: /,"");throw new Error("Invalid string literal: ".concat(n))}}function parse_symbol(e){if(e.match(/^\|.*\|$/)){e=e.replace(/(^\|)|(\|$)/g,"");var r={t:"\t",r:"\r",n:"\n"};e=e.replace(/\\(x[^;]+);/g,function(e,t){return String.fromCharCode(parseInt("0"+t,16))}).replace(/\\(.)/g,function(e,t){return r[t]||t})}return new LSymbol(e)}function parse_argument(e){if(constants.hasOwnProperty(e)){return constants[e]}if(e.match(/^"[\s\S]*"$/)){return parse_string(e)}else if(e[0]==="#"){var t=e.match(re_re);if(t){return new RegExp(t[1],t[2])}else if(e.match(char_re)){return parse_character(e)}var r=e.match(/#\\(.+)/);if(r&&ucs2decode(r[1]).length===1){return parse_character(e)}}if(e.match(/[0-9a-f]|[+-]i/i)){if(e.match(int_re)){return parse_integer(e)}else if(e.match(float_re)){return parse_float(e)}else if(e.match(rational_re)){return parse_rational(e)}else if(e.match(complex_re)){return parse_complex(e)}}if(e.match(/^#[iexobd]/)){throw new Error("Invalid numeric constant: "+e)}return parse_symbol(e)}function is_atom_string(e){return!(["(",")","[","]"].includes(e)||specials.names().includes(e))}function is_symbol_string(e){return is_atom_string(e)&&!(e.match(re_re)||e.match(/^"[\s\S]*"$/)||e.match(int_re)||e.match(float_re)||e.match(complex_re)||e.match(rational_re)||e.match(char_re)||["#t","#f","nil"].includes(e))}var string_re=/"(?:\\[\S\s]|[^"])*"?/g;function escape_regex(e){if(typeof e==="string"){var t=/([-\\^$[\]()+{}?*.|])/g;return e.replace(t,"\\$1")}return e}function Stack(){this.data=[]}Stack.prototype.push=function(e){this.data.push(e)};Stack.prototype.top=function(){return this.data[this.data.length-1]};Stack.prototype.pop=function(){return this.data.pop()};Stack.prototype.is_empty=function(){return!this.data.length};function tokens(e){if(e instanceof LString){e=e.valueOf()}var t=new Lexer(e,{whitespace:true});var r=[];while(true){var n=t.peek(true);if(n===eof){break}r.push(n);t.skip()}return r}function multiline_formatter(e){var t=e.token,r=_objectWithoutProperties(e,_excluded);if(t.match(/^"[\s\S]*"$/)&&t.match(/\n/)){var n=new RegExp("^ {1,"+(e.col+1)+"}","mg");t=t.replace(n,"")}return _objectSpread({token:t},r)}function Thunk(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:function(){};this.fn=e;this.cont=t}Thunk.prototype.toString=function(){return"#"};function trampoline(n){return function(){for(var e=arguments.length,t=new Array(e),r=0;r1&&arguments[1]!==undefined?arguments[1]:false;if(e instanceof LString){e=e.toString()}if(t){return tokens(e)}else{var r=tokens(e).map(function(e){if(e.token==="#\\ "||e.token=="#\\\n"){return e.token}return e.token.trim()}).filter(function(e){return e&&!e.match(/^;/)&&!e.match(/^#\|[\s\S]*\|#$/)});return strip_s_comments(r)}}function strip_s_comments(e){var t=0;var r=null;var n=[];for(var i=0;i0&&arguments[0]!==undefined?arguments[0]:null;if(e instanceof LSymbol){if(e.is_gensym()){return e}e=e.valueOf()}if(is_gensym(e)){return LSymbol(e)}if(e!==null){return r(e,Symbol("#:".concat(e)))}t++;return r(t,Symbol("#:g".concat(t)))}}();function QuotedPromise(e){var r=this;var n={pending:true,rejected:false,fulfilled:false,reason:undefined,type:undefined};e=e.then(function(e){n.type=type(e);n.fulfilled=true;n.pending=false;return e});read_only(this,"_promise",e,{hidden:true});if(is_function(e["catch"])){e=e["catch"](function(e){n.rejected=true;n.pending=false;n.reason=e})}Object.keys(n).forEach(function(t){Object.defineProperty(r,"__".concat(t,"__"),{enumerable:true,get:function e(){return n[t]}})});read_only(this,"__promise__",e);this.then=false}QuotedPromise.prototype.then=function(e){return new QuotedPromise(this.valueOf().then(e))};QuotedPromise.prototype["catch"]=function(e){return new QuotedPromise(this.valueOf()["catch"](e))};QuotedPromise.prototype.valueOf=function(){if(!this._promise){throw new Error("QuotedPromise: invalid promise created")}return this._promise};QuotedPromise.prototype.toString=function(){if(this.__pending__){return QuotedPromise.pending_str}if(this.__rejected__){return QuotedPromise.rejected_str}return"#")};QuotedPromise.pending_str="#";QuotedPromise.rejected_str="#";function promise_all(e){if(Array.isArray(e)){return Promise.all(escape_quoted_promises(e)).then(unescape_quoted_promises)}return e}function escape_quoted_promises(e){var t=new Array(e.length),r=e.length;while(r--){var n=e[r];if(n instanceof QuotedPromise){t[r]=new Value(n)}else{t[r]=n}}return t}function unescape_quoted_promises(e){var t=new Array(e.length),r=e.length;while(r--){var n=e[r];if(n instanceof Value){t[r]=n.valueOf()}else{t[r]=n}}return t}var specials={LITERAL:Symbol["for"]("literal"),SPLICE:Symbol["for"]("splice"),SYMBOL:Symbol["for"]("symbol"),names:function e(){return Object.keys(this.__list__)},type:function e(t){try{return this.get(t).type}catch(e){console.log({name:t});console.log(e);return null}},get:function e(t){return this.__list__[t]},off:function e(t){var r=this;var n=arguments.length>1&&arguments[1]!==undefined?arguments[1]:null;if(Array.isArray(t)){t.forEach(function(e){return r.off(e,n)})}else if(n===null){delete this.__events__[t]}else{this.__events__=this.__events__.filter(function(e){return e!==n})}},on:function e(t,r){var n=this;if(Array.isArray(t)){t.forEach(function(e){return n.on(e,r)})}else if(!this.__events__[t]){this.__events__[t]=[r]}else{this.__events__[t].push(r)}},trigger:function e(t){for(var r=arguments.length,n=new Array(r>1?r-1:0),i=1;i",new LSymbol("quote-promise"),specials.LITERAL]];var builtins=defined_specials.map(function(e){return e[0]});Object.freeze(builtins);Object.defineProperty(specials,"__builtins__",{writable:false,value:builtins});defined_specials.forEach(function(e){var t=_slicedToArray(e,3),r=t[0],n=t[1],i=t[2];specials.append(r,n,i)});var Lexer=function(){function p(e){var t=this;var r=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},n=r.whitespace,i=n===void 0?false:n;_classCallCheck(this,p);read_only(this,"__input__",e.replace(/\r/g,""));var a={};["_i","_whitespace","_col","_newline","_line","_state","_next","_token","_prev_char"].forEach(function(r){Object.defineProperty(t,r,{configurable:false,enumerable:false,get:function e(){return a[r]},set:function e(t){a[r]=t}})});this._whitespace=i;this._i=this._line=this._col=this._newline=0;this._state=this._next=this._token=null;this._prev_char=""}_createClass(p,[{key:"get",value:function e(t){return this.__internal[t]}},{key:"set",value:function e(t,r){this.__internal[t]=r}},{key:"token",value:function e(){var t=arguments.length>0&&arguments[0]!==undefined?arguments[0]:false;if(t){var r=this._line;if(this._whitespace&&this._token==="\n"){--r}return{token:this._token,col:this._col,offset:this._i,line:r}}return this._token}},{key:"peek",value:function e(){var t=arguments.length>0&&arguments[0]!==undefined?arguments[0]:false;if(this._i>=this.__input__.length){return eof}if(this._token){return this.token(t)}var r=this.next_token();if(r){this._token=this.__input__.substring(this._i,this._next);return this.token(t)}return eof}},{key:"skip",value:function e(){if(this._next!==null){this._token=null;this._i=this._next}}},{key:"read_line",value:function e(){var t=this.__input__.length;if(this._i>=t){return eof}for(var r=this._i;r=r){return eof}if(t+this._i>=r){return this.read_rest()}var n=this._i+t;var i=this.__input__.substring(this._i,n);var a=i.match(/\n/g);if(a){this._line+=a.length}this._i=n;return i}},{key:"peek_char",value:function e(){if(this._i>=this.__input__.length){return eof}return LCharacter(this.__input__[this._i])}},{key:"read_char",value:function e(){var t=this.peek_char();this.skip_char();return t}},{key:"skip_char",value:function e(){if(this._i1&&arguments[1]!==undefined?arguments[1]:{},n=r.prev_char,i=r["char"],a=r.next_char;var o=_slicedToArray(t,4),u=o[0],s=o[1],c=o[2],l=o[3];if(t.length!==5){throw new Error("Lexer: Invalid rule of length ".concat(t.length))}if(!i.match(u)){return false}if(!match_or_null(s,n)){return false}if(!match_or_null(c,a)){return false}if(l!==this._state){return false}return true}},{key:"next_token",value:function e(){if(this._i>=this.__input__.length){return false}var t=true;e:for(var r=this._i,n=this.__input__.length;r2&&arguments[2]!==undefined?arguments[2]:null;var i=arguments.length>3&&arguments[3]!==undefined?arguments[3]:null;if(t.length===0){throw new Error("Lexer: invalid literal rule")}if(t.length===1){return[[t,n,i,null,null]]}var a=[];for(var o=0,u=t.length;o1&&arguments[1]!==undefined?arguments[1]:{},r=t.env,n=t.meta,i=n===void 0?false:n,a=t.formatter,o=a===void 0?multiline_formatter:a;_classCallCheck(this,u);if(e instanceof LString){e=e.toString()}read_only(this,"_formatter",o,{hidden:true});read_only(this,"__lexer__",new Lexer(e));read_only(this,"__env__",r);read_only(this,"_meta",i,{hidden:true});read_only(this,"_refs",[],{hidden:true});read_only(this,"_state",{parentheses:0},{hidden:true})}_createClass(u,[{key:"resolve",value:function e(t){return this.__env__&&this.__env__.get(t,{throwError:false})}},{key:"peek",value:function(){var e=_asyncToGenerator(_regeneratorRuntime.mark(function e(){var r;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:r=this.__lexer__.peek(true);if(!(r===eof)){t.next=4;break}return t.abrupt("return",eof);case 4:if(!this.is_comment(r.token)){t.next=7;break}this.skip();return t.abrupt("continue",0);case 7:if(!(r.token==="#;")){t.next=14;break}this.skip();if(!(this.__lexer__.peek()===eof)){t.next=11;break}throw new Error("Lexer: syntax error eof found after comment");case 11:t.next=13;return this._read_object();case 13:return t.abrupt("continue",0);case 14:return t.abrupt("break",17);case 17:r=this._formatter(r);if(!this._meta){t.next=20;break}return t.abrupt("return",r);case 20:return t.abrupt("return",r.token);case 21:case"end":return t.stop()}},e,this)}));function t(){return e.apply(this,arguments)}return t}()},{key:"reset",value:function e(){this._refs.length=0}},{key:"skip",value:function e(){this.__lexer__.skip()}},{key:"read",value:function(){var e=_asyncToGenerator(_regeneratorRuntime.mark(function e(){var r;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:t.next=2;return this.peek();case 2:r=t.sent;this.skip();return t.abrupt("return",r);case 5:case"end":return t.stop()}},e,this)}));function t(){return e.apply(this,arguments)}return t}()},{key:"match_datum_label",value:function e(t){var r=t.match(/^#([0-9]+)=$/);return r&&r[1]}},{key:"match_datum_ref",value:function e(t){var r=t.match(/^#([0-9]+)#$/);return r&&r[1]}},{key:"is_open",value:function e(t){var r=["(","["].includes(t);if(r){this._state.parentheses++}return r}},{key:"is_close",value:function e(t){var r=[")","]"].includes(t);if(r){this._state.parentheses--}return r}},{key:"read_list",value:function(){var e=_asyncToGenerator(_regeneratorRuntime.mark(function e(){var r,n,i,a,o;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:r=_nil,n=r;case 1:t.next=4;return this.peek();case 4:a=t.sent;if(!(a===eof)){t.next=7;break}return t.abrupt("break",32);case 7:if(!this.is_close(a)){t.next=10;break}this.skip();return t.abrupt("break",32);case 10:if(!(a==="."&&!is_nil(r))){t.next=18;break}this.skip();t.next=14;return this._read_object();case 14:n.cdr=t.sent;i=true;t.next=30;break;case 18:if(!i){t.next=22;break}throw new Error("Parser: syntax error more than one element after dot");case 22:t.t0=Pair;t.next=25;return this._read_object();case 25:t.t1=t.sent;t.t2=_nil;o=new t.t0(t.t1,t.t2);if(is_nil(r)){r=o}else{n.cdr=o}n=o;case 30:t.next=1;break;case 32:return t.abrupt("return",r);case 33:case"end":return t.stop()}},e,this)}));function t(){return e.apply(this,arguments)}return t}()},{key:"read_value",value:function(){var e=_asyncToGenerator(_regeneratorRuntime.mark(function e(){var r;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:t.next=2;return this.read();case 2:r=t.sent;if(!(r===eof)){t.next=5;break}throw new Error("Parser: Expected token eof found");case 5:return t.abrupt("return",parse_argument(r));case 6:case"end":return t.stop()}},e,this)}));function t(){return e.apply(this,arguments)}return t}()},{key:"is_comment",value:function e(t){return t.match(/^;/)||t.match(/^#\|/)&&t.match(/\|#$/)}},{key:"evaluate",value:function e(t){return _evaluate(t,{env:this.__env__,error:function e(t){throw t}})}},{key:"read_object",value:function(){var e=_asyncToGenerator(_regeneratorRuntime.mark(function e(){var r;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:this.reset();t.next=3;return this._read_object();case 3:r=t.sent;if(r instanceof DatumReference){r=r.valueOf()}if(!this._refs.length){t.next=7;break}return t.abrupt("return",this._resolve_object(r));case 7:return t.abrupt("return",r);case 8:case"end":return t.stop()}},e,this)}));function t(){return e.apply(this,arguments)}return t}()},{key:"balanced",value:function e(){return this._state.parentheses===0}},{key:"ballancing_error",value:function e(t,r){var n=this._state.parentheses;var i;if(n<0){i=new Error("Parser: unexpected parenthesis");i.__code__=[r.toString()+")"]}else{i=new Error("Parser: expected parenthesis but eof found");var a=new RegExp("\\){".concat(n,"}$"));i.__code__=[t.toString().replace(a,"")]}throw i}},{key:"_resolve_object",value:function(){var t=_asyncToGenerator(_regeneratorRuntime.mark(function e(r){var n=this;var i;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(!Array.isArray(r)){t.next=2;break}return t.abrupt("return",r.map(function(e){return n._resolve_object(e)}));case 2:if(!is_plain_object(r)){t.next=6;break}i={};Object.keys(r).forEach(function(e){i[e]=n._resolve_object(r[e])});return t.abrupt("return",i);case 6:if(!is_pair(r)){t.next=8;break}return t.abrupt("return",this._resolve_pair(r));case 8:return t.abrupt("return",r);case 9:case"end":return t.stop()}},e,this)}));function e(e){return t.apply(this,arguments)}return e}()},{key:"_resolve_pair",value:function(){var t=_asyncToGenerator(_regeneratorRuntime.mark(function e(r){return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(!is_pair(r)){t.next=15;break}if(!(r.car instanceof DatumReference)){t.next=7;break}t.next=4;return r.car.valueOf();case 4:r.car=t.sent;t.next=8;break;case 7:this._resolve_pair(r.car);case 8:if(!(r.cdr instanceof DatumReference)){t.next=14;break}t.next=11;return r.cdr.valueOf();case 11:r.cdr=t.sent;t.next=15;break;case 14:this._resolve_pair(r.cdr);case 15:return t.abrupt("return",r);case 16:case"end":return t.stop()}},e,this)}));function e(e){return t.apply(this,arguments)}return e}()},{key:"_read_object",value:function(){var e=_asyncToGenerator(_regeneratorRuntime.mark(function e(){var r,n,i,a,o,u,s,c,l,f,_;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:t.next=2;return this.peek();case 2:r=t.sent;if(!(r===eof)){t.next=5;break}return t.abrupt("return",r);case 5:if(!is_special(r)){t.next=38;break}n=specials.get(r);i=is_builtin(r);this.skip();o=is_symbol_extension(r);if(!o){t.next=14;break}t.t0=undefined;t.next=17;break;case 14:t.next=16;return this._read_object();case 16:t.t0=t.sent;case 17:u=t.t0;if(i){t.next=25;break}s=this.__env__.get(n.symbol);if(!(typeof s==="function")){t.next=25;break}if(is_literal(r)){c=[u]}else if(is_nil(u)){c=[]}else if(is_pair(u)){c=u.to_array(false)}if(!(c||o)){t.next=24;break}return t.abrupt("return",call_function(s,o?[]:c,{env:this.__env__,dynamic_env:this.__env__,use_dynamic:false}));case 24:throw new Error("Parse Error: Invalid parser extension "+"invocation ".concat(n.symbol));case 25:if(is_literal(r)){a=new Pair(n.symbol,new Pair(u,_nil))}else{a=new Pair(n.symbol,u)}if(!i){t.next=28;break}return t.abrupt("return",a);case 28:if(!(s instanceof Macro)){t.next=37;break}t.next=31;return this.evaluate(a);case 31:l=t.sent;if(!(is_pair(l)||l instanceof LSymbol)){t.next=34;break}return t.abrupt("return",Pair.fromArray([LSymbol("quote"),l]));case 34:return t.abrupt("return",l);case 37:throw new Error("Parse Error: invalid parser extension: "+n.symbol);case 38:f=this.match_datum_ref(r);if(!(f!==null)){t.next=44;break}this.skip();if(!this._refs[f]){t.next=43;break}return t.abrupt("return",new DatumReference(f,this._refs[f]));case 43:throw new Error("Parse Error: invalid datum label #".concat(f,"#"));case 44:_=this.match_datum_label(r);if(!(_!==null)){t.next=51;break}this.skip();this._refs[_]=this._read_object();return t.abrupt("return",this._refs[_]);case 51:if(!this.is_close(r)){t.next=55;break}this.skip();t.next=61;break;case 55:if(!this.is_open(r)){t.next=60;break}this.skip();return t.abrupt("return",this.read_list());case 60:return t.abrupt("return",this.read_value());case 61:case"end":return t.stop()}},e,this)}));function t(){return e.apply(this,arguments)}return t}()}]);return u}();var DatumReference=function(){function r(e,t){_classCallCheck(this,r);this.name=e;this.data=t}_createClass(r,[{key:"valueOf",value:function e(){return this.data}}]);return r}();function _parse(e,t){return _parse2.apply(this,arguments)}function _parse2(){_parse2=_wrapAsyncGenerator(_regeneratorRuntime.mark(function e(r,n){var i,a,o;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(!n){if(global_env){n=global_env.get("**interaction-environment**",{throwError:false})}else{n=user_env}}i=new Parser(r,{env:n});case 3:t.next=6;return _awaitAsyncGenerator(i.read_object());case 6:o=t.sent;if(!i.balanced()){i.ballancing_error(o,a)}if(!(o===eof)){t.next=10;break}return t.abrupt("break",15);case 10:a=o;t.next=13;return o;case 13:t.next=3;break;case 15:case"end":return t.stop()}},e)}));return _parse2.apply(this,arguments)}function unpromise(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:function(e){return e};var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:null;if(is_promise(e)){var n=e.then(t);if(r===null){return n}else{return n["catch"](r)}}if(e instanceof Array){return unpromise_array(e,t,r)}if(is_plain_object(e)){return unpromise_object(e,t,r)}return t(e)}function unpromise_array(t,r,e){if(t.find(is_promise)){return unpromise(promise_all(t),function(e){if(Object.isFrozen(t)){Object.freeze(e)}return r(e)},e)}return r(t)}function unpromise_object(t,e,r){var i=Object.keys(t);var n=[],a=[];var o=i.length;while(o--){var u=i[o];var s=t[u];n[o]=s;if(is_promise(s)){a.push(s)}}if(a.length){return unpromise(promise_all(n),function(e){var n={};e.forEach(function(e,t){var r=i[t];n[r]=e});if(Object.isFrozen(t)){Object.freeze(n)}return n},r)}return e(t)}function read_only(e,t,r){var n=arguments.length>3&&arguments[3]!==undefined?arguments[3]:{},i=n.hidden,a=i===void 0?false:i;Object.defineProperty(e,t,{value:r,configurable:true,enumerable:!a})}function uniterate_async(e){return _uniterate_async.apply(this,arguments)}function _uniterate_async(){_uniterate_async=_asyncToGenerator(_regeneratorRuntime.mark(function e(r){var n,i,a,o,u,s,c;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:n=[];i=false;a=false;t.prev=3;u=_asyncIterator(r);case 5:t.next=7;return u.next();case 7:if(!(i=!(s=t.sent).done)){t.next=13;break}c=s.value;n.push(c);case 10:i=false;t.next=5;break;case 13:t.next=19;break;case 15:t.prev=15;t.t0=t["catch"](3);a=true;o=t.t0;case 19:t.prev=19;t.prev=20;if(!(i&&u["return"]!=null)){t.next=24;break}t.next=24;return u["return"]();case 24:t.prev=24;if(!a){t.next=27;break}throw o;case 27:return t.finish(24);case 28:return t.finish(19);case 29:return t.abrupt("return",n);case 30:case"end":return t.stop()}},e,null,[[3,15,19,29],[20,,24,28]])}));return _uniterate_async.apply(this,arguments)}function matcher(e,t){if(t instanceof RegExp){return function(e){return String(e).match(t)}}else if(is_function(t)){return t}throw new Error("Invalid matcher")}function doc(e,t,r,n){if(typeof e!=="string"){t=arguments[0];r=arguments[1];n=arguments[2];e=null}if(r){if(n){t.__doc__=r}else{t.__doc__=trim_lines(r)}}if(e){t.__name__=e}else if(t.name&&!is_lambda(t)){t.__name__=t.name}return t}function trim_lines(e){return e.split("\n").map(function(e){return e.trim()}).join("\n")}function previousSexp(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:1;var r=e.length;if(t<=0){throw Error("previousSexp: Invalid argument sexp = ".concat(t))}e:while(t--&&r>=0){var n=1;while(n>0){var i=e[--r];if(!i){break e}if(i==="("||i.token==="("){n--}else if(i===")"||i.token===")"){n++}}r--}return e.slice(r+1)}function lineIndent(e){if(!e||!e.length){return 0}var t=e.length;if(e[t-1].token==="\n"){return 0}while(--t){if(e[t].token==="\n"){var r=(e[t+1]||{}).token;if(r){return r.length}}}return 0}function match(e,t){return l(e,t)===t.length;function l(r,n){function e(e,t){var r=_createForOfIteratorHelper(e),n;try{for(r.s();!(n=r.n()).done;){var i=n.value;var a=l(i,t);if(a!==-1){return a}}}catch(e){r.e(e)}finally{r.f()}return-1}function t(){return r[a]===Symbol["for"]("symbol")&&!is_symbol_string(n[u])}function i(){var e=r[a+1];var t=n[u+1];if(e!==undefined&&t!==undefined){return l([e],[t])}}var a=0;var o={};for(var u=0;u0){continue}}else if(t()){return-1}}else if(r[a]instanceof Array){var c=l(r[a],n.slice(u));if(c===-1||c+u>n.length){return-1}u+=c-1;a++;continue}else{return-1}a++}if(r.length!==a){return-1}return n.length}}function Formatter(e){this.__code__=e.replace(/\r/g,"")}Formatter.defaults={offset:0,indent:2,exceptions:{specials:[/^(?:#:)?(?:define(?:-values|-syntax|-macro|-class|-record-type)?|(?:call-with-(?:input-file|output-file|port))|lambda|let-env|try|catch|when|unless|while|syntax-rules|(let|letrec)(-syntax|\*?-values|\*)?)$/],shift:{1:["&","#"]}}};Formatter.match=match;Formatter.prototype._options=function e(t){var r=Formatter.defaults;if(typeof t==="undefined"){return Object.assign({},r)}var n=t&&t.exceptions||{};var i=n.specials||[];var a=n.shift||{1:[]};return _objectSpread(_objectSpread(_objectSpread({},r),t),{},{exceptions:{specials:[].concat(_toConsumableArray(r.exceptions.specials),_toConsumableArray(i)),shift:_objectSpread(_objectSpread({},a),{},{1:[].concat(_toConsumableArray(r.exceptions.shift[1]),_toConsumableArray(a[1]))})}})};Formatter.prototype.indent=function e(t){var r=tokenize(this.__code__,true);return this._indent(r,t)};Formatter.exception_shift=function(a,e){function t(e){if(!e.length){return false}if(e.indexOf(a)!==-1){return true}else{var t=e.filter(function(e){return e instanceof RegExp});if(!t.length){return false}var r=_createForOfIteratorHelper(t),n;try{for(r.s();!(n=r.n()).done;){var i=n.value;if(a.match(i)){return true}}}catch(e){r.e(e)}finally{r.f()}}return false}if(t(e.exceptions.specials)){return e.indent}var r=e.exceptions.shift;for(var n=0,i=Object.entries(r);n0){n.offset=0}if(a.toString()===t.toString()&&balanced(a)){return n.offset+a[0].col}else if(a.length===1){return n.offset+a[0].col+1}else{var s=-1;if(o){var c=Formatter.exception_shift(o.token,n);if(c!==-1){s=c}}if(s===-1){s=Formatter.exception_shift(a[1].token,n)}if(s!==-1){return n.offset+a[0].col+s}else if(a[0].line3&&a[1].line===a[3].line){if(a[1].token==="("||a[1].token==="["){return n.offset+a[1].col}return n.offset+a[3].col}else if(a[0].line===a[1].line){return n.offset+n.indent+a[0].col}else{var l=a.slice(2);for(var f=0;f")};Ahead.prototype.match=function(e){return e.match(this.pattern)};function Pattern(){for(var e=arguments.length,t=new Array(e),r=0;r")};Formatter.Pattern=Pattern;Formatter.Ahead=Ahead;var p_o=/^[[(]$/;var p_e=/^[\])]$/;var not_p=/[^()[\]]/;var not_close=new Ahead(/[^)\]]/);var glob=Symbol["for"]("*");var sexp_or_atom=new Pattern([p_o,glob,p_e],[not_p],"+");var sexp=new Pattern([p_o,glob,p_e],"+");var symbol=new Pattern([Symbol["for"]("symbol")],"?");var symbols=new Pattern([Symbol["for"]("symbol")],"*");var identifiers=[p_o,symbols,p_e];var let_value=new Pattern([p_o,Symbol["for"]("symbol"),glob,p_e],"+");var syntax_rules=keywords_re("syntax-rules");var def_lambda_re=keywords_re("define","lambda","define-macro","syntax-rules");var non_def=/^(?!.*\b(?:[()[\]]|define(?:-macro)?|let(?:\*|rec|-env|-syntax|)?|lambda|syntax-rules)\b).*$/;var let_re=/^(?:#:)?(let(?:\*|rec|-env|-syntax)?)$/;function keywords_re(){for(var e=arguments.length,t=new Array(e),r=0;r0&&!u[e]){u[e]=previousSexp(o,e)}});var s=_createForOfIteratorHelper(i),c;try{for(s.s();!(c=s.n()).done;){var l=_slicedToArray(c.value,3),f=l[0],_=l[1],p=l[2];_=_.valueOf();var h=_>0?u[_]:o;var d=h.filter(function(e){return e.trim()&&!is_special(e)});var m=r(h);var y=match(f,d);var v=n.slice(a).find(function(e){return e.trim()&&!is_special(e)});if(y&&(p instanceof Ahead&&p.match(v)||!p)){var g=a-m;if(n[g]!=="\n"){if(!n[g].trim()){n[g]="\n"}else{n.splice(g,0,"\n");a++}}a+=m;continue e}}}catch(e){s.e(e)}finally{s.f()}}this.__code__=n.join("");return this};Formatter.prototype._spaces=function(e){return" ".repeat(e)};Formatter.prototype.format=function e(t){var r=this.__code__.replace(/[ \t]*\n[ \t]*/g,"\n ");var n=tokenize(r,true);var i=this._options(t);var a=0;var o=0;for(var u=0;u0){n=Math.floor(t()*r);r--;var i=[e[n],e[r]];e[r]=i[0];e[n]=i[1]}return e}function Nil(){}Nil.prototype.toString=function(){return"()"};Nil.prototype.valueOf=function(){return undefined};Nil.prototype.serialize=function(){return 0};Nil.prototype.to_object=function(){return{}};Nil.prototype.append=function(e){return new Pair(e,_nil)};Nil.prototype.to_array=function(){return[]};var _nil=new Nil;function Pair(e,t){if(typeof this!=="undefined"&&this.constructor!==Pair||typeof this==="undefined"){return new Pair(e,t)}this.car=e;this.cdr=t}function to_array(a,o){return function e(t){typecheck(a,t,["pair","nil"]);if(is_nil(t)){return[]}var r=[];var n=t;while(true){if(is_pair(n)){if(n.haveCycles("cdr")){break}var i=n.car;if(o&&is_pair(i)){i=this.get(a).call(this,i)}r.push(i);n=n.cdr}else if(is_nil(n)){break}else{throw new Error("".concat(a,": can't convert improper list"))}}return r}}Pair.prototype.flatten=function(){return Pair.fromArray(flatten(this.to_array()))};Pair.prototype.length=function(){var e=0;var t=this;while(true){if(!t||is_nil(t)||!is_pair(t)||t.haveCycles("cdr")){break}e++;t=t.cdr}return e};Pair.match=function(e,t){if(e instanceof LSymbol){return LSymbol.is(e,t)}else if(is_pair(e)){return Pair.match(e.car,t)||Pair.match(e.cdr,t)}else if(Array.isArray(e)){return e.some(function(e){return Pair.match(e,t)})}else if(is_plain_object(e)){return Object.values(e).some(function(e){return Pair.match(e,t)})}return false};Pair.prototype.find=function(e){return Pair.match(this,e)};Pair.prototype.clone=function(){var r=arguments.length>0&&arguments[0]!==undefined?arguments[0]:true;var n=new Map;function i(e){if(is_pair(e)){if(n.has(e)){return n.get(e)}var t=new Pair;n.set(e,t);if(r){t.car=i(e.car)}else{t.car=e.car}t.cdr=i(e.cdr);t[__cycles__]=e[__cycles__];return t}return e}return i(this)};Pair.prototype.last_pair=function(){var e=this;while(true){if(!is_pair(e.cdr)){return e}if(e.haveCycles("cdr")){break}e=e.cdr}};Pair.prototype.to_array=function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:true;var t=[];if(is_pair(this.car)){if(e){t.push(this.car.to_array())}else{t.push(this.car)}}else{t.push(this.car.valueOf())}if(is_pair(this.cdr)){t=t.concat(this.cdr.to_array(e))}return t};Pair.fromArray=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:true;var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:false;if(is_pair(e)||r&&e instanceof Array&&e[__data__]){return e}if(t===false){var n=_nil;for(var i=e.length;i--;){n=new Pair(e[i],n)}return n}if(e.length&&!(e instanceof Array)){e=_toConsumableArray(e)}var a=_nil;var o=e.length;while(o--){var u=e[o];if(u instanceof Array){u=Pair.fromArray(u,t,r)}else if(typeof u==="string"){u=LString(u)}else if(typeof u==="number"&&!Number.isNaN(u)){u=LNumber(u)}a=new Pair(u,a)}return a};Pair.prototype.to_object=function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:false;var t=this;var r={};while(true){if(is_pair(t)&&is_pair(t.car)){var n=t.car;var i=n.car;if(i instanceof LSymbol){i=i.__name__}if(i instanceof LString){i=i.valueOf()}var a=n.cdr;if(is_pair(a)){a=a.to_object(e)}if(is_native(a)){if(!e){a=a.valueOf()}}r[i]=a;t=t.cdr}else{break}}return r};Pair.fromPairs=function(e){return e.reduce(function(e,t){return new Pair(new Pair(new LSymbol(t[0]),t[1]),e)},_nil)};Pair.fromObject=function(t){var e=Object.keys(t).map(function(e){return[e,t[e]]});return Pair.fromPairs(e)};Pair.prototype.reduce=function(e){var t=this;var r=_nil;while(true){if(!is_nil(t)){r=e(r,t.car);t=t.cdr}else{break}}return r};Pair.prototype.reverse=function(){if(this.haveCycles()){throw new Error("You can't reverse list that have cycles")}var e=this;var t=_nil;while(!is_nil(e)){var r=e.cdr;e.cdr=t;t=e;e=r}return t};Pair.prototype.transform=function(n){function i(e){if(is_pair(e)){if(e.replace){delete e.replace;return e}var t=n(e.car);if(is_pair(t)){t=i(t)}var r=n(e.cdr);if(is_pair(r)){r=i(r)}return new Pair(t,r)}return e}return i(this)};Pair.prototype.map=function(e){if(typeof this.car!=="undefined"){return new Pair(e(this.car),is_nil(this.cdr)?_nil:this.cdr.map(e))}else{return _nil}};var repr=new Map;function is_plain_object(e){return e&&_typeof$1(e)==="object"&&e.constructor===Object}var props=Object.getOwnPropertyNames(Array.prototype);var array_methods=[];props.forEach(function(e){array_methods.push(Array[e],Array.prototype[e])});function is_array_method(e){e=unbind(e);return array_methods.includes(e)}function is_lips_function(e){return is_function(e)&&(is_lambda(e)||e.__doc__)}function user_repr(r){var e=r.constructor||Object;var n=is_plain_object(r);var i=is_function(r[Symbol.asyncIterator])||is_function(r[Symbol.iterator]);var a;if(repr.has(e)){a=repr.get(e)}else{repr.forEach(function(e,t){t=unbind(t);if(r.constructor===t&&(t===Object&&n&&!i||t!==Object)){a=e}})}return a}var str_mapping=new Map;[[true,"#t"],[false,"#f"],[null,"null"],[undefined,"#"]].forEach(function(e){var t=_slicedToArray(e,2),r=t[0],n=t[1];str_mapping.set(r,n)});function symbolize(r){if(r&&_typeof$1(r)==="object"){var n={};var e=Object.getOwnPropertySymbols(r);e.forEach(function(e){var t=e.toString().replace(/Symbol\(([^)]+)\)/,"$1");n[t]=toString(r[e])});var t=Object.getOwnPropertyNames(r);t.forEach(function(e){var t=r[e];if(t&&_typeof$1(t)==="object"&&t.constructor===Object){n[e]=symbolize(t)}else{n[e]=toString(t)}});return n}return r}function get_props(e){return Object.keys(e).concat(Object.getOwnPropertySymbols(e))}function has_own_function(e,t){return e.hasOwnProperty(t)&&is_function(e.toString)}function function_to_string(e){if(is_native_function(e)){return"#"}var t=e.prototype&&e.prototype.constructor;if(is_function(t)&&is_lambda(t)){if(e[__class__]&&t.hasOwnProperty("__name__")){var r=t.__name__;if(LString.isString(r)){r=r.toString();return"#")}return"#"}}if(e.hasOwnProperty("__name__")){var n=e.__name__;if(_typeof$1(n)==="symbol"){n=symbol_to_string(n)}if(typeof n==="string"){return"#")}}if(has_own_function(e,"toString")){return e.toString()}else if(e.name&&!is_lambda(e)){return"#")}else{return"#"}}var instances=new Map;[[Error,function(e){return e.message}],[Pair,function(e,t){var r=t.quote,n=t.skip_cycles,i=t.pair_args;if(!n){e.markCycles()}return e.toString.apply(e,[r].concat(_toConsumableArray(i)))}],[LCharacter,function(e,t){var r=t.quote;if(r){return e.toString()}return e.valueOf()}],[LString,function(e,t){var r=t.quote;e=e.toString();if(r){return JSON.stringify(e).replace(/\\n/g,"\n")}return e}],[RegExp,function(e){return"#"+e.toString()}]].forEach(function(e){var t=_slicedToArray(e,2),r=t[0],n=t[1];instances.set(r,n)});var native_types=[LSymbol,LNumber,Macro,Values,InputPort,OutputPort,Environment,QuotedPromise];function toString(e,t,r){if(typeof jQuery!=="undefined"&&e instanceof jQuery.fn.init){return"#"}if(str_mapping.has(e)){return str_mapping.get(e)}if(is_prototype(e)){return"#"}if(e){var n=e.constructor;if(instances.has(n)){for(var i=arguments.length,a=new Array(i>3?i-3:0),o=3;o"}if(e===null){return"null"}if(_typeof$1(e)==="object"){var l=e.constructor;if(!l){l=Object}var f;if(typeof l.__class__==="string"){f=l.__class__}else{var _=user_repr(e);if(_){if(is_function(_)){return _(e,t)}else{throw new Error("toString: Invalid repr value")}}f=l.name}if(is_function(e.toString)&&is_lambda(e.toString)){return e.toString().valueOf()}if(type(e)==="instance"){if(is_lambda(l)&&l.__name__){f=l.__name__.valueOf()}else if(!is_native_function(l)){f="instance"}}if(is_iterator(e,Symbol.iterator)){if(f){return"#")}return"#"}if(is_iterator(e,Symbol.asyncIterator)){if(f){return"#")}return"#"}if(f!==""){return"#<"+f+">"}return"#"}if(typeof e!=="string"){return e.toString()}return e}function is_prototype(e){return e&&_typeof$1(e)==="object"&&e.hasOwnProperty&&e.hasOwnProperty("constructor")&&typeof e.constructor==="function"&&e.constructor.prototype===e}Pair.prototype.markCycles=function(){markCycles(this);return this};Pair.prototype.haveCycles=function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:null;if(!e){return this.haveCycles("car")||this.haveCycles("cdr")}return!!(this[__cycles__]&&this[__cycles__][e])};function markCycles(e){var t=[];var i=[];var a=[];function o(e){if(!t.includes(e)){t.push(e)}}function u(e,t,r,n){if(is_pair(r)){if(n.includes(r)){if(!a.includes(r)){a.push(r)}if(!e[__cycles__]){e[__cycles__]={}}e[__cycles__][t]=r;if(!i.includes(e)){i.push(e)}return true}}}var s=trampoline(function e(t,r){if(is_pair(t)){delete t.ref;delete t[__cycles__];o(t);r.push(t);var n=u(t,"car",t.car,r);var i=u(t,"cdr",t.cdr,r);if(!n){s(t.car,r.slice())}if(!i){return new Thunk(function(){return e(t.cdr,r.slice())})}}});function r(e,t){if(is_pair(e[__cycles__][t])){var r=n.indexOf(e[__cycles__][t]);e[__cycles__][t]="#".concat(r,"#")}}s(e,[]);var n=t.filter(function(e){return a.includes(e)});n.forEach(function(e,t){e[__ref__]="#".concat(t,"=")});i.forEach(function(e){r(e,"car");r(e,"cdr")})}Pair.prototype.toString=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},r=t.nested,n=r===void 0?false:r;var i=[];if(this[__ref__]){i.push(this[__ref__]+"(")}else if(!n){i.push("(")}var a;if(this[__cycles__]&&this[__cycles__].car){a=this[__cycles__].car}else{a=toString(this.car,e,true)}if(a!==undefined){i.push(a)}if(is_pair(this.cdr)){if(this[__cycles__]&&this[__cycles__].cdr){i.push(" . ");i.push(this[__cycles__].cdr)}else{if(this.cdr[__ref__]){i.push(" . ")}else{i.push(" ")}var o=this.cdr.toString(e,{nested:true});i.push(o)}}else if(!is_nil(this.cdr)){i=i.concat([" . ",toString(this.cdr,e,true)])}if(!n||this[__ref__]){i.push(")")}return i.join("")};Pair.prototype.set=function(e,t){this[e]=t;if(is_pair(t)){this.markCycles()}};Pair.prototype.append=function(e){if(e instanceof Array){return this.append(Pair.fromArray(e))}var t=this;if(t.car===undefined){if(is_pair(e)){this.car=e.car;this.cdr=e.cdr}else{this.car=e}}else if(!is_nil(e)){while(true){if(is_pair(t)&&!is_nil(t.cdr)){t=t.cdr}else{break}}t.cdr=e}return this};Pair.prototype.serialize=function(){return[this.car,this.cdr]};Pair.prototype[Symbol.iterator]=function(){var r=this;return{next:function e(){var t=r;r=t.cdr;if(is_nil(t)){return{value:undefined,done:true}}else{return{value:t.car,done:false}}}}};function abs(e){return e<0?-e:e}function seq_compare(e,t){var r=_toArray(t),n=r[0],i=r.slice(1);while(i.length>0){var a=i,o=_slicedToArray(a,1),u=o[0];if(!e(n,u)){return false}var s=i;var c=_toArray(s);n=c[0];i=c.slice(1)}return true}function equal(e,t){if(is_function(e)){return is_function(t)&&unbind(e)===unbind(t)}else if(e instanceof LNumber){if(!(t instanceof LNumber)){return false}var r;if(e.__type__===t.__type__){if(e.__type__==="complex"){r=e.__im__.__type__===t.__im__.__type__&&e.__re__.__type__===t.__re__.__type__}else{r=true}if(r&&e.cmp(t)===0){if(e.valueOf()===0){return Object.is(e.valueOf(),t.valueOf())}return true}}return false}else if(typeof e==="number"){if(typeof t!=="number"){return false}if(Number.isNaN(e)){return Number.isNaN(t)}if(e===Number.NEGATIVE_INFINITY){return t===Number.NEGATIVE_INFINITY}if(e===Number.POSITIVE_INFINITY){return t===Number.POSITIVE_INFINITY}return equal(LNumber(e),LNumber(t))}else if(e instanceof LCharacter){if(!(t instanceof LCharacter)){return false}return e.__char__===t.__char__}else{return e===t}}function same_atom(e,t){if(type(e)!==type(t)){return false}if(!is_atom(e)){return false}if(e instanceof RegExp){return e.source===t.source}if(e instanceof LString){return e.valueOf()===t.valueOf()}return equal(e,t)}function is_atom(e){return e instanceof LSymbol||LString.isString(e)||is_nil(e)||e===null||e instanceof LCharacter||e instanceof LNumber||e===true||e===false}var truncate=function(){if(Math.trunc){return Math.trunc}else{return function(e){if(e===0){return 0}else if(e<0){return Math.ceil(e)}else{return Math.floor(e)}}}}();function Macro(e,t,r,n){if(typeof this!=="undefined"&&this.constructor!==Macro||typeof this==="undefined"){return new Macro(e,t)}typecheck("Macro",e,"string",1);typecheck("Macro",t,"function",2);if(r){if(n){this.__doc__=r}else{this.__doc__=trim_lines(r)}}this.__name__=e;this.__fn__=t}Macro.defmacro=function(e,t,r,n){var i=new Macro(e,t,r,n);i.__defmacro__=true;return i};Macro.prototype.invoke=function(e,t,r){var n=t.env,i=_objectWithoutProperties(t,_excluded2);var a=_objectSpread(_objectSpread({},i),{},{macro_expand:r});var o=this.__fn__.call(n,e,a,this.__name__);return o};Macro.prototype.toString=function(){return"#")};var macro="define-macro";var recur_guard=-1e4;function macro_expand(c){return function(){var r=_asyncToGenerator(_regeneratorRuntime.mark(function e(r,v){var a,g,n,i,o,b,w,D,x,E,L,A,u,S,s;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:s=function e(){s=_asyncToGenerator(_regeneratorRuntime.mark(function e(r,n,i){var a,o,u,s,c,l,f,_,p,h,d,m,y;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(!(is_pair(r)&&r.car instanceof LSymbol)){t.next=50;break}if(!r[__data__]){t.next=3;break}return t.abrupt("return",r);case 3:a=r.car.valueOf();o=i.get(r.car,{throwError:false});u=b(r.car);s=u||w(o,r)||D(o);if(!(s&&is_pair(r.cdr.car))){t.next=28;break}if(!u){t.next=15;break}g=E(r.cdr.car);t.next=12;return A(r.cdr.car,n);case 12:c=t.sent;t.next=17;break;case 15:g=x(r.cdr.car);c=r.cdr.car;case 17:t.t0=Pair;t.t1=r.car;t.t2=Pair;t.t3=c;t.next=23;return S(r.cdr.cdr,n,i);case 23:t.t4=t.sent;t.t5=new t.t2(t.t3,t.t4);return t.abrupt("return",new t.t0(t.t1,t.t5));case 28:if(!L(a,o)){t.next=50;break}l=o instanceof Syntax?r:r.cdr;t.next=32;return o.invoke(l,_objectSpread(_objectSpread({},v),{},{env:i}),true);case 32:f=t.sent;if(!(o instanceof Syntax)){t.next=41;break}_=f,p=_.expr,h=_.scope;if(!is_pair(p)){t.next=40;break}if(!(n!==-1&&n<=1||n")}return"#"};var SyntaxParameter=_createClass(function e(t){_classCallCheck(this,e);read_only(this,"_syntax",t,{hidden:true});read_only(this._syntax,"_param",true,{hidden:true})});Syntax.Parameter=SyntaxParameter;function extract_patterns(e,t,I,N){var r=arguments.length>4&&arguments[4]!==undefined?arguments[4]:{};var j={"...":{symbols:{},lists:[]},symbols:{}};var R=r.expansion,T=r.define;log(I);function $(t,e){var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:[];var n=arguments.length>3&&arguments[3]!==undefined?arguments[3]:false;log({code:e,pattern:t});if(is_atom(t)&&!(t instanceof LSymbol)){return same_atom(t,e)}if(t instanceof LSymbol&&I.includes(t.literal())){if(!LSymbol.is(e,t)){return false}var i=R.ref(t);return!i||i===T||i===global_env}if(Array.isArray(t)&&Array.isArray(e)){log("<<< a 1");if(t.length===0&&e.length===0){return true}if(LSymbol.is(t[1],N)){if(t[0]instanceof LSymbol){var a=t[0].valueOf();log("<<< a 2 "+n);if(n){var o=e.length-2;var u=o>0?e.slice(0,o):e;var s=Pair.fromArray(u,false);if(!j["..."].symbols[a]){j["..."].symbols[a]=new Pair(s,_nil)}else{j["..."].symbols[a].append(new Pair(s,_nil))}}else{j["..."].symbols[a]=Pair.fromArray(e,false)}}else if(Array.isArray(t[0])){log("<<< a 3");var c=_toConsumableArray(r);if(!e.every(function(e){return $(t[0],e,c,true)})){return false}}if(t.length>2){var l=t.slice(2);return $(l,e.slice(-l.length),r,n)}return true}var f=$(t[0],e[0],r,n);log({first:f,pattern:t[0],code:e[0]});var _=$(t.slice(1),e.slice(1),r,n);log({first:f,rest:_});return f&&_}if(is_pair(t)&&is_pair(t.car)&&is_pair(t.car.cdr)&&LSymbol.is(t.car.cdr.car,N)){log(">> 0");if(is_nil(e)){log({pattern:t});if(t.car.car instanceof LSymbol){var p=t.car.car.valueOf();if(j["..."].symbols[p]){throw new Error("syntax: named ellipsis can only "+"appear onces")}j["..."].symbols[p]=e}}}if(is_pair(t)&&is_pair(t.cdr)&&LSymbol.is(t.cdr.car,N)){if(!is_nil(t.cdr.cdr)){if(is_pair(t.cdr.cdr)){var h=t.cdr.cdr.length();if(!is_pair(e)){return false}var d=e.length();var m=e;while(d-1>h){m=m.cdr;d--}var y=m.cdr;m.cdr=_nil;if(!$(t.cdr.cdr,y,r,n)){return false}}}if(t.car instanceof LSymbol){var v=t.car.__name__;if(j["..."].symbols[v]&&!r.includes(v)&&!n){throw new Error("syntax: named ellipsis can only appear onces")}log(">> 1");if(is_nil(e)){log(">> 2");if(n){log("NIL");j["..."].symbols[v]=_nil}else{log("NULL");j["..."].symbols[v]=null}}else if(is_pair(e)&&(is_pair(e.car)||is_nil(e.car))){log(">> 3 "+n);if(n){if(j["..."].symbols[v]){var g=j["..."].symbols[v];if(is_nil(g)){g=new Pair(_nil,new Pair(e,_nil))}else{g=g.append(new Pair(e,_nil))}j["..."].symbols[v]=g}else{j["..."].symbols[v]=new Pair(e,_nil)}}else{log(">> 4");j["..."].symbols[v]=new Pair(e,_nil)}}else{log(">> 6");if(is_pair(e)){if(!is_pair(e.cdr)&&!is_nil(e.cdr)){log(">> 7 (b)");if(is_nil(t.cdr.cdr)){return false}else if(!j["..."].symbols[v]){j["..."].symbols[v]=new Pair(e.car,_nil);return $(t.cdr.cdr,e.cdr)}}var b=e.last_pair();if(!is_nil(b.cdr)){if(is_nil(t.cdr.cdr)){return false}else{var w=e.clone();w.last_pair().cdr=_nil;j["..."].symbols[v]=w;return $(t.cdr.cdr,b.cdr)}}log(">> 7 "+n);r.push(v);if(!j["..."].symbols[v]){j["..."].symbols[v]=new Pair(e,_nil)}else{var D=j["..."].symbols[v];j["..."].symbols[v]=D.append(new Pair(e,_nil))}log({IIIIII:j["..."].symbols[v]})}else if(t.car instanceof LSymbol&&is_pair(t.cdr)&&LSymbol.is(t.cdr.car,N)){log(">> 8");j["..."].symbols[v]=null;return $(t.cdr.cdr,e)}else{log(">> 9");return false}}return true}else if(is_pair(t.car)){var x=_toConsumableArray(r);if(is_nil(e)){log(">> 10");j["..."].lists.push(_nil);return true}log(">> 11");var E=e;while(is_pair(E)){if(!$(t.car,E.car,x,true)){return false}E=E.cdr}return true}if(Array.isArray(t.car)){var x=_toConsumableArray(r);var L=e;while(is_pair(L)){if(!$(t.car,L.car,x,true)){return false}L=L.cdr}return true}return false}if(t instanceof LSymbol){if(LSymbol.is(t,N)){throw new Error("syntax: invalid usage of ellipsis")}log(">> 12");var A=t.__name__;if(I.includes(A)){return true}if(n){var S,F;log(j["..."].symbols[A]);(F=(S=j["..."].symbols)[A])!==null&&F!==void 0?F:S[A]=[];j["..."].symbols[A].push(e)}else{j.symbols[A]=e}return true}if(is_pair(t)&&is_pair(e)){log(">> 13");log({a:13,code:e,pattern:t});if(is_nil(e.cdr)){var k=t.car instanceof LSymbol&&t.cdr instanceof LSymbol;if(k){if(!$(t.car,e.car,r,n)){return false}log(">> 14");var C=t.cdr.valueOf();if(!(C in j.symbols)){j.symbols[C]=_nil}C=t.car.valueOf();if(!(C in j.symbols)){j.symbols[C]=e.car}return true}}log({pattern:t,code:e});if(is_pair(t.cdr)&&is_pair(t.cdr.cdr)&&t.cdr.car instanceof LSymbol&&LSymbol.is(t.cdr.cdr.car,N)&&is_pair(t.cdr.cdr.cdr)&&!LSymbol.is(t.cdr.cdr.cdr.car,N)&&$(t.car,e.car,r,n)&&$(t.cdr.cdr.cdr,e.cdr,r,n)){var B=t.cdr.car.__name__;log({pattern:t,code:e,name:B});if(I.includes(B)){return true}j["..."].symbols[B]=null;return true}log("recur");log({pattern:t,code:e});var O=$(t.car,e.car,r,n);log({car:O,pattern:t.car,code:e.car});var P=$(t.cdr,e.cdr,r,n);log({car:O,cdr:P});if(O&&P){return true}}else if(is_nil(t)&&(is_nil(e)||e===undefined)){return true}else if(is_pair(t.car)&&LSymbol.is(t.car.car,N)){throw new Error("syntax: invalid usage of ellipsis")}else{return false}}if($(e,t)){return j}}function clear_gensyms(e,i){function a(t){if(is_pair(t)){if(!i.length){return t}var e=a(t.car);var r=a(t.cdr);return new Pair(e,r)}else if(t instanceof LSymbol){var n=i.find(function(e){return e.gensym===t});if(n){return LSymbol(n.name)}return t}else{return t}}return a(e)}function transform_syntax(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};var O=e.bindings,t=e.expr,P=e.scope,o=e.symbols,l=e.names,I=e.ellipsis;var f={};function u(e){if(e instanceof LSymbol){return true}return["string","symbol"].includes(_typeof$1(e))}function N(e){if(!u(e)){var t=type(e);throw new Error("syntax: internal error, need symbol got ".concat(t))}var r=e.valueOf();if(r===I){throw new Error("syntax: internal error, ellipis not transformed")}var n=_typeof$1(r);if(["string","symbol"].includes(n)){if(r in O.symbols){return O.symbols[r]}else if(n==="string"&&r.match(/\./)){var i=r.split(".");var a=i[0];if(a in O.symbols){return Pair.fromArray([LSymbol("."),O.symbols[a]].concat(i.slice(1).map(function(e){return LString(e)})))}}}if(o.includes(r)){return e}return s(r,e)}function s(e,t){if(!f[e]){var r=P.ref(e);if(_typeof$1(e)==="symbol"&&!r){e=t.literal()}if(f[e]){return f[e]}var n=gensym(e);if(r){var i=P.get(e);P.set(n,i)}else{var a=P.get(e,{throwError:false});if(typeof a!=="undefined"){P.set(n,a)}}l.push({name:e,gensym:n});f[e]=n;if(typeof e==="string"&&e.match(/\./)){var o=e.split(".").filter(Boolean),u=_toArray(o),s=u[0],c=u.slice(1);if(f[s]){hidden_prop(n,"__object__",[f[s]].concat(_toConsumableArray(c)))}}}return f[e]}function j(e,t,r){var n=arguments.length>3&&arguments[3]!==undefined?arguments[3]:function(){};var i=r.nested;log({bindings:t,expr:e});if(Array.isArray(e)&&!e.length){return e}if(e instanceof LSymbol){var a=e.valueOf();if(is_gensym(e)&&!t[a]);log("[t 1");if(t[a]){if(is_pair(t[a])){var o=t[a],u=o.car,s=o.cdr;if(i){var c=u.car,l=u.cdr;if(!is_nil(l)){n(a,new Pair(l,_nil))}return c}if(!is_nil(s)){n(a,s)}return u}else if(t[a]instanceof Array){n(a,t[a].slice(1));return t[a][0]}}return N(e)}var f=Array.isArray(e);if(is_pair(e)||f){var _=f?e[0]:e.car;var p=f?e[1]:is_pair(e.cdr)&&e.cdr.car;if(_ instanceof LSymbol&&LSymbol.is(p,I)){f?e.slice(2):e.cdr.cdr;log("[t 2");var h=_.valueOf();var d=t[h];if(d===null){return}else if(d){log({name:h,binding:t[h]});if(is_pair(d)){log("[t 2 Pair "+i);var m=d.car,y=d.cdr;var v=f?e.slice(2):e.cdr.cdr;if(i){if(!is_nil(y)){log("|| next 1");n(h,y)}if(f&&v.length||!is_nil(v)&&!f){var g=j(v,t,r,n);if(f){return m.concat(g)}else if(is_pair(m)){return m.append(g)}else{log("UNKNOWN")}}return m}else if(is_pair(m)){if(!is_nil(m.cdr)){log("|| next 2");n(h,new Pair(m.cdr,y))}return m.car}else if(is_nil(y)){return m}else{var b=e.last_pair();if(b.cdr instanceof LSymbol){log("|| next 3");n(h,d.last_pair());return m}}}else if(d instanceof Array){log("[t 2 Array "+i);if(i){n(h,d.slice(1));return Pair.fromArray(d)}else{var w=d.slice(1);if(w.length){n(h,w)}return d[0]}}else{return d}}}log("[t 3 recur ",e);var D=f?e.slice(1):e.cdr;var x=j(_,t,r,n);var E=j(D,t,r,n);log({head:x,rest:E});if(f){return[x].concat(E)}return new Pair(x,E)}return e}function R(t,r){var e=Object.values(t);var n=Object.getOwnPropertySymbols(t);if(n.length){e.push.apply(e,_toConsumableArray(n.map(function(e){return t[e]})))}return e.length&&e.every(function(e){if(e===null){return!r}return is_pair(e)||is_nil(e)||Array.isArray(e)&&e.length})}function T(e){return Object.keys(e).concat(Object.getOwnPropertySymbols(e))}function $(i){var e=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},t=e.disabled;log("traverse>> ",i);var a=Array.isArray(i);if(a&&i.length===0){return i}if(is_pair(i)||a){var r=a?i[0]:i.car;var n,o;if(a){n=i[1];o=i.slice(2)}else if(is_pair(i.cdr)){n=i.cdr.car;o=i.cdr.cdr}log({first:r,second:n,rest_second:o});if(!t&&is_pair(r)&&LSymbol.is(r.car,I)){return $(r.cdr,{disabled:true})}if(n&&LSymbol.is(n,I)&&!t){log(">> 1");var u=O["..."].symbols;var s=Object.values(u);if(s.length&&s.every(function(e){return e===null})){log(">>> 1 (a)");return $(o,{disabled:t})}var c=T(u);var l=r instanceof LSymbol&&LSymbol.is(o.car,I);if(is_pair(r)||l){log(">>> 1 (b)");if(is_nil(O["..."].lists[0])){if(!l){return $(o,{disabled:t})}log(o);return _nil}var f=r;if(l){log(">>> 1 (c)");f=new Pair(r,new Pair(n,_nil))}log(">> 2");var _;if(c.length){log(">> 2 (a)");var p=_objectSpread({},u);_=a?[]:_nil;var h=function e(){log({bind:p});if(!R(p)){return 1}var n={};var t=function e(t,r){n[t]=r};var r=j(f,p,{nested:true},t);if(r!==undefined){if(l){if(a){if(Array.isArray(r)){var i;(i=_).push.apply(i,_toConsumableArray(r))}else{log("ZONK {1}")}}else{if(is_nil(_)){_=r}else{_=_.append(r)}}}else if(a){_.push(r)}else{_=new Pair(r,_)}}p=n};while(true){if(h())break}if(!is_nil(_)&&!l&&!a){_=_.reverse()}if(a){if(o){log({rest_second:o,expr:i});var d=$(o,{disabled:t});return _.concat(d)}return _}if(!is_nil(i.cdr.cdr)&&!LSymbol.is(i.cdr.cdr.car,I)){var m=$(i.cdr.cdr,{disabled:t});return _.append(m)}return _}else{log(">> 3");var y=j(r,u,{nested:true});if(y){return new Pair(y,_nil)}return _nil}}else if(r instanceof LSymbol){log(">> 4");if(LSymbol.is(o.car,I)){log(">> 4 (a)")}else{log(">> 4 (b)")}var v=r.__name__;var g=_defineProperty({},v,u[v]);log({bind:g});var b=u[v]===null;var w=a?[]:_nil;var D=function e(){if(!R(g,true)){log({bind:g});return 1}var n={};var t=function e(t,r){n[t]=r};var r=j(i,g,{nested:false},t);log({value:r});if(typeof r!=="undefined"){if(a){w.push(r)}else{w=new Pair(r,w)}}g=n};while(true){if(D())break}if(!is_nil(w)&&!a){w=w.reverse()}if(is_pair(i.cdr)){if(is_pair(i.cdr.cdr)||i.cdr.cdr instanceof LSymbol){var x=$(i.cdr.cdr,{disabled:t});log({node:x});if(b){return x}if(is_nil(w)){w=x}else{w.append(x)}log({result:w,node:x})}}log("<<<< 2");return w}}var E=$(r,{disabled:t});var L;var A;if(r instanceof LSymbol){var S=P.get(r,{throwError:false});A=S instanceof Macro&&S.__name__==="syntax-rules"}if(A){if(i.cdr.car instanceof LSymbol){L=new Pair($(i.cdr.car,{disabled:t}),new Pair(i.cdr.cdr.car,$(i.cdr.cdr.cdr,{disabled:t})))}else{L=new Pair(i.cdr.car,$(i.cdr.cdr,{disabled:t}))}log("REST >>>> ",L)}else{L=$(i.cdr,{disabled:t})}log({a:true,car:toString(i.car),cdr:toString(i.cdr),head:toString(E),rest:toString(L)});return new Pair(E,L)}if(i instanceof LSymbol){if(t&&LSymbol.is(i,I)){return i}var F=Object.keys(O["..."].symbols);var k=i.literal();if(F.includes(k)){var C="missing ellipsis symbol next to name `".concat(k,"'");throw new Error("syntax-rules: ".concat(C))}var B=N(i);if(typeof B!=="undefined"){return B}}return i}return $(t,{})}function is_null(e){return is_undef(e)||is_nil(e)||e===null}function is_nil(e){return e===_nil}function is_function(e){return typeof e==="function"&&typeof e.bind==="function"}function is_continuation(e){return e instanceof Continuation}function is_context(e){return e instanceof LambdaContext}function is_parameter(e){return e instanceof Parameter}function is_pair(e){return e instanceof Pair}function is_env(e){return e instanceof Environment}function is_callable(e){return is_function(e)||is_continuation(e)||is_parameter(e)||is_macro(e)}function is_macro(e){return e instanceof Macro||e instanceof SyntaxParameter}function is_promise(e){if(e instanceof QuotedPromise){return false}if(e instanceof Promise){return true}return!!e&&is_function(e.then)}function is_undef(e){return typeof e==="undefined"}function is_iterator(e,t){if(has_own_symbol(e,t)||has_own_symbol(e.__proto__,t)){return is_function(e[t])}}function is_instance(e){if(!e){return false}if(_typeof$1(e)!=="object"){return false}if(e.__instance__){e.__instance__=false;return e.__instance__}return false}function self_evaluated(e){var t=_typeof$1(e);return["string","function"].includes(t)||_typeof$1(e)==="symbol"||e instanceof QuotedPromise||e instanceof LSymbol||e instanceof LNumber||e instanceof LString||e instanceof RegExp}function is_native(e){return e instanceof LNumber||e instanceof LString||e instanceof LCharacter}function has_own_symbol(e,t){if(e===null){return false}return _typeof$1(e)==="object"&&t in Object.getOwnPropertySymbols(e)}function box(e){switch(_typeof$1(e)){case"string":return LString(e);case"bigint":return LNumber(e);case"number":if(Number.isNaN(e)){return nan}else{return LNumber(e)}}return e}function map_object(r,n){var e=Object.getOwnPropertyNames(r);var t=Object.getOwnPropertySymbols(r);var i={};e.concat(t).forEach(function(e){var t=n(r[e]);i[e]=t});return i}function unbox(t){var e=[LString,LNumber].some(function(e){return t instanceof e});if(e){return t.valueOf()}if(t instanceof Array){return t.map(unbox)}if(t instanceof QuotedPromise){delete t.then}if(is_plain_object(t)){return map_object(t,unbox)}return t}function patch_value(e,t){if(is_pair(e)){e.markCycles();return quote(e)}if(is_function(e)){if(t){return bind(e,t)}}return box(e)}function unbind(e){if(is_bound(e)){return e[__fn__]}return e}function bind(e,t){if(e[Symbol["for"]("__bound__")]){return e}var r=e.bind(t);var n=Object.getOwnPropertyNames(e);var i=_createForOfIteratorHelper(n),a;try{for(i.s();!(a=i.n()).done;){var o=a.value;if(filter_fn_names(o)){try{r[o]=e[o]}catch(e){}}}}catch(e){i.e(e)}finally{i.f()}hidden_prop(r,"__fn__",e);hidden_prop(r,"__context__",t);hidden_prop(r,"__bound__",true);if(is_native_function(e)){hidden_prop(r,"__native__",true)}if(is_plain_object(t)&&is_lambda(e)){hidden_prop(r,"__method__",true)}r.valueOf=function(){return e};return r}function is_object_bound(e){return is_bound(e)&&e[Symbol["for"]("__context__")]===Object}function is_bound(e){return!!(is_function(e)&&e[__fn__])}function lips_context(e){if(is_function(e)){var t=e[__context__];if(t&&(t===lips||t.constructor&&t.constructor.__class__)){return true}}return false}function is_port(e){return e instanceof InputPort||e instanceof OutputPort}function is_port_method(e){if(is_function(e)){if(is_port(e[__context__])){return true}}return false}var __context__=Symbol["for"]("__context__");var __fn__=Symbol["for"]("__fn__");var __data__=Symbol["for"]("__data__");var __ref__=Symbol["for"]("__ref__");var __cycles__=Symbol["for"]("__cycles__");var __class__=Symbol["for"]("__class__");var __method__=Symbol["for"]("__method__");var __prototype__=Symbol["for"]("__prototype__");var __lambda__=Symbol["for"]("__lambda__");var exluded_names=["name","length","caller","callee","arguments","prototype"];function filter_fn_names(e){return!exluded_names.includes(e)}function hidden_prop(e,t,r){Object.defineProperty(e,Symbol["for"](t),{get:function e(){return r},set:function e(){},configurable:false,enumerable:false})}function set_fn_length(t,r){try{Object.defineProperty(t,"length",{get:function e(){return r}});return t}catch(e){var n=new Array(r).fill(0).map(function(e,t){return"a"+t}).join(",");var i=new Function("f","return function(".concat(n,") {\n return f.apply(this, arguments);\n };"));return i(t)}}function is_lambda(e){return e&&e[__lambda__]}function is_method(e){return e&&e[__method__]}function is_raw_lambda(e){return is_lambda(e)&&!e[__prototype__]&&!is_method(e)&&!is_port_method(e)}function is_native_function(e){var t=Symbol["for"]("__native__");return is_function(e)&&e.toString().match(/\{\s*\[native code\]\s*\}/)&&(e.name.match(/^bound /)&&e[t]===true||!e.name.match(/^bound /)&&!e[t])}function let_macro(e){var b;switch(e){case Symbol["for"]("letrec"):b="letrec";break;case Symbol["for"]("let"):b="let";break;case Symbol["for"]("let*"):b="let*";break;default:throw new Error("Invalid let_macro value")}return Macro.defmacro(b,function(t,e){var l=e.dynamic_env;var f=e.error,r=e.macro_expand,_=e.use_dynamic;var p;if(t.car instanceof LSymbol){if(!(is_pair(t.cdr.car)||is_nil(t.cdr.car))){throw new Error("let require list of pairs")}var n;if(is_nil(t.cdr.car)){p=_nil;n=_nil}else{n=t.cdr.car.map(function(e){return e.car});p=t.cdr.car.map(function(e){return e.cdr.car})}return Pair.fromArray([LSymbol("letrec"),[[t.car,Pair(LSymbol("lambda"),Pair(n,t.cdr.cdr))]],Pair(t.car,p)])}else if(r){return}var h=this;p=global_env.get("list->array")(t.car);var d=h.inherit(b);var m,y;if(b==="let*"){y=d}else if(b==="let"){m=[]}var v=0;function g(){var e=new Pair(new LSymbol("begin"),t.cdr);return _evaluate(e,{env:d,dynamic_env:d,use_dynamic:_,error:f})}return function t(){var r=p[v++];l=b==="let*"?d:h;if(!r){if(m&&m.length){var e=m.map(function(e){return e.value});var n=e.filter(is_promise);if(n.length){return promise_all(e).then(function(e){for(var t=0,r=e.length;t1&&arguments[1]!==undefined?arguments[1]:{},r=t.use_dynamic,n=t.error;var i=this;var a=this;var o=[];var u=e;while(is_pair(u)){o.push(_evaluate(u.car,{env:i,dynamic_env:a,use_dynamic:r,error:n}));u=u.cdr}var s=o.filter(is_promise).length;if(s){return promise_all(o).then(c.bind(this))}else{return c.call(this,o)}})}function guard_math_call(e){for(var t=arguments.length,r=new Array(t>1?t-1:0),n=1;n2?n-2:0),a=2;a1&&arguments[1]!==undefined?arguments[1]:null;return function(){for(var e=arguments.length,t=new Array(e),r=0;r1?e-1:0),r=1;r=o){return a.apply(this,n)}else{return i}}return i.apply(this,arguments)}}function limit(n,i){typecheck("limit",i,"function",2);return function(){for(var e=arguments.length,t=new Array(e),r=0;r1){e=e.toLowerCase();if(LCharacter.__names__[e]){t=e;e=LCharacter.__names__[e]}else{throw new Error("Internal: Unknown named character")}}else{t=LCharacter.__rev_names__[e]}Object.defineProperty(this,"__char__",{value:e,enumerable:true});if(t){Object.defineProperty(this,"__name__",{value:t,enumerable:true})}}LCharacter.__names__=characters;LCharacter.__rev_names__={};Object.keys(LCharacter.__names__).forEach(function(e){var t=LCharacter.__names__[e];LCharacter.__rev_names__[t]=e});LCharacter.prototype.toUpperCase=function(){return LCharacter(this.__char__.toUpperCase())};LCharacter.prototype.toLowerCase=function(){return LCharacter(this.__char__.toLowerCase())};LCharacter.prototype.toString=function(){return"#\\"+(this.__name__||this.__char__)};LCharacter.prototype.valueOf=LCharacter.prototype.serialize=function(){return this.__char__};function LString(e){if(typeof this!=="undefined"&&!(this instanceof LString)||typeof this==="undefined"){return new LString(e)}if(e instanceof Array){this.__string__=e.map(function(e,t){typecheck("LString",e,"character",t+1);return e.toString()}).join("")}else{this.__string__=e.valueOf()}}{var ignore=["length","constructor"];var _keys=Object.getOwnPropertyNames(String.prototype).filter(function(e){return!ignore.includes(e)});var wrap=function e(n){return function(){for(var e=arguments.length,t=new Array(e),r=0;r0){r.push(this.__string__.substring(0,e))}r.push(t);if(e1&&arguments[1]!==undefined?arguments[1]:false;if(e instanceof LNumber){return e}if(typeof this!=="undefined"&&!(this instanceof LNumber)||typeof this==="undefined"){return new LNumber(e,t)}if(typeof e==="undefined"){throw new Error("Invalid LNumber constructor call")}var r=LNumber.getType(e);if(LNumber.types[r]){return LNumber.types[r](e,t)}var n=e instanceof Array&&LString.isString(e[0])&&LNumber.isNumber(e[1]);if(e instanceof LNumber){return LNumber(e.value)}if(!LNumber.isNumber(e)&&!n){throw new Error("You can't create LNumber from ".concat(type(e)))}if(e===null){e=0}var i;if(n){var a=e,o=_slicedToArray(a,2),u=o[0],s=o[1];if(u instanceof LString){u=u.valueOf()}if(s instanceof LNumber){s=s.valueOf()}var c=u.match(/^([+-])/);var l=false;if(c){u=u.replace(/^[+-]/,"");if(c[1]==="-"){l=true}}}if(Number.isNaN(e)){return LFloat(e)}else if(typeof BigInt!=="undefined"){if(typeof e!=="bigint"){if(n){var f;switch(s){case 8:f="0o";break;case 16:f="0x";break;case 2:f="0b";break;case 10:f="";break}if(typeof f==="undefined"){var _=BigInt(s);i=_toConsumableArray(u).map(function(e,t){return BigInt(parseInt(e,s))*pow(_,BigInt(t))}).reduce(function(e,t){return e+t})}else{i=BigInt(f+u)}}else{i=BigInt(e)}if(l){i*=BigInt(-1)}}else{i=e}return LBigInteger(i,true)}else if(typeof BN!=="undefined"&&!(e instanceof BN)){if(e instanceof Array){return LBigInteger(_construct(BN,_toConsumableArray(e)))}return LBigInteger(new BN(e))}else if(n){this.constant(parseInt(u,s),"integer")}else{this.constant(e,"integer")}}LNumber.prototype.constant=function(e,t){Object.defineProperty(this,"__value__",{value:e,enumerable:true});Object.defineProperty(this,"__type__",{value:t,enumerable:true})};LNumber.types={float:function e(t){return new LFloat(t)},complex:function e(t){var r=arguments.length>1&&arguments[1]!==undefined?arguments[1]:false;if(!LNumber.isComplex(t)){t={im:0,re:t}}return new LComplex(t,r)},rational:function e(t){var r=arguments.length>1&&arguments[1]!==undefined?arguments[1]:false;if(!LNumber.isRational(t)){t={num:t,denom:1}}return new LRational(t,r)}};LNumber.prototype.serialize=function(){return this.__value__};LNumber.prototype.isNaN=function(){return Number.isNaN(this.__value__)};LNumber.prototype.gcd=function(e){var t=this.abs();e=e.abs();if(e.cmp(t)===1){var r=t;t=e;e=r}while(true){t=t.rem(e);if(t.cmp(0)===0){return e}e=e.rem(t);if(e.cmp(0)===0){return t}}};LNumber.isFloat=function e(t){return t instanceof LFloat||Number(t)===t&&t%1!==0};LNumber.isNumber=function(e){return e instanceof LNumber||LNumber.isNative(e)||LNumber.isBN(e)};LNumber.isComplex=function(e){if(!e){return false}var t=e instanceof LComplex||(LNumber.isNumber(e.im)||LNumber.isRational(e.im)||Number.isNaN(e.im))&&(LNumber.isNumber(e.re)||LNumber.isRational(e.re)||Number.isNaN(e.re));return t};LNumber.isRational=function(e){if(!e){return false}return e instanceof LRational||LNumber.isNumber(e.num)&&LNumber.isNumber(e.denom)};LNumber.isInteger=function(e){if(!(LNumber.isNative(e)||e instanceof LNumber)){return false}if(LNumber.isFloat(e)){return false}if(LNumber.isRational(e)){return false}if(LNumber.isComplex(e)){return false}return true};LNumber.isNative=function(e){return typeof e==="bigint"||typeof e==="number"};LNumber.isBigInteger=function(e){return e instanceof LBigInteger||typeof e==="bigint"||LNumber.isBN(e)};LNumber.isBN=function(e){return typeof BN!=="undefined"&&e instanceof BN};LNumber.getArgsType=function(e,t){if(e instanceof LFloat||t instanceof LFloat){return LFloat}if(e instanceof LBigInteger||t instanceof LBigInteger){return LBigInteger}return LNumber};LNumber.prototype.toString=function(e){if(Number.isNaN(this.__value__)){return"+nan.0"}if(e>=2&&e<36){return this.__value__.toString(e)}return this.__value__.toString()};LNumber.prototype.asType=function(e){var t=LNumber.getType(this);return LNumber.types[t]?LNumber.types[t](e):LNumber(e)};LNumber.prototype.isBigNumber=function(){return typeof this.__value__==="bigint"||typeof BN!=="undefined"&&!(this.value instanceof BN)};["floor","ceil","round"].forEach(function(e){LNumber.prototype[e]=function(){if(this["float"]||LNumber.isFloat(this.__value__)){return LNumber(Math[e](this.__value__))}else{return LNumber(Math[e](this.valueOf()))}}});LNumber.prototype.valueOf=function(){if(LNumber.isNative(this.__value__)){return Number(this.__value__)}else if(LNumber.isBN(this.__value__)){return this.__value__.toNumber()}};var matrix=function(){var e=function e(t,r){return[t,r]};return{bigint:{bigint:e,float:function e(t,r){return[LFloat(t.valueOf()),r]},rational:function e(t,r){return[{num:t,denom:1},r]},complex:function e(t,r){return[{im:0,re:t},r]}},integer:{integer:e,float:function e(t,r){return[LFloat(t.valueOf()),r]},rational:function e(t,r){return[{num:t,denom:1},r]},complex:function e(t,r){return[{im:0,re:t},r]}},float:{bigint:function e(t,r){return[t,r&&LFloat(r.valueOf())]},integer:function e(t,r){return[t,r&&LFloat(r.valueOf())]},float:e,rational:function e(t,r){return[t,r&&LFloat(r.valueOf())]},complex:function e(t,r){return[{re:t,im:LFloat(0)},r]}},complex:{bigint:t("bigint"),integer:t("integer"),float:t("float"),rational:t("rational"),complex:function e(t,r){var n=LNumber.coerce(t.__re__,r.__re__),i=_slicedToArray(n,2),a=i[0],o=i[1];var u=LNumber.coerce(t.__im__,r.__im__),s=_slicedToArray(u,2),c=s[0],l=s[1];return[{im:c,re:a},{im:l,re:o}]}},rational:{bigint:function e(t,r){return[t,r&&{num:r,denom:1}]},integer:function e(t,r){return[t,r&&{num:r,denom:1}]},float:function e(t,r){return[LFloat(t.valueOf()),r]},rational:e,complex:function e(t,r){return[{im:coerce(t.__type__,r.__im__.__type__,0)[0],re:coerce(t.__type__,r.__re__.__type__,t)[0]},{im:coerce(t.__type__,r.__im__.__type__,r.__im__)[0],re:coerce(t.__type__,r.__re__.__type__,r.__re__)[0]}]}}};function t(r){return function(e,t){return[{im:coerce(r,e.__im__.__type__,0,e.__im__)[1],re:coerce(r,e.__re__.__type__,0,e.__re__)[1]},{im:coerce(r,e.__im__.__type__,0,0)[1],re:coerce(r,t.__type__,0,t)[1]}]}}}();function coerce(e,t,r,n){return matrix[e][t](r,n)}LNumber.coerce=function(e,t){var r=LNumber.getType(e);var n=LNumber.getType(t);if(!matrix[r]){throw new Error("LNumber::coerce unknown lhs type ".concat(r))}else if(!matrix[r][n]){throw new Error("LNumber::coerce unknown rhs type ".concat(n))}var i=matrix[r][n](e,t);return i.map(function(e){return LNumber(e,true)})};LNumber.prototype.coerce=function(e){if(!(typeof e==="number"||e instanceof LNumber)){throw new Error("LNumber: you can't coerce ".concat(type(e)))}if(typeof e==="number"){e=LNumber(e)}return LNumber.coerce(this,e)};LNumber.getType=function(e){if(e instanceof LNumber){return e.__type__}if(LNumber.isFloat(e)){return"float"}if(LNumber.isComplex(e)){return"complex"}if(LNumber.isRational(e)){return"rational"}if(typeof e==="number"){return"integer"}if(typeof BigInt!=="undefined"&&typeof e!=="bigint"||typeof BN!=="undefined"&&!(e instanceof BN)){return"bigint"}};LNumber.prototype.isFloat=function(){return!!(LNumber.isFloat(this.__value__)||this["float"])};var mapping={add:"+",sub:"-",mul:"*",div:"/",rem:"%",or:"|",and:"&",neg:"~",shl:">>",shr:"<<"};var rev_mapping={};Object.keys(mapping).forEach(function(t){rev_mapping[mapping[t]]=t;LNumber.prototype[t]=function(e){return this.op(mapping[t],e)}});LNumber._ops={"*":function e(t,r){return t*r},"+":function e(t,r){return t+r},"-":function e(t,r){if(typeof r==="undefined"){return-t}return t-r},"/":function e(t,r){return t/r},"%":function e(t,r){return t%r},"|":function e(t,r){return t|r},"&":function e(t,r){return t&r},"~":function e(t){return~t},">>":function e(t,r){return t>>r},"<<":function e(t,r){return t<1&&arguments[1]!==undefined?arguments[1]:false;if(typeof this!=="undefined"&&!(this instanceof LComplex)||typeof this==="undefined"){return new LComplex(e,t)}if(e instanceof LComplex){return LComplex({im:e.__im__,re:e.__re__})}if(LNumber.isNumber(e)&&t){if(!t){return Number(e)}}else if(!LNumber.isComplex(e)){var r="Invalid constructor call for LComplex expect &(:im :re ) object but got ".concat(toString(e));throw new Error(r)}var n=e.im instanceof LNumber?e.im:LNumber(e.im);var i=e.re instanceof LNumber?e.re:LNumber(e.re);this.constant(n,i)}LComplex.prototype=Object.create(LNumber.prototype);LComplex.prototype.constructor=LComplex;LComplex.prototype.constant=function(e,t){Object.defineProperty(this,"__im__",{value:e,enumerable:true});Object.defineProperty(this,"__re__",{value:t,enumerable:true});Object.defineProperty(this,"__type__",{value:"complex",enumerable:true})};LComplex.prototype.serialize=function(){return{re:this.__re__,im:this.__im__}};LComplex.prototype.toRational=function(e){if(LNumber.isFloat(this.__im__)&&LNumber.isFloat(this.__re__)){var t=LFloat(this.__im__).toRational(e);var r=LFloat(this.__re__).toRational(e);return LComplex({im:t,re:r})}return this};LComplex.prototype.pow=function(e){e.cmp(0);if(e===0){return LNumber(1)}var t=LNumber(Math.atan2(this.__im__.valueOf(),this.__re__.valueOf()));var r=LNumber(this.modulus());if(LNumber.isComplex(e)&&e.__im__.cmp(0)!==0){var n=e.mul(Math.log(r.valueOf())).add(LComplex.i.mul(t).mul(e));var i=LFloat(Math.E).pow(n.__re__.valueOf());return LComplex({re:i.mul(Math.cos(n.__im__.valueOf())),im:i.mul(Math.sin(n.__im__.valueOf()))})}var a=e.__re__.cmp(0)>0;e=e.__re__.valueOf();if(LNumber.isInteger(e)&&a){var o=this;while(--e){o=o.mul(this)}return o}var u=r.pow(e);var s=t.mul(e);return LComplex({re:u.mul(Math.cos(s)),im:u.mul(Math.sin(s))})};LComplex.prototype.add=function(e){return this.complex_op("add",e,function(e,t,r,n){return{re:e.add(t),im:r.add(n)}})};LComplex.prototype.factor=function(){if(this.__im__ instanceof LFloat||this.__im__ instanceof LFloat){var e=this.__re__,t=this.__im__;var r,n;if(e instanceof LFloat){r=e.toRational().mul(e.toRational())}else{r=e.mul(e)}if(t instanceof LFloat){n=t.toRational().mul(t.toRational())}else{n=t.mul(t)}return r.add(n)}else{return this.__re__.mul(this.__re__).add(this.__im__.mul(this.__im__))}};LComplex.prototype.modulus=function(){return this.factor().sqrt()};LComplex.prototype.conjugate=function(){return LComplex({re:this.__re__,im:this.__im__.sub()})};LComplex.prototype.sqrt=function(){var e=this.modulus();var t,r;if(e.cmp(0)===0){t=r=e}else if(this.__re__.cmp(0)===1){t=LFloat(.5).mul(e.add(this.__re__)).sqrt();r=this.__im__.div(t).div(2)}else{r=LFloat(.5).mul(e.sub(this.__re__)).sqrt();if(this.__im__.cmp(0)===-1){r=r.sub()}t=this.__im__.div(r).div(2)}return LComplex({im:r,re:t})};LComplex.prototype.div=function(e){if(LNumber.isNumber(e)&&!LNumber.isComplex(e)){if(!(e instanceof LNumber)){e=LNumber(e)}var t=this.__re__.div(e);var r=this.__im__.div(e);return LComplex({re:t,im:r})}else if(!LNumber.isComplex(e)){throw new Error("[LComplex::div] Invalid value")}if(this.cmp(e)===0){var n=this.coerce(e),i=_slicedToArray(n,2),a=i[0],o=i[1];var u=a.__im__.div(o.__im__);return u.coerce(o.__re__)[0]}var s=this.coerce(e),c=_slicedToArray(s,2),l=c[0],f=c[1];var _=f.factor();var p=f.conjugate();var h=l.mul(p);if(!LNumber.isComplex(h)){return h.div(_)}var d=h.__re__.op("/",_);var m=h.__im__.op("/",_);return LComplex({re:d,im:m})};LComplex.prototype.sub=function(e){return this.complex_op("sub",e,function(e,t,r,n){return{re:e.sub(t),im:r.sub(n)}})};LComplex.prototype.mul=function(e){return this.complex_op("mul",e,function(e,t,r,n){var i={re:e.mul(t).sub(r.mul(n)),im:e.mul(n).add(t.mul(r))};return i})};LComplex.prototype.complex_op=function(e,t,i){var a=this;var r=function e(t,r){var n=i(a.__re__,t,a.__im__,r);if("im"in n&&"re"in n){if(n.im.cmp(0)===0){return n.re}return LComplex(n,true)}return n};if(typeof t==="undefined"){return r()}if(LNumber.isNumber(t)&&!LNumber.isComplex(t)){if(!(t instanceof LNumber)){t=LNumber(t)}var n=t.asType(0);t={__im__:n,__re__:t}}else if(!LNumber.isComplex(t)){throw new Error("[LComplex::".concat(e,"] Invalid value"))}var o=t.__re__ instanceof LNumber?t.__re__:this.__re__.asType(t.__re__);var u=t.__im__ instanceof LNumber?t.__im__:this.__im__.asType(t.__im__);return r(o,u)};LComplex._op={"+":"add","-":"sub","*":"mul","/":"div"};LComplex.prototype._op=function(e,t){var r=LComplex._op[e];return this[r](t)};LComplex.prototype.cmp=function(e){var t=this.coerce(e),r=_slicedToArray(t,2),n=r[0],i=r[1];var a=n.__re__.coerce(i.__re__),o=_slicedToArray(a,2),u=o[0],s=o[1];var c=u.cmp(s);if(c!==0){return c}else{var l=n.__im__.coerce(i.__im__),f=_slicedToArray(l,2),_=f[0],p=f[1];return _.cmp(p)}};LComplex.prototype.valueOf=function(){return[this.__re__,this.__im__].map(function(e){return e.valueOf()})};LComplex.prototype.toString=function(){var e;if(this.__re__.cmp(0)!==0){e=[toString(this.__re__)]}else{e=[]}var t=this.__im__.valueOf();var r=[Number.NEGATIVE_INFINITY,Number.POSITIVE_INFINITY].includes(t);var n=toString(this.__im__);if(!r&&!Number.isNaN(t)){var i=this.__im__.cmp(0);if(i<0||i===0&&this.__im__._minus){e.push("-")}else{e.push("+")}n=n.replace(/^-/,"")}e.push(n);e.push("i");return e.join("")};function LFloat(e){if(typeof this!=="undefined"&&!(this instanceof LFloat)||typeof this==="undefined"){return new LFloat(e)}if(!LNumber.isNumber(e)){throw new Error("Invalid constructor call for LFloat")}if(e instanceof LNumber){return LFloat(e.valueOf())}if(typeof e==="number"){if(Object.is(e,-0)){Object.defineProperty(this,"_minus",{value:true})}this.constant(e,"float")}}LFloat.prototype=Object.create(LNumber.prototype);LFloat.prototype.constructor=LFloat;LFloat.prototype.toString=function(){if(this.__value__===Number.NEGATIVE_INFINITY){return"-inf.0"}if(this.__value__===Number.POSITIVE_INFINITY){return"+inf.0"}if(Number.isNaN(this.__value__)){return"+nan.0"}var e=this.__value__.toString();if(!e.match(/e/i)){var t=this.__value__.toString().replace(/^-/,"");var r=this.__value__<0?"-":"";if(e.match(/^-?0\.0{3}/)){var n=t.match(/^[.0]+/g)[0].length-1;var i=t.replace(/^[.0]+/,"").replace(/^([0-9])/,"$1.");return"".concat(r).concat(i,"e-").concat(n)}if(e.match(/^-?[0-9]{7,}\.?/)){var a=t.match(/^[0-9]+/g)[0].length-1;var o=t.replace(/\./,"").replace(/^([0-9])/,"$1.").replace(/0+$/,"").replace(/\.$/,".0");return"".concat(r).concat(o,"e").concat(a)}if(!LNumber.isFloat(this.__value__)){var u=e+".0";return this._minus?"-"+u:u}}return e.replace(/^([0-9]+)e/,"$1.0e")};LFloat.prototype._op=function(e,t){if(t instanceof LNumber){t=t.__value__}var r=LNumber._ops[e];if(e==="/"&&this.__value__===0&&t===0){return NaN}return LFloat(r(this.__value__,t))};LFloat.prototype.toRational=function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:null;if(e===null){return toRational(this.__value__.valueOf())}return approxRatio(e.valueOf())(this.__value__.valueOf())};LFloat.prototype.sqrt=function(){var e=this.valueOf();if(this.cmp(0)<0){var t=LFloat(Math.sqrt(-e));return LComplex({re:0,im:t})}return LFloat(Math.sqrt(e))};LFloat.prototype.abs=function(){var e=this.valueOf();if(e<0){e=-e}return LFloat(e)};var toRational=approxRatio(1e-10);function approxRatio(n){return function(e){var t=function e(n,t,r){var i=function e(t,r){return r0){i=simplest_rational2(n,r)}else if(n.cmp(r)<=0){i=r}else if(r.cmp(0)>0){i=simplest_rational2(r,n)}else if(t.cmp(0)<0){i=LNumber(simplest_rational2(n.sub(),r.sub())).sub()}else{i=LNumber(0)}if(LNumber.isFloat(t)||LNumber.isFloat(e)){return LFloat(i)}return i}function simplest_rational2(e,t){var r=LNumber(e).floor();var n=LNumber(t).floor();if(e.cmp(r)<1){return r}else if(r.cmp(n)===0){var i=LNumber(1).div(t.sub(n));var a=LNumber(1).div(e.sub(r));return r.add(LNumber(1).div(simplest_rational2(i,a)))}else{return r.add(LNumber(1))}}function LRational(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:false;if(typeof this!=="undefined"&&!(this instanceof LRational)||typeof this==="undefined"){return new LRational(e,t)}if(!LNumber.isRational(e)){throw new Error("Invalid constructor call for LRational")}var r,n;if(e instanceof LRational){r=LNumber(e.__num__);n=LNumber(e.__denom__)}else{r=LNumber(e.num);n=LNumber(e.denom)}if(!t&&n.cmp(0)!==0){var i=r.op("%",n).cmp(0)===0;if(i){return LNumber(r.div(n))}}this.constant(r,n)}LRational.prototype=Object.create(LNumber.prototype);LRational.prototype.constructor=LRational;LRational.prototype.constant=function(e,t){Object.defineProperty(this,"__num__",{value:e,enumerable:true});Object.defineProperty(this,"__denom__",{value:t,enumerable:true});Object.defineProperty(this,"__type__",{value:"rational",enumerable:true})};LRational.prototype.serialize=function(){return{num:this.__num__,denom:this.__denom__}};LRational.prototype.pow=function(e){if(LNumber.isRational(e)){return pow(this.valueOf(),e.valueOf())}var t=e.cmp(0);if(t===0){return LNumber(1)}if(t===-1){e=e.sub();var r=this.__denom__.pow(e);var n=this.__num__.pow(e);return LRational({num:r,denom:n})}var i=this;e=e.valueOf();while(e>1){i=i.mul(this);e--}return i};LRational.prototype.sqrt=function(){var e=this.__num__.sqrt();var t=this.__denom__.sqrt();if(e instanceof LFloat||t instanceof LFloat){return e.div(t)}return LRational({num:e,denom:t})};LRational.prototype.abs=function(){var e=this.__num__;var t=this.__denom__;if(e.cmp(0)===-1){e=e.sub()}if(t.cmp(0)!==1){t=t.sub()}return LRational({num:e,denom:t})};LRational.prototype.cmp=function(e){return LNumber(this.valueOf(),true).cmp(e)};LRational.prototype.toString=function(){var e=this.__num__.gcd(this.__denom__);var t,r;if(e.cmp(1)!==0){t=this.__num__.div(e);if(t instanceof LRational){t=LNumber(t.valueOf(true))}r=this.__denom__.div(e);if(r instanceof LRational){r=LNumber(r.valueOf(true))}}else{t=this.__num__;r=this.__denom__}var n=this.cmp(0)<0;if(n){if(t.abs().cmp(r.abs())===0){return t.toString()}}else if(t.cmp(r)===0){return t.toString()}return t.toString()+"/"+r.toString()};LRational.prototype.valueOf=function(e){if(this.__denom__.cmp(0)===0){if(this.__num__.cmp(0)<0){return Number.NEGATIVE_INFINITY}return Number.POSITIVE_INFINITY}if(e){return LNumber._ops["/"](this.__num__.value,this.__denom__.value)}return LFloat(this.__num__.valueOf()).div(this.__denom__.valueOf())};LRational.prototype.mul=function(e){if(!(e instanceof LNumber)){e=LNumber(e)}if(LNumber.isRational(e)){var t=this.__num__.mul(e.__num__);var r=this.__denom__.mul(e.__denom__);return LRational({num:t,denom:r})}var n=LNumber.coerce(this,e),i=_slicedToArray(n,2),a=i[0],o=i[1];return a.mul(o)};LRational.prototype.div=function(e){if(!(e instanceof LNumber)){e=LNumber(e)}if(LNumber.isRational(e)){var t=this.__num__.mul(e.__denom__);var r=this.__denom__.mul(e.__num__);return LRational({num:t,denom:r})}var n=LNumber.coerce(this,e),i=_slicedToArray(n,2),a=i[0],o=i[1];var u=a.div(o);return u};LRational.prototype._op=function(e,t){return this[rev_mapping[e]](t)};LRational.prototype.sub=function(e){if(typeof e==="undefined"){return this.mul(-1)}if(!(e instanceof LNumber)){e=LNumber(e)}if(LNumber.isRational(e)){var t=e.__num__.sub();var r=e.__denom__;return this.add(LRational({num:t,denom:r}))}if(!(e instanceof LNumber)){e=LNumber(e).sub()}else{e=e.sub()}var n=LNumber.coerce(this,e),i=_slicedToArray(n,2),a=i[0],o=i[1];return a.add(o)};LRational.prototype.add=function(e){if(!(e instanceof LNumber)){e=LNumber(e)}if(LNumber.isRational(e)){var t=this.__denom__;var r=e.__denom__;var n=this.__num__;var i=e.__num__;var a,o;if(t!==r){o=r.mul(n).add(i.mul(t));a=t.mul(r)}else{o=n.add(i);a=t}return LRational({num:o,denom:a})}if(LNumber.isFloat(e)){return LFloat(this.valueOf()).add(e)}var u=LNumber.coerce(this,e),s=_slicedToArray(u,2),c=s[0],l=s[1];return c.add(l)};function LBigInteger(e,t){if(typeof this!=="undefined"&&!(this instanceof LBigInteger)||typeof this==="undefined"){return new LBigInteger(e,t)}if(e instanceof LBigInteger){return LBigInteger(e.__value__,e._native)}if(!LNumber.isBigInteger(e)){throw new Error("Invalid constructor call for LBigInteger")}this.constant(e,"bigint");Object.defineProperty(this,"_native",{value:t})}LBigInteger.prototype=Object.create(LNumber.prototype);LBigInteger.prototype.constructor=LBigInteger;LBigInteger.bn_op={"+":"iadd","-":"isub","*":"imul","/":"idiv","%":"imod","|":"ior","&":"iand","~":"inot","<<":"ishrn",">>":"ishln"};LBigInteger.prototype.serialize=function(){return this.__value__.toString()};LBigInteger.prototype._op=function(e,t){if(typeof t==="undefined"){if(LNumber.isBN(this.__value__)){e=LBigInteger.bn_op[e];return LBigInteger(this.__value__.clone()[e](),false)}return LBigInteger(LNumber._ops[e](this.__value__),true)}if(LNumber.isBN(this.__value__)&&LNumber.isBN(t.__value__)){e=LBigInteger.bn_op[e];return LBigInteger(this.__value__.clone()[e](t),false)}var r=LNumber._ops[e](this.__value__,t.__value__);if(e==="/"){var n=this.op("%",t).cmp(0)===0;if(n){return LNumber(r)}return LRational({num:this,denom:t})}return LBigInteger(r,true)};LBigInteger.prototype.sqrt=function(){var e;var t=this.cmp(0)<0;if(LNumber.isNative(this.__value__)){e=LNumber(Math.sqrt(t?-this.valueOf():this.valueOf()))}else if(LNumber.isBN(this.__value__)){e=t?this.__value__.neg().sqrt():this.__value__.sqrt()}if(t){return LComplex({re:0,im:e})}return e};LNumber.NaN=LNumber(NaN);LComplex.i=LComplex({im:1,re:0});function InputPort(e){var n=this;if(typeof this!=="undefined"&&!(this instanceof InputPort)||typeof this==="undefined"){return new InputPort(e)}typecheck("InputPort",e,"function");read_only(this,"__type__",text_port);var i;Object.defineProperty(this,"__parser__",{enumerable:true,get:function e(){return i},set:function e(t){typecheck("InputPort::__parser__",t,"parser");i=t}});this._read=e;this._with_parser=this._with_init_parser.bind(this,_asyncToGenerator(_regeneratorRuntime.mark(function e(){var r;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(n.char_ready()){t.next=5;break}t.next=3;return n._read();case 3:r=t.sent;i=new Parser(r,{env:n});case 5:return t.abrupt("return",n.__parser__);case 6:case"end":return t.stop()}},e)})));this.char_ready=function(){return!!this.__parser__&&this.__parser__.__lexer__.peek()!==eof};this._make_defaults()}InputPort.prototype._make_defaults=function(){this.read=this._with_parser(function(e){return e.read_object()});this.read_line=this._with_parser(function(e){return e.__lexer__.read_line()});this.read_char=this._with_parser(function(e){return e.__lexer__.read_char()});this.read_string=this._with_parser(function(e,t){if(!LNumber.isInteger(t)){var r=LNumber.getType(t);typeErrorMessage("read-string",r,"integer")}return e.__lexer__.read_string(t.valueOf())});this.peek_char=this._with_parser(function(e){return e.__lexer__.peek_char()})};InputPort.prototype._with_init_parser=function(u,s){var c=this;return _asyncToGenerator(_regeneratorRuntime.mark(function e(){var r,n,i,a,o=arguments;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:t.next=2;return u.call(c);case 2:r=t.sent;for(n=o.length,i=new Array(n),a=0;a"};function OutputPort(e){if(typeof this!=="undefined"&&!(this instanceof OutputPort)||typeof this==="undefined"){return new OutputPort(e)}typecheck("OutputPort",e,"function");read_only(this,"__type__",text_port);this.write=e}OutputPort.prototype.is_open=function(){return this._closed!==true};OutputPort.prototype.close=function(){Object.defineProperty(this,"_closed",{get:function e(){return true},set:function e(){},configurable:false,enumerable:false});this.write=function(){throw new Error("output-port: port is closed")}};OutputPort.prototype.flush=function(){};OutputPort.prototype.toString=function(){return"#"};var BufferedOutputPort=function(e){_inherits(r,e);function r(e){var t;_classCallCheck(this,r);t=_callSuper(this,r,[function(){var e;return(e=t)._write.apply(e,arguments)}]);typecheck("BufferedOutputPort",e,"function");read_only(_assertThisInitialized(t),"_fn",e,{hidden:true});read_only(_assertThisInitialized(t),"_buffer",[],{hidden:true});return t}_createClass(r,[{key:"flush",value:function e(){if(this._buffer.length){this._fn(this._buffer.join(""));this._buffer.length=0}}},{key:"_write",value:function e(){var t=this;for(var r=arguments.length,n=new Array(r),i=0;i"};OutputStringPort.prototype.valueOf=function(){return this.__buffer__.map(function(e){return e.valueOf()}).join("")};function OutputFilePort(e,t){var r=this;if(typeof this!=="undefined"&&!(this instanceof OutputFilePort)||typeof this==="undefined"){return new OutputFilePort(e,t)}typecheck("OutputFilePort",e,"string");read_only(this,"__filename__",e);read_only(this,"_fd",t.valueOf(),{hidden:true});read_only(this,"__type__",text_port);this.write=function(e){if(!LString.isString(e)){e=toString(e)}else{e=e.valueOf()}r.fs().write(r._fd,e,function(e){if(e){throw e}})}}OutputFilePort.prototype=Object.create(OutputPort.prototype);OutputFilePort.prototype.constructor=OutputFilePort;OutputFilePort.prototype.fs=function(){if(!this._fs){this._fs=this.internal("fs")}return this._fs};OutputFilePort.prototype.internal=function(e){return user_env.get("**internal-env**").get(e)};OutputFilePort.prototype.close=function(){var n=this;return new Promise(function(t,r){n.fs().close(n._fd,function(e){if(e){r(e)}else{read_only(n,"_fd",null,{hidden:true});OutputPort.prototype.close.call(n);t()}})})};OutputFilePort.prototype.toString=function(){return"#")};function InputStringPort(e,t){var r=this;if(typeof this!=="undefined"&&!(this instanceof InputStringPort)||typeof this==="undefined"){return new InputStringPort(e)}typecheck("InputStringPort",e,"string");t=t||global_env;e=e.valueOf();this._with_parser=this._with_init_parser.bind(this,function(){if(!r.__parser__){r.__parser__=new Parser(e,{env:t})}return r.__parser__});read_only(this,"__type__",text_port);this._make_defaults()}InputStringPort.prototype.char_ready=function(){return true};InputStringPort.prototype=Object.create(InputPort.prototype);InputStringPort.prototype.constructor=InputStringPort;InputStringPort.prototype.toString=function(){return"#"};function InputByteVectorPort(e){if(typeof this!=="undefined"&&!(this instanceof InputByteVectorPort)||typeof this==="undefined"){return new InputByteVectorPort(e)}typecheck("InputByteVectorPort",e,"uint8array");read_only(this,"__vector__",e);read_only(this,"__type__",binary_port);var r=0;Object.defineProperty(this,"__index__",{enumerable:true,get:function e(){return r},set:function e(t){typecheck("InputByteVectorPort::__index__",t,"number");if(t instanceof LNumber){t=t.valueOf()}if(typeof t==="bigint"){t=Number(t)}if(Math.floor(t)!==t){throw new Error("InputByteVectorPort::__index__ value is "+"not integer")}r=t}})}InputByteVectorPort.prototype=Object.create(InputPort.prototype);InputByteVectorPort.prototype.constructor=InputByteVectorPort;InputByteVectorPort.prototype.toString=function(){return"#"};InputByteVectorPort.prototype.close=function(){var t=this;read_only(this,"__vector__",_nil);var r=function e(){throw new Error("Input-binary-port: port is closed")};["read_u8","close","peek_u8","read_u8_vector"].forEach(function(e){t[e]=r});this.u8_ready=this.char_ready=function(){return false}};InputByteVectorPort.prototype.u8_ready=function(){return true};InputByteVectorPort.prototype.peek_u8=function(){if(this.__index__>=this.__vector__.length){return eof}return this.__vector__[this.__index__]};InputByteVectorPort.prototype.skip=function(){if(this.__index__<=this.__vector__.length){++this.__index__}};InputByteVectorPort.prototype.read_u8=function(){var e=this.peek_u8();this.skip();return e};InputByteVectorPort.prototype.read_u8_vector=function(e){if(typeof e==="undefined"){e=this.__vector__.length}else if(e>this.__index__+this.__vector__.length){e=this.__index__+this.__vector__.length}if(this.peek_u8()===eof){return eof}return this.__vector__.slice(this.__index__,e)};function OutputByteVectorPort(){if(typeof this!=="undefined"&&!(this instanceof OutputByteVectorPort)||typeof this==="undefined"){return new OutputByteVectorPort}read_only(this,"__type__",binary_port);read_only(this,"_buffer",[],{hidden:true});this.write=function(e){typecheck("write",e,["number","uint8array"]);if(LNumber.isNumber(e)){this._buffer.push(e.valueOf())}else{var t;(t=this._buffer).push.apply(t,_toConsumableArray(Array.from(e)))}};Object.defineProperty(this,"__buffer__",{enumerable:true,get:function e(){return Uint8Array.from(this._buffer)}})}OutputByteVectorPort.prototype=Object.create(OutputPort.prototype);OutputByteVectorPort.prototype.constructor=OutputByteVectorPort;OutputByteVectorPort.prototype.close=function(){OutputPort.prototype.close.call(this);read_only(this,"_buffer",null,{hidden:true})};OutputByteVectorPort.prototype._close_guard=function(){if(this._closed){throw new Error("output-port: binary port is closed")}};OutputByteVectorPort.prototype.write_u8=function(e){typecheck("OutputByteVectorPort::write_u8",e,"number");this.write(e)};OutputByteVectorPort.prototype.write_u8_vector=function(e){typecheck("OutputByteVectorPort::write_u8_vector",e,"uint8array");this.write(e)};OutputByteVectorPort.prototype.toString=function(){return"#"};OutputByteVectorPort.prototype.valueOf=function(){return this.__buffer__};function InputFilePort(e,t){if(typeof this!=="undefined"&&!(this instanceof InputFilePort)||typeof this==="undefined"){return new InputFilePort(e,t)}InputStringPort.call(this,e);typecheck("InputFilePort",t,"string");read_only(this,"__filename__",t)}InputFilePort.prototype=Object.create(InputStringPort.prototype);InputFilePort.prototype.constructor=InputFilePort;InputFilePort.prototype.toString=function(){return"#")};function InputBinaryFilePort(e,t){if(typeof this!=="undefined"&&!(this instanceof InputBinaryFilePort)||typeof this==="undefined"){return new InputBinaryFilePort(e,t)}InputByteVectorPort.call(this,e);typecheck("InputBinaryFilePort",t,"string");read_only(this,"__filename__",t)}InputBinaryFilePort.prototype=Object.create(InputByteVectorPort.prototype);InputBinaryFilePort.prototype.constructor=InputBinaryFilePort;InputBinaryFilePort.prototype.toString=function(){return"#")};function OutputBinaryFilePort(e,t){var i=this;if(typeof this!=="undefined"&&!(this instanceof OutputBinaryFilePort)||typeof this==="undefined"){return new OutputBinaryFilePort(e,t)}typecheck("OutputBinaryFilePort",e,"string");read_only(this,"__filename__",e);read_only(this,"_fd",t.valueOf(),{hidden:true});read_only(this,"__type__",binary_port);var a;this.write=function(e){typecheck("write",e,["number","uint8array"]);var n;if(!a){a=i.internal("fs")}if(LNumber.isNumber(e)){n=new Uint8Array([e.valueOf()])}else{n=new Uint8Array(Array.from(e))}return new Promise(function(t,r){a.write(i._fd,n,function(e){if(e){r(e)}else{t()}})})}}OutputBinaryFilePort.prototype=Object.create(OutputFilePort.prototype);OutputBinaryFilePort.prototype.constructor=OutputBinaryFilePort;OutputBinaryFilePort.prototype.write_u8=function(e){typecheck("OutputByteVectorPort::write_u8",e,"number");this.write(e)};OutputBinaryFilePort.prototype.write_u8_vector=function(e){typecheck("OutputByteVectorPort::write_u8_vector",e,"uint8array");this.write(e)};var binary_port=Symbol["for"]("binary");var text_port=Symbol["for"]("text");var eof=new EOF;function EOF(){}EOF.prototype.toString=function(){return"#"};function Interpreter(e){var t=this;var r=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},n=r.stderr,i=r.stdin,a=r.stdout,o=r.command_line,u=o===void 0?null:o,s=_objectWithoutProperties(r,_excluded3);if(typeof this!=="undefined"&&!(this instanceof Interpreter)||typeof this==="undefined"){return new Interpreter(e,_objectSpread({stdin:i,stdout:a,stderr:n,command_line:u},s))}if(typeof e==="undefined"){e="anonymous"}this.__env__=user_env.inherit(e,s);this.__env__.set("parent.frame",doc("parent.frame",function(){return t.__env__},global_env.__env__["parent.frame"].__doc__));var c="**interaction-environment-defaults**";this.set(c,get_props(s).concat(c));var l=internal_env.inherit("internal-".concat(e));if(is_port(i)){l.set("stdin",i)}if(is_port(n)){l.set("stderr",n)}if(is_port(a)){l.set("stdout",a)}l.set("command-line",u);set_interaction_env(this.__env__,l)}Interpreter.prototype.exec=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};var r=t.use_dynamic,n=r===void 0?false:r,i=t.dynamic_env,a=t.env;typecheck("Interpreter::exec",e,["string","array"],1);typecheck("Interpreter::exec",n,"boolean",2);if(!a){a=this.__env__}if(!i){i=a}global_env.set("**interaction-environment**",this.__env__);return exec(e,{env:a,dynamic_env:i,use_dynamic:n})};Interpreter.prototype.get=function(e){var t=this.__env__.get(e);if(is_function(t)){var r=new LambdaContext({env:this.__env__});return t.bind(r)}return t};Interpreter.prototype.set=function(e,t){return this.__env__.set(e,t)};Interpreter.prototype.constant=function(e,t){return this.__env__.constant(e,t)};function LipsError(e,t){this.name="LipsError";this.message=e;this.args=t;this.stack=(new Error).stack}LipsError.prototype=new Error;LipsError.prototype.constructor=LipsError;var IgnoreException=function(e){_inherits(t,e);function t(){_classCallCheck(this,t);return _callSuper(this,t,arguments)}return _createClass(t)}(_wrapNativeSuper(Error));function Environment(e,t,r){if(arguments.length===1){if(_typeof$1(arguments[0])==="object"){e=arguments[0];t=null}else if(typeof arguments[0]==="string"){e={};t=null;r=arguments[0]}}this.__docs__=new Map;this.__env__=e;this.__parent__=t;this.__name__=r||"anonymous"}Environment.prototype.list=function(){return get_props(this.__env__)};Environment.prototype.fs=function(){return this.get("**fs**")};Environment.prototype.unset=function(e){if(e instanceof LSymbol){e=e.valueOf()}if(e instanceof LString){e=e.valueOf()}delete this.__env__[e]};Environment.prototype.inherit=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};if(_typeof$1(e)==="object"){t=e}if(!e||_typeof$1(e)==="object"){e="child of "+(this.__name__||"unknown")}return new Environment(t||{},this,e)};Environment.prototype.doc=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:null;var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:false;if(e instanceof LSymbol){e=e.__name__}if(e instanceof LString){e=e.valueOf()}if(t){if(!r){t=trim_lines(t)}this.__docs__.set(e,t);return this}if(this.__docs__.has(e)){return this.__docs__.get(e)}if(this.__parent__){return this.__parent__.doc(e)}};Environment.prototype.new_frame=function(e,t){var n=this.inherit("__frame__");n.set("parent.frame",doc("parent.frame",function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:1;e=e.valueOf();var t=n.__parent__;if(!is_env(t)){return _nil}if(e<=0){return t}var r=t.get("parent.frame");return r(e-1)},global_env.__env__["parent.frame"].__doc__));t.callee=e;n.set("arguments",t);return n};Environment.prototype._lookup=function(e){if(e instanceof LSymbol){e=e.__name__}if(e instanceof LString){e=e.valueOf()}if(this.__env__.hasOwnProperty(e)){return Value(this.__env__[e])}if(this.__parent__){return this.__parent__._lookup(e)}};Environment.prototype.toString=function(){return"#"};Environment.prototype.clone=function(){var t=this;var r={};Object.keys(this.__env__).forEach(function(e){r[e]=t.__env__[e]});return new Environment(r,this.__parent__,this.__name__)};Environment.prototype.merge=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:"merge";typecheck("Environment::merge",e,"environment");return this.inherit(t,e.__env__)};function Value(e){if(typeof this!=="undefined"&&!(this instanceof Value)||typeof this==="undefined"){return new Value(e)}this.value=e}Value.isUndefined=function(e){return e instanceof Value&&typeof e.value==="undefined"};Value.prototype.valueOf=function(){return this.value};function Values(e){if(e.length){if(e.length===1){return e[0]}}if(typeof this!=="undefined"&&!(this instanceof Values)||typeof this==="undefined"){return new Values(e)}this.__values__=e}Values.prototype.toString=function(){return this.__values__.map(function(e){return toString(e)}).join("\n")};Values.prototype.valueOf=function(){return this.__values__};Environment.prototype.get=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};typecheck("Environment::get",e,["symbol","string"]);var r=t.throwError,n=r===void 0?true:r;var i=e;if(i instanceof LSymbol||i instanceof LString){i=i.valueOf()}var a=this._lookup(i);if(a instanceof Value){if(Value.isUndefined(a)){return undefined}return patch_value(a.valueOf())}var o;if(e instanceof LSymbol&&e[LSymbol.object]){o=e[LSymbol.object]}else if(typeof i==="string"){o=i.split(".").filter(Boolean)}if(o&&o.length>0){var u=o,s=_toArray(u),c=s[0],l=s.slice(1);a=this._lookup(c);if(l.length){try{if(a instanceof Value){a=a.valueOf()}else{a=get(root,c);if(is_function(a)){a=unbind(a)}}if(typeof a!=="undefined"){return get.apply(void 0,[a].concat(_toConsumableArray(l)))}}catch(e){throw e}}else if(a instanceof Value){return patch_value(a.valueOf())}a=get(root,i)}if(typeof a!=="undefined"){return a}if(n){throw new Error("Unbound variable `"+i.toString()+"'")}};Environment.prototype.set=function(e,t){var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:null;typecheck("Environment::set",e,["string","symbol"]);if(LNumber.isNumber(t)){t=LNumber(t)}if(e instanceof LSymbol){e=e.__name__}if(e instanceof LString){e=e.valueOf()}this.__env__[e]=t;if(r){this.doc(e,r,true)}return this};Environment.prototype.constant=function(t,e){var r=this;if(this.__env__.hasOwnProperty(t)){throw new Error("Environment::constant: ".concat(t," already exists"))}if(arguments.length===1&&is_plain_object(arguments[0])){var n=arguments[0];Object.keys(n).forEach(function(e){r.constant(t,n[e])})}else{Object.defineProperty(this.__env__,t,{value:e,enumerable:true})}return this};Environment.prototype.has=function(e){return this.__env__.hasOwnProperty(e)};Environment.prototype.ref=function(e){var t=this;while(true){if(!t){break}if(t.has(e)){return t}t=t.__parent__}};Environment.prototype.parents=function(){var e=this;var t=[];while(e){t.unshift(e);e=e.__parent__}return t};function quote(e){if(is_promise(e)){return e.then(quote)}if(is_pair(e)||e instanceof LSymbol){e[__data__]=true}return e}var native_lambda=_parse(tokenize('(lambda ()\n "[native code]"\n (throw "Invalid Invocation"))'))[0];var get=doc("get",function e(t){var r;for(var n=arguments.length,i=new Array(n>1?n-1:0),a=1;a0&&arguments[0]!==undefined?arguments[0]:null;if(e===null){e=internal(this,"stdin")}typecheck_text_port("peek-char",e,"input-port");return e.peek_char()},"(peek-char port)\n\n This function reads and returns a character from the string\n port, or, if there is no more data in the string port, it\n returns an EOF."),"read-line":doc("read-line",function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:null;if(e===null){e=internal(this,"stdin")}typecheck_text_port("read-line",e,"input-port");return e.read_line()},"(read-line port)\n\n This function reads and returns the next line from the input\n port."),"read-char":doc("read-char",function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:null;if(e===null){e=internal(this,"stdin")}typecheck_text_port("read-char",e,"input-port");return e.read_char()},"(read-char port)\n\n This function reads and returns the next character from the\n input port."),read:doc("read",function(){var e=_asyncToGenerator(function(){var l=this;var f=arguments.length>0&&arguments[0]!==undefined?arguments[0]:null;return _regeneratorRuntime.mark(function e(){var r,n,i,a,o,u,s,c;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:r=l.env;if(!LString.isString(f)){t.next=30;break}n=false;i=false;t.prev=4;o=_asyncIterator(_parse(f,r));case 6:t.next=8;return o.next();case 8:if(!(n=!(u=t.sent).done)){t.next=14;break}s=u.value;return t.abrupt("return",s);case 11:n=false;t.next=6;break;case 14:t.next=20;break;case 16:t.prev=16;t.t0=t["catch"](4);i=true;a=t.t0;case 20:t.prev=20;t.prev=21;if(!(n&&o["return"]!=null)){t.next=25;break}t.next=25;return o["return"]();case 25:t.prev=25;if(!i){t.next=28;break}throw a;case 28:return t.finish(25);case 29:return t.finish(20);case 30:if(f===null){c=internal(r,"stdin")}else{c=f}typecheck_text_port("read",c,"input-port");return t.abrupt("return",c.read.call(r));case 33:case"end":return t.stop()}},e,null,[[4,16,20,30],[21,,25,29]])})()});function t(){return e.apply(this,arguments)}return t}(),"(read [string])\n\n This function, if used with a string, will parse it and\n return the LIPS code, if there is any. If called with a\n port, it will parse the next item from the port. If called\n without an input, it will read a string from standard input\n (using the browser's prompt or a user defined input method)\n and calls itself with that string. This function can be used\n together with `eval` to evaluate code from a string."),pprint:doc("pprint",function e(t){if(is_pair(t)){t=new lips.Formatter(t.toString(true))["break"]().format();global_env.get("display").call(global_env,t)}else{global_env.get("write").call(global_env,t)}global_env.get("newline").call(global_env)},"(pprint expression)\n\n This function will pretty print its input to stdout. If it is called\n with a non-list, it will just call the print function on its\n input."),print:doc("print",function e(){var t=global_env.get("display");var r=global_env.get("newline");var n=this.use_dynamic;var i=global_env;var a=global_env;for(var o=arguments.length,u=new Array(o),s=0;s1?r-1:0),i=1;in.length){throw new Error("Not enough arguments")}var u=0;var s=global_env.get("repr");t=t.replace(a,function(e){var t=e[1];if(t==="~"){return"~"}else if(t==="%"){return"\n"}else{var r=n[u++];if(t==="a"){return s(r)}else{return s(r,true)}}});o=t.match(/~([\S])/);if(o){throw new Error("format: Unrecognized escape sequence ".concat(o[1]))}return t},"(format string n1 n2 ...)\n\n This function accepts a string template and replaces any\n escape sequences in its inputs:\n\n * ~a value as if printed with `display`\n * ~s value as if printed with `write`\n * ~% newline character\n * ~~ literal tilde '~'\n\n If there are missing inputs or other escape characters it\n will error."),display:doc("display",function e(t){var r=arguments.length>1&&arguments[1]!==undefined?arguments[1]:null;if(r===null){r=internal(this,"stdout")}else{typecheck("display",r,"output-port")}var n=t;if(!(r instanceof OutputBinaryFilePort)){n=global_env.get("repr")(t)}r.write.call(global_env,n)},"(display string [port])\n\n This function outputs the string to the standard output or\n the port if given. No newline."),"display-error":doc("display-error",function e(){var t=internal(this,"stderr");var r=global_env.get("repr");for(var n=arguments.length,i=new Array(n),a=0;a1&&arguments[1]!==undefined?arguments[1]:{},r=t.use_dynamic,n=_objectWithoutProperties(t,_excluded4);var i=this;var o=this;var u;var s=_objectSpread(_objectSpread({},n),{},{env:this,dynamic_env:i,use_dynamic:r});var c=_evaluate(e.cdr.car,s);c=resolve_promises(c);function l(t,r,n){if(is_promise(t)){return t.then(function(e){return l(t,e,n)})}if(is_promise(r)){return r.then(function(e){return l(t,e,n)})}if(is_promise(n)){return n.then(function(e){return l(t,r,e)})}o.get("set-obj!").call(o,t,r,n);return n}if(is_pair(e.car)&&LSymbol.is(e.car.car,".")){var f=e.car.cdr.car;var _=e.car.cdr.cdr.car;var p=_evaluate(f,s);var h=_evaluate(_,s);return l(p,h,c)}if(!(e.car instanceof LSymbol)){throw new Error("set! first argument need to be a symbol or "+"dot accessor that evaluate to object.")}var d=e.car.valueOf();u=this.ref(e.car.__name__);return unpromise(c,function(e){if(!u){var t=d.split(".");if(t.length>1){var r=t.pop();var n=t.join(".");var i=a.get(n,{throwError:false});if(i){l(i,r,e);return}}throw new Error("Unbound variable `"+d+"'")}u.set(d,e)})}),"(set! name value)\n\n Macro that can be used to set the value of the variable or slot (mutate it).\n set! searches the scope chain until it finds first non empty slot and sets it."),"unset!":doc(new Macro("set!",function(e){if(!(e.car instanceof LSymbol)){throw new Error("unset! first argument need to be a symbol or "+"dot accessor that evaluate to object.")}var t=e.car;var r=this.ref(t);if(r){delete r.__env__[t.__name__]}}),"(unset! name)\n\n Function to delete the specified name from environment.\n Trying to access the name afterwards will error."),"set-car!":doc("set-car!",function(e,t){typecheck("set-car!",e,"pair");e.car=t},"(set-car! obj value)\n\n Function that sets the car (first item) of the list/pair to specified value.\n The old value is lost."),"set-cdr!":doc("set-cdr!",function(e,t){typecheck("set-cdr!",e,"pair");e.cdr=t},"(set-cdr! obj value)\n\n Function that sets the cdr (tail) of the list/pair to specified value.\n It will destroy the list. The old tail is lost."),"empty?":doc("empty?",function(e){return typeof e==="undefined"||is_nil(e)},"(empty? object)\n\n Function that returns #t if value is nil (an empty list) or undefined."),gensym:doc("gensym",gensym,"(gensym)\n\n Generates a unique symbol that is not bound anywhere,\n to use with macros as meta name."),load:doc("load",function e(u,t){typecheck("load",u,"string");var s=this;if(s.__name__==="__frame__"){s=s.__parent__}if(!(t instanceof Environment)){if(s===global_env){t=s}else{t=this.get("**interaction-environment**")}}var c="**module-path**";var l=global_env.get(c,{throwError:false});u=u.valueOf();if(!u.match(/.[^.]+$/)){u+=".scm"}var r=u.match(/\.xcb$/);function f(e){if(r){e=unserialize_bin(e)}else{if(type(e)==="buffer"){e=e.toString()}e=e.replace(/^#!.*/,"");if(e.match(/^\{/)){e=unserialize(e)}}return exec(e,{env:t})}function n(e){return root.fetch(e).then(function(e){return r?e.arrayBuffer():e.text()}).then(function(e){if(r){e=new Uint8Array(e)}return e})}if(is_node()){return new Promise(function(){var r=_asyncToGenerator(_regeneratorRuntime.mark(function e(r,n){var i,a,o;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:i=nodeRequire("path");if(!l){t.next=6;break}l=l.valueOf();u=i.join(l,u);t.next=12;break;case 6:a=s.get("command-line",{throwError:false});if(!a){t.next=11;break}t.next=10;return a();case 10:o=t.sent;case 11:if(o&&!is_nil(o)){process.cwd();u=i.join(i.dirname(o.car.valueOf()),u)}case 12:global_env.set(c,i.dirname(u));nodeRequire("fs").readFile(u,function(e,t){if(e){n(e);global_env.set(c,l)}else{try{f(t).then(function(){r();global_env.set(c,l)})["catch"](n)}catch(e){n(e)}}});case 14:case"end":return t.stop()}},e)}));return function(e,t){return r.apply(this,arguments)}}())}if(l){l=l.valueOf();u=l+"/"+u.replace(/^\.?\/?/,"")}return n(u).then(function(e){global_env.set(c,u.replace(/\/[^/]*$/,""));return f(e)}).then(function(){})["finally"](function(){global_env.set(c,l)})},"(load filename)\n (load filename environment)\n\n Fetches the file (from disk or network) and evaluates its content as LIPS code.\n If the second argument is provided and it's an environment the evaluation\n will happen in that environment."),while:doc(new Macro("while",function(e,t){var r=e.car;var n=_objectSpread(_objectSpread({},t),{},{env:this});var i=new Pair(new LSymbol("begin"),e.cdr);return function t(){return unpromise(_evaluate(r,n),function(e){if(e){return unpromise(_evaluate(i,n),t)}})}()}),"(while cond body)\n\n Creates a loop, it executes cond and body until cond expression is false."),do:doc(new Macro("do",function(){var r=_asyncToGenerator(function(_,e){var p=this;var h=e.use_dynamic,d=e.error;return _regeneratorRuntime.mark(function e(){var r,n,u,s,i,c,l,a,o,f;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:r=p;n=r;u=r.inherit("do");s=_.car;i=_.cdr.car;c=_.cdr.cdr;if(!is_nil(c)){c=new Pair(LSymbol("begin"),c)}l={env:r,dynamic_env:n,use_dynamic:h,error:d};a=s;case 9:if(is_nil(a)){t.next=20;break}o=a.car;t.t0=u;t.t1=o.car;t.next=15;return _evaluate(o.cdr.car,l);case 15:t.t2=t.sent;t.t0.set.call(t.t0,t.t1,t.t2);a=a.cdr;t.next=9;break;case 20:l={env:u,dynamic_env:n,error:d};f=_regeneratorRuntime.mark(function e(){var r,n,i,a,o;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(is_nil(c)){t.next=3;break}t.next=3;return lips.evaluate(c,l);case 3:r=s;n={};case 5:if(is_nil(r)){t.next=15;break}i=r.car;if(is_nil(i.cdr.cdr)){t.next=12;break}t.next=10;return _evaluate(i.cdr.cdr.car,l);case 10:a=t.sent;n[i.car.valueOf()]=a;case 12:r=r.cdr;t.next=5;break;case 15:o=Object.getOwnPropertySymbols(n);Object.keys(n).concat(o).forEach(function(e){u.set(e,n[e])});case 17:case"end":return t.stop()}},e)});case 22:t.next=24;return _evaluate(i.car,l);case 24:t.t3=t.sent;if(!(t.t3===false)){t.next=29;break}return t.delegateYield(f(),"t4",27);case 27:t.next=22;break;case 29:if(is_nil(i.cdr)){t.next=33;break}t.next=32;return _evaluate(i.cdr.car,l);case 32:return t.abrupt("return",t.sent);case 33:case"end":return t.stop()}},e)})()});return function(e,t){return r.apply(this,arguments)}}()),"(do (( )) (test return) . body)\n\n Iteration macro that evaluates the expression body in scope of the variables.\n On each loop it changes the variables according to the expression and runs\n test to check if the loop should continue. If test is a single value, the macro\n will return undefined. If the test is a pair of expressions the macro will\n evaluate and return the second expression after the loop exits."),if:doc(new Macro("if",function(r,e){var t=e.error,n=e.use_dynamic;var i=this;var a=this;var o={env:a,dynamic_env:i,use_dynamic:n,error:t};var u=function e(t){if(t===false){return _evaluate(r.cdr.cdr.car,o)}else{return _evaluate(r.cdr.car,o)}};if(is_nil(r)){throw new Error("too few expressions for `if`")}var s=_evaluate(r.car,o);return unpromise(s,u)}),"(if cond true-expr false-expr)\n\n Macro that evaluates cond expression and if the value is true, it\n evaluates and returns true-expression, if not it evaluates and returns\n false-expression."),"let-env":new Macro("let-env",function(t){var e=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};var r=e.dynamic_env,n=e.use_dynamic,i=e.error;typecheck("let-env",t,"pair");var a=_evaluate(t.car,{env:this,dynamic_env:r,error:i,use_dynamic:n});return unpromise(a,function(e){typecheck("let-env",e,"environment");return _evaluate(Pair(LSymbol("begin"),t.cdr),{env:e,dynamic_env:r,error:i})})},"(let-env env . body)\n\n Special macro that evaluates body in context of given environment\n object."),letrec:doc(let_macro(Symbol["for"]("letrec")),"(letrec ((a value-a) (b value-b) ...) . body)\n\n Macro that creates a new environment, then evaluates and assigns values to\n names and then evaluates the body in context of that environment.\n Values are evaluated sequentially and the next value can access the\n previous values/names."),"letrec*":doc(let_macro(Symbol["for"]("letrec")),"(letrec* ((a value-a) (b value-b) ...) . body)\n\n Same as letrec but the order of execution of the binding is guaranteed,\n so you can use recursive code as well as referencing the previous binding.\n\n In LIPS both letrec and letrec* behave the same."),"let*":doc(let_macro(Symbol["for"]("let*")),"(let* ((a value-a) (b value-b) ...) . body)\n\n Macro similar to `let`, but the subsequent bindings after the first\n are evaluated in the environment including the previous let variables,\n so you can define one variable, and use it in the next's definition."),let:doc(let_macro(Symbol["for"]("let")),"(let ((a value-a) (b value-b) ...) . body)\n\n Macro that creates a new environment, then evaluates and assigns values to names,\n and then evaluates the body in context of that environment. Values are evaluated\n sequentially but you can't access previous values/names when the next are\n evaluated. You can only get them in the body of the let expression. (If you want\n to define multiple variables and use them in each other's definitions, use\n `let*`.)"),"begin*":doc(parallel("begin*",function(e){return e.pop()}),"(begin* . body)\n\n This macro is a parallel version of begin. It evaluates each expression\n in the body and if it's a promise it will await it in parallel and return\n the value of the last expression (i.e. it uses Promise.all())."),shuffle:doc("shuffle",function(e){typecheck("shuffle",e,["pair","nil","array"]);var t=global_env.get("random");if(is_nil(e)){return _nil}if(Array.isArray(e)){return shuffle(e.slice(),t)}var r=global_env.get("list->array")(e);r=shuffle(r,t);return global_env.get("array->list")(r)},"(shuffle obj)\n\n Order items in vector or list in random order."),begin:doc(new Macro("begin",function(e,t){var n=_objectSpread(_objectSpread({},t),{},{env:this});var i=global_env.get("list->array")(e);var a;return function t(){if(i.length){var e=i.shift();var r=_evaluate(e,n);return unpromise(r,function(e){a=e;return t()})}else{return a}}()}),"(begin . args)\n\n Macro that runs a list of expressions in order and returns the value\n of the last one. It can be used in places where you can only have a\n single expression, like (if)."),ignore:new Macro("ignore",function(e,t){var r=_objectSpread(_objectSpread({},t),{},{env:this,dynamic_env:this});_evaluate(new Pair(new LSymbol("begin"),e),r)},"(ignore . body)\n\n Macro that will evaluate the expression and swallow any promises that may\n be created. It will discard any value that may be returned by the last body\n expression. The code should have side effects and/or when it's promise\n it should resolve to undefined."),"call/cc":doc(Macro.defmacro("call/cc",function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};var r=_objectSpread({env:this},t);return unpromise(_evaluate(e.car,r),function(e){if(is_function(e)){return e(new Continuation(null))}})}),"(call/cc proc)\n\n Call-with-current-continuation.\n\n NOT SUPPORTED BY LIPS RIGHT NOW"),parameterize:doc(new Macro("parameterize",function(t,e){var i=e.dynamic_env;var a=i.inherit("parameterize").new_frame(null,{});var o=_objectSpread(_objectSpread({},e),{},{env:this});var u=t.car;if(!is_pair(u)){var r=type(u);throw new Error("Invalid syntax for parameterize expecting pair got ".concat(r))}function s(){var e=new Pair(new LSymbol("begin"),t.cdr);return _evaluate(e,_objectSpread(_objectSpread({},o),{},{dynamic_env:a}))}return function r(){var e=u.car;var n=e.car.valueOf();return unpromise(_evaluate(e.cdr.car,o),function(e){var t=i.get(n,{throwError:false});if(!is_parameter(t)){throw new Error("Unknown parameter ".concat(n))}a.set(n,t.inherit(e));if(!is_null(u.cdr)){u=u.cdr;return r()}else{return s()}})}()}),"(parameterize ((name value) ...)\n\n Macro that change the dynamic variable created by make-parameter."),"make-parameter":doc(new Macro("make-parameter",function(e,t){t.dynamic_env;var r=_evaluate(e.car,t);var n;if(is_pair(e.cdr.car)){n=_evaluate(e.cdr.car,t)}return new Parameter(r,n)}),"(make-parameter init converter)\n\n Function creates new dynamic variable that can be custimized with parameterize\n macro. The value should be assigned to a variable e.g.:\n\n (define radix (make-parameter 10))\n\n The result value is a procedure that return the value of dynamic variable."),"define-syntax-parameter":doc(new Macro("define-syntax-parameter",function(e,t){var r=e.car;var n=this;if(!(r instanceof LSymbol)){throw new Error("define-syntax-parameter: invalid syntax expecting symbol got ".concat(type(r)))}var i=_evaluate(e.cdr.car,_objectSpread({env:n},t));typecheck("define-syntax-parameter",i,"syntax",2);i.__name__=r.valueOf();if(i.__name__ instanceof LString){i.__name__=i.__name__.valueOf()}var a;if(is_pair(e.cdr.cdr)&&LString.isString(e.cdr.cdr.car)){a=e.cdr.cdr.car.valueOf()}n.set(e.car,new SyntaxParameter(i),a,true)}),"(define-syntax-parameter name syntax [__doc__])\n\n Binds to the transformer obtained by evaluating .\n The transformer provides the default expansion for the syntax parameter,\n and in the absence of syntax-parameterize, is functionally equivalent to\n define-syntax."),"syntax-parameterize":doc(new Macro("syntax-parameterize",function(e,t){var r=global_env.get("list->array")(e.car);var n=this.inherit("syntax-parameterize");while(r.length){var i=r.shift();if(!(is_pair(i)||i.car instanceof LSymbol)){var a="invalid syntax for syntax-parameterize: ".concat(repr(e,true));throw new Error("syntax-parameterize: ".concat(a))}var o=_evaluate(i.cdr.car,_objectSpread(_objectSpread({},t),{},{env:this}));var u=i.car;typecheck("syntax-parameterize",o,["syntax"]);typecheck("syntax-parameterize",u,"symbol");o.__name__=u.valueOf();if(o.__name__ instanceof LString){o.__name__=o.__name__.valueOf()}var s=new SyntaxParameter(o);if(u.is_gensym()){var c=u.literal();var l=this.get(c,{throwError:false});if(l instanceof SyntaxParameter){n.set(c,s)}}n.set(u,s)}var f=new Pair(new LSymbol("begin"),e.cdr);return _evaluate(f,_objectSpread(_objectSpread({},t),{},{env:n}))}),"(syntax-parameterize (bindings) body)\n\n Macro work similar to let-syntax but the the bindnds will be exposed to the user.\n With syntax-parameterize you can define anaphoric macros."),define:doc(Macro.defmacro("define",function(r,e){var n=this;if(is_pair(r.car)&&r.car.car instanceof LSymbol){var t=new Pair(new LSymbol("define"),new Pair(r.car.car,new Pair(new Pair(new LSymbol("lambda"),new Pair(r.car.cdr,r.cdr)))));return t}else if(e.macro_expand){return}e.dynamic_env=this;e.env=n;var i=r.cdr.car;var a;if(is_pair(i)){i=_evaluate(i,e);a=true}else if(i instanceof LSymbol){i=n.get(i)}typecheck("define",r.car,"symbol");return unpromise(i,function(e){if(n.__name__===Syntax.__merge_env__){n=n.__parent__}if(a&&(is_function(e)&&is_lambda(e)||e instanceof Syntax||is_parameter(e))){e.__name__=r.car.valueOf();if(e.__name__ instanceof LString){e.__name__=e.__name__.valueOf()}}var t;if(is_pair(r.cdr.cdr)&&LString.isString(r.cdr.cdr.car)){t=r.cdr.cdr.car.valueOf()}n.set(r.car,e,t,true)})}),'(define name expression)\n (define name expression "doc string")\n (define (function-name . args) . body)\n\n Macro for defining values. It can be used to define variables,\n or functions. If the first argument is list it will create a function\n with name being first element of the list. This form expands to\n `(define function-name (lambda args body))`'),"set-obj!":doc("set-obj!",function(e,t,r){var n=arguments.length>3&&arguments[3]!==undefined?arguments[3]:null;var i=_typeof$1(e);if(is_null(e)||i!=="object"&&i!=="function"){var a=typeErrorMessage("set-obj!",type(e),["object","function"]);throw new Error(a)}typecheck("set-obj!",t,["string","symbol","number"]);e=unbind(e);t=t.valueOf();if(arguments.length===2){delete e[t]}else if(is_prototype(e)&&is_function(r)){e[t]=unbind(r);e[t][__prototype__]=true}else if(is_function(r)||is_native(r)||is_nil(r)){e[t]=r}else{e[t]=r&&!is_prototype(r)?r.valueOf():r}if(props){var o=e[t];Object.defineProperty(e,t,_objectSpread(_objectSpread({},n),{},{value:o}))}},"(set-obj! obj key value)\n (set-obj! obj key value props)\n\n Function set a property of a JavaScript object. props should be a vector of pairs,\n passed to Object.defineProperty."),"null-environment":doc("null-environment",function(){return global_env.inherit("null")},"(null-environment)\n\n Returns a clean environment with only the standard library."),values:doc("values",function e(){for(var t=arguments.length,r=new Array(t),n=0;n1&&arguments[1]!==undefined?arguments[1]:{},y=e.use_dynamic,v=e.error;var g=this;var b;if(is_pair(m.cdr)&&LString.isString(m.cdr.car)&&!is_nil(m.cdr.cdr)){b=m.cdr.car.valueOf()}function w(){var e=is_context(this)?this:{dynamic_env:g},r=e.dynamic_env;var n=g.inherit("lambda");r=r.inherit("lambda");if(this&&!is_context(this)){if(this&&!this.__instance__){Object.defineProperty(this,"__instance__",{enumerable:false,get:function e(){return true},set:function e(){},configurable:false})}n.set("this",this)}for(var t=arguments.length,i=new Array(t),a=0;a> SYNTAX");log(e);log(v);var n=w.inherit("syntax");var i=n;var a=this;if(a.__name__===Syntax.__merge_env__){var o=Object.getOwnPropertySymbols(a.__env__);o.forEach(function(e){a.__parent__.set(e,a.__env__[e])});a=a.__parent__}var u={env:n,dynamic_env:i,use_dynamic:g,error:b};var s,c,l;if(v.car instanceof LSymbol){s=v.car;l=D(v.cdr.car);c=v.cdr.cdr}else{s="...";l=D(v.car);c=v.cdr}try{while(!is_nil(c)){var f=c.car.car;var _=c.car.cdr.car;log("[[[ RULE");log(f);var p=extract_patterns(f,e,l,s,{expansion:this,define:w});if(p){if(is_debug()){console.log(JSON.stringify(symbolize(p),true,2));console.log("PATTERN: "+f.toString(true));console.log("MACRO: "+e.toString(true))}var h=[];var d=transform_syntax({bindings:p,expr:_,symbols:l,scope:n,lex_scope:a,names:h,ellipsis:s});log("OUPUT>>> ",d);if(d){_=d}var m=a.merge(n,Syntax.__merge_env__);if(r){return{expr:_,scope:m}}var y=_evaluate(_,_objectSpread(_objectSpread({},u),{},{env:m}));return clear_gensyms(y,h)}c=c.cdr}}catch(e){e.message+="\nin macro:\n ".concat(v.toString(true));throw e}throw new Error("syntax-rules: no matching syntax in macro ".concat(e.toString(true)))},w);r.__code__=v;return r},"(syntax-rules () (pattern expression) ...)\n\n Base of hygienic macros, it will return a new syntax expander\n that works like Lisp macros."),quote:doc(new Macro("quote",function(e){return quote(e.car)}),"(quote expression) or 'expression\n\n Macro that returns a single LIPS expression as data (it won't evaluate the\n argument). It will return a list if put in front of LIPS code.\n And if put in front of a symbol it will return the symbol itself, not the value\n bound to that name."),"unquote-splicing":doc("unquote-splicing",function(){throw new Error("You can't call `unquote-splicing` outside of quasiquote")},"(unquote-splicing code) or ,@code\n\n Special form used in the quasiquote macro. It evaluates the expression inside and\n splices the list into quasiquote's result. If it is not the last element of the\n expression, the computed value must be a pair."),unquote:doc("unquote",function(){throw new Error("You can't call `unquote` outside of quasiquote")},"(unquote code) or ,code\n\n Special form used in the quasiquote macro. It evaluates the expression inside and\n substitutes the value into quasiquote's result."),quasiquote:Macro.defmacro("quasiquote",function(e,t){var u=t.use_dynamic,s=t.error;var c=this;var l=c;function a(e){return is_pair(e)||is_plain_object(e)||Array.isArray(e)}function f(e,t){var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:a;if(is_pair(e)){var n=e.car;var i=e.cdr;if(r(n)){n=t(n)}if(r(i)){i=t(i)}if(is_promise(n)||is_promise(i)){return promise_all([n,i]).then(function(e){var t=_slicedToArray(e,2),r=t[0],n=t[1];return new Pair(r,n)})}else{return new Pair(n,i)}}return e}function o(e,t){if(is_pair(e)){if(!is_nil(t)){e.append(t)}}else{e=new Pair(e,t)}return e}function r(e){return!!e.filter(function(e){return is_pair(e)&&LSymbol.is(e.car,/^(unquote|unquote-splicing)$/)}).length}function _(e,n,i){return e.reduce(function(e,t){if(!is_pair(t)){e.push(t);return e}if(LSymbol.is(t.car,"unquote-splicing")){var r;if(n+11){var t="You can't splice multiple atoms inside list";throw new Error(t)}if(!(is_pair(i.cdr)&&is_nil(r[0]))){return r[0]}}r=r.map(function(e){if(d.has(e)){return e.clone()}else{d.add(e);return e}});var n=m(i.cdr,0,1);if(is_nil(n)&&is_nil(r[0])){return undefined}return unpromise(n,function(e){if(is_nil(r[0])){return e}if(r.length===1){return o(r[0],e)}var t=r.reduce(function(e,t){return o(e,t)});return o(t,e)})})}(i.car.cdr)}var d=new Set;function m(e,t,r){if(is_pair(e)){if(is_pair(e.car)){if(LSymbol.is(e.car.car,"unquote-splicing")){return h(e,t+1,r)}if(LSymbol.is(e.car.car,"unquote")){if(t+2===r&&is_pair(e.car.cdr)&&is_pair(e.car.cdr.car)&&LSymbol.is(e.car.cdr.car.car,"unquote-splicing")){var n=e.car.cdr;return new Pair(new Pair(new LSymbol("unquote"),h(n,t+2,r)),_nil)}else if(is_pair(e.car.cdr)&&!is_nil(e.car.cdr.cdr)){if(is_pair(e.car.cdr.car)){var i=[];return function t(r){if(is_nil(r)){return Pair.fromArray(i)}return unpromise(_evaluate(r.car,{env:c,dynamic_env:l,use_dynamic:u,error:s}),function(e){i.push(e);return t(r.cdr)})}(e.car.cdr)}else{return e.car.cdr}}}}if(LSymbol.is(e.car,"quasiquote")){var a=m(e.cdr,t,r+1);return new Pair(e.car,a)}if(LSymbol.is(e.car,"quote")){return new Pair(e.car,m(e.cdr,t,r))}if(LSymbol.is(e.car,"unquote")){t++;if(tr){throw new Error("You can't call `unquote` outside "+"of quasiquote")}if(is_pair(e.cdr)){if(!is_nil(e.cdr.cdr)){if(is_pair(e.cdr.car)){var o=[];return function t(r){if(is_nil(r)){return Pair.fromArray(o)}return unpromise(_evaluate(r.car,{env:c,dynamic_env:l,use_dynamic:u,error:s}),function(e){o.push(e);return t(r.cdr)})}(e.cdr)}else{return e.cdr}}else{return _evaluate(e.cdr.car,{env:c,dynamic_env:l,error:s})}}else{return e.cdr}}return f(e,function(e){return m(e,t,r)})}else if(is_plain_object(e)){return p(e,t,r)}else if(e instanceof Array){return _(e,t,r)}return e}function n(e){if(is_pair(e)){delete e[__data__];if(!e.haveCycles("car")){n(e.car)}if(!e.haveCycles("cdr")){n(e.cdr)}}}if(is_plain_object(e.car)&&!r(Object.values(e.car))){return quote(e.car)}if(Array.isArray(e.car)&&!r(e.car)){return quote(e.car)}if(is_pair(e.car)&&!e.car.find("unquote")&&!e.car.find("unquote-splicing")&&!e.car.find("quasiquote")){return quote(e.car)}var i=m(e.car,0,1);return unpromise(i,function(e){n(e);return quote(e)})},"(quasiquote list)\n\n Similar macro to `quote` but inside it you can use special expressions (unquote\n x) abbreviated to ,x that will evaluate x and insert its value verbatim or\n (unquote-splicing x) abbreviated to ,@x that will evaluate x and splice the value\n into the result. Best used with macros but it can be used outside."),clone:doc("clone",function e(t){typecheck("clone",t,"pair");return t.clone()},"(clone list)\n\n Function that returns a clone of the list, that does not share any pairs with the\n original, so the clone can be safely mutated without affecting the original."),append:doc("append",function e(){var t;for(var r=arguments.length,n=new Array(r),i=0;iarray")(t).reverse();return global_env.get("array->list")(r)}else if(Array.isArray(t)){return t.reverse()}else{throw new Error(typeErrorMessage("reverse",type(t),"array or pair"))}},"(reverse list)\n\n Function that reverses the list or array. If value is not a list\n or array it will error."),nth:doc("nth",function e(t,r){typecheck("nth",t,"number");typecheck("nth",r,["array","pair"]);if(is_pair(r)){var n=r;var i=0;while(iarray")(r).join(t)},"(join separator list)\n\n Function that returns a string by joining elements of the list using separator."),split:doc("split",function e(t,r){typecheck("split",t,["regex","string"]);typecheck("split",r,"string");return global_env.get("array->list")(r.split(t))},"(split separator string)\n\n Function that creates a list by splitting string by separator which can\n be a string or regular expression."),replace:doc("replace",function e(t,r,n){typecheck("replace",t,["regex","string"]);typecheck("replace",r,["string","function"]);typecheck("replace",n,"string");return n.replace(t,r)},"(replace pattern replacement string)\n\n Function that changes pattern to replacement inside string. Pattern can be a\n string or regex and replacement can be function or string. See Javascript\n String.replace()."),match:doc("match",function e(t,r){typecheck("match",t,["regex","string"]);typecheck("match",r,"string");var n=r.match(t);return n?global_env.get("array->list")(n):false},"(match pattern string)\n\n Function that returns a match object from JavaScript as a list or #f if\n no match."),search:doc("search",function e(t,r){typecheck("search",t,["regex","string"]);typecheck("search",r,"string");return r.search(t)},"(search pattern string)\n\n Function that returns the first found index of the pattern inside a string."),repr:doc("repr",function e(t,r){return toString(t,r)},"(repr obj)\n\n Function that returns a LIPS code representation of the object as a string."),"escape-regex":doc("escape-regex",function(e){typecheck("escape-regex",e,"string");return escape_regex(e.valueOf())},"(escape-regex string)\n\n Function that returns a new string where all special operators used in regex,\n are escaped with backslashes so they can be used in the RegExp constructor\n to match a literal string."),env:doc("env",function e(e){e=e||this.env;var t=Object.keys(e.__env__).map(LSymbol);var r;if(t.length){r=Pair.fromArray(t)}else{r=_nil}if(e.__parent__ instanceof Environment){return global_env.get("env").call(this,e.__parent__).append(r)}return r},"(env)\n (env obj)\n\n Function that returns a list of names (functions, macros and variables)\n that are bound in the current environment or one of its parents."),new:doc("new",function(e){for(var t=arguments.length,r=new Array(t>1?t-1:0),n=1;n2&&arguments[2]!==undefined?arguments[2]:specials.LITERAL;typecheck("set-special!",e,"string",1);typecheck("set-special!",t,"symbol",2);specials.append(e.valueOf(),t,r)},'(set-special! symbol name [type])\n\n Add a special symbol to the list of transforming operators by the parser.\n e.g.: `(add-special! "#" \'x)` will allow to use `#(1 2 3)` and it will be\n transformed into (x (1 2 3)) so you can write x macro that will process\n the list. 3rd argument is optional, and it can be one of two values:\n lips.specials.LITERAL, which is the default behavior, or\n lips.specials.SPLICE which causes the value to be unpacked into the expression.\n This can be used for e.g. to make `#(1 2 3)` into (x 1 2 3) that is needed\n by # that defines vectors.'),get:get,".":get,unbind:doc(unbind,"(unbind fn)\n\n Function that removes the weak 'this' binding from a function so you\n can get properties from the actual function object."),type:doc(type,"(type object)\n\n Function that returns the type of an object as string."),debugger:doc("debugger",function(){debugger},'(debugger)\n\n Function that triggers the JavaScript debugger (e.g. the browser devtools)\n using the "debugger;" statement. If a debugger is not running this\n function does nothing.'),in:doc("in",function(e,t){if(e instanceof LSymbol||e instanceof LString||e instanceof LNumber){e=e.valueOf()}return e in unbox(t)},'(in key value)\n\n Function that uses the Javascript "in" operator to check if key is\n a valid property in the value.'),"instance?":doc("instance?",function(e){return is_instance(e)},"(instance? obj)\n\n Checks if object is an instance, created with a new operator"),instanceof:doc("instanceof",function(e,t){return t instanceof unbind(e)},"(instanceof type obj)\n\n Predicate that tests if the obj is an instance of type."),"prototype?":doc("prototype?",is_prototype,"(prototype? obj)\n\n Predicate that tests if value is a valid JavaScript prototype,\n i.e. calling (new) with it will not throw ' is not a constructor'."),"macro?":doc("macro?",function(e){return e instanceof Macro},"(macro? expression)\n\n Predicate that tests if value is a macro."),"continuation?":doc("continuation?",is_continuation,"(continuation? expression)\n\n Predicate that tests if value is a callable continuation."),"function?":doc("function?",is_function,"(function? expression)\n\n Predicate that tests if value is a callable function."),"real?":doc("real?",function(e){if(type(e)!=="number"){return false}if(e instanceof LNumber){return e.isFloat()}return LNumber.isFloat(e)},"(real? number)\n\n Predicate that tests if value is a real number (not complex)."),"number?":doc("number?",function(e){return Number.isNaN(e)||LNumber.isNumber(e)},"(number? expression)\n\n Predicate that tests if value is a number or NaN value."),"string?":doc("string?",function(e){return LString.isString(e)},"(string? expression)\n\n Predicate that tests if value is a string."),"pair?":doc("pair?",is_pair,"(pair? expression)\n\n Predicate that tests if value is a pair or list structure."),"regex?":doc("regex?",function(e){return e instanceof RegExp},"(regex? expression)\n\n Predicate that tests if value is a regular expression."),"null?":doc("null?",function(e){return is_null(e)},"(null? expression)\n\n Predicate that tests if value is null-ish (i.e. undefined, nil, or\n Javascript null)."),"boolean?":doc("boolean?",function(e){return typeof e==="boolean"},"(boolean? expression)\n\n Predicate that tests if value is a boolean (#t or #f)."),"symbol?":doc("symbol?",function(e){return e instanceof LSymbol},"(symbol? expression)\n\n Predicate that tests if value is a LIPS symbol."),"array?":doc("array?",function(e){return e instanceof Array},"(array? expression)\n\n Predicate that tests if value is an array."),"object?":doc("object?",function(e){return!is_nil(e)&&e!==null&&!(e instanceof LCharacter)&&!(e instanceof RegExp)&&!(e instanceof LString)&&!is_pair(e)&&!(e instanceof LNumber)&&_typeof$1(e)==="object"&&!(e instanceof Array)},"(object? expression)\n\n Predicate that tests if value is an plain object (not another LIPS type)."),flatten:doc("flatten",function e(t){typecheck("flatten",t,"pair");return t.flatten()},"(flatten list)\n\n Returns a shallow list from tree structure (pairs)."),"array->list":doc("array->list",function(e){typecheck("array->list",e,"array");return Pair.fromArray(e)},"(array->list array)\n\n Function that converts a JavaScript array to a LIPS cons list."),"tree->array":doc("tree->array",to_array("tree->array",true),"(tree->array list)\n\n Function that converts a LIPS cons tree structure into a JavaScript array."),"list->array":doc("list->array",to_array("list->array"),"(list->array list)\n\n Function that converts a LIPS list into a JavaScript array."),apply:doc("apply",function e(t){for(var r=arguments.length,n=new Array(r>1?r-1:0),i=1;iarray").call(this,a));return t.apply(this,prepare_fn_args(t,n))},"(apply fn list)\n\n Function that calls fn with the list of arguments."),length:doc("length",function e(t){if(!t||is_nil(t)){return 0}if(is_pair(t)){return t.length()}if("length"in t){return t.length}},'(length expression)\n\n Function that returns the length of the object. The object can be a LIPS\n list or any object that has a "length" property. Returns undefined if the\n length could not be found.'),"string->number":doc("string->number",function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:10;typecheck("string->number",e,"string",1);typecheck("string->number",t,"number",2);e=e.valueOf();t=t.valueOf();if(e.match(rational_bare_re)||e.match(rational_re)){return parse_rational(e,t)}else if(e.match(complex_bare_re)||e.match(complex_re)){return parse_complex(e,t)}else{var r=t===10&&!e.match(/e/i)||t===16;if(e.match(int_bare_re)&&r||e.match(int_re)){return parse_integer(e,t)}if(e.match(float_re)){return parse_float(e)}}return false},"(string->number number [radix])\n\n Function that parses a string into a number."),try:doc(new Macro("try",function(r,e){var f=this;var _=e.use_dynamic;e.error;return new Promise(function(t,u){var s,n;if(LSymbol.is(r.cdr.car.car,"catch")){s=r.cdr.car;if(is_pair(r.cdr.cdr)&&LSymbol.is(r.cdr.cdr.car.car,"finally")){n=r.cdr.cdr.car}}else if(LSymbol.is(r.cdr.car.car,"finally")){n=r.cdr.car}if(!(n||s)){throw new Error("try: invalid syntax")}function c(e){t(e);throw new IgnoreException("[CATCH]")}var l=function e(t,r){r(t)};if(n){l=function e(t,r){l=u;i.error=function(e){throw e};unpromise(_evaluate(new Pair(new LSymbol("begin"),n.cdr),i),function(){r(t)})}}var i={env:f,use_dynamic:_,dynamic_env:f,error:function e(t){if(t instanceof IgnoreException){throw t}var r=f.inherit("try");if(s){var n=s.cdr.car.car;if(!(n instanceof LSymbol)){throw new Error("try: invalid syntax: catch require variable name")}r.set(n,t);var i;var a={env:r,use_dynamic:_,dynamic_env:f,error:function e(t){i=true;u(t);throw new IgnoreException("[CATCH]")}};var o=_evaluate(new Pair(new LSymbol("begin"),s.cdr.cdr),a);unpromise(o,function e(t){if(!i){l(t,c)}})}else{l(undefined,function(){throw t})}}};var e=_evaluate(r.car,i);unpromise(e,function(e){l(e,t)},i.error)})}),"(try expr (catch (e) code))\n (try expr (catch (e) code) (finally code))\n (try expr (finally code))\n\n Macro that executes expr and catches any exceptions thrown. If catch is provided\n it's executed when an error is thrown. If finally is provided it's always\n executed at the end."),raise:doc("raise",function(e){throw e},"(raise obj)\n\n Throws the object verbatim (no wrapping an a new Error)."),throw:doc("throw",function(e){throw new Error(e)},"(throw string)\n\n Throws a new exception."),find:doc("find",function t(r,n){typecheck("find",r,["regex","function"]);typecheck("find",n,["pair","nil"]);if(is_null(n)){return _nil}var e=matcher("find",r);return unpromise(e(n.car),function(e){if(e&&!is_nil(e)){return n.car}return t(r,n.cdr)})},"(find fn list)\n (find regex list)\n\n Higher-order function that finds the first value for which fn return true.\n If called with a regex it will create a matcher function."),"for-each":doc("for-each",function(e){var t;typecheck("for-each",e,"function");for(var r=arguments.length,n=new Array(r>1?r-1:0),i=1;i1?t-1:0),a=1;a3?n-3:0),a=3;a3?i-3:0),o=3;oarray")(r);var a=[];var o=matcher("filter",t);return function t(r){function e(e){if(e&&!is_nil(e)){a.push(n)}return t(++r)}if(r===i.length){return Pair.fromArray(a)}var n=i[r];return unpromise(o(n),e)}(0)},"(filter fn list)\n (filter regex list)\n\n Higher-order function that calls `fn` for each element of the list\n and return a new list for only those elements for which fn returns\n a truthy value. If called with a regex it will create a matcher function."),compose:doc(compose,"(compose . fns)\n\n Higher-order function that creates a new function that applies all functions\n from right to left and returns the last value. Reverse of pipe.\n e.g.:\n ((compose (curry + 2) (curry * 3)) 10) --\x3e (+ 2 (* 3 10)) --\x3e 32"),pipe:doc(pipe,"(pipe . fns)\n\n Higher-order function that creates a new function that applies all functions\n from left to right and returns the last value. Reverse of compose.\n e.g.:\n ((pipe (curry + 2) (curry * 3)) 10) --\x3e (* 3 (+ 2 10)) --\x3e 36"),curry:doc(curry,"(curry fn . args)\n\n Higher-order function that creates a curried version of the function.\n The result function will have partially applied arguments and it\n will keep returning one-argument functions until all arguments are provided,\n then it calls the original function with the accumulated arguments.\n\n e.g.:\n (define (add a b c d) (+ a b c d))\n (define add1 (curry add 1))\n (define add12 (add 2))\n (display (add12 3 4))"),gcd:doc("gcd",function e(){for(var t=arguments.length,r=new Array(t),n=0;nu?a%=u:u%=a}a=abs(s*r[o])/(a+u)}return LNumber(a)},"(lcm n1 n2 ...)\n\n Function that returns the least common multiple of the arguments."),"odd?":doc("odd?",single_math_op(function(e){return LNumber(e).isOdd()}),"(odd? number)\n\n Checks if number is odd."),"even?":doc("even?",single_math_op(function(e){return LNumber(e).isEven()}),"(even? number)\n\n Checks if number is even."),"*":doc("*",reduce_math_op(function(e,t){return LNumber(e).mul(t)},LNumber(1)),"(* . numbers)\n\n Multiplies all numbers passed as arguments. If single value is passed\n it will return that value."),"+":doc("+",reduce_math_op(function(e,t){return LNumber(e).add(t)},LNumber(0)),"(+ . numbers)\n\n Sums all numbers passed as arguments. If single value is passed it will\n return that value."),"-":doc("-",function(){for(var e=arguments.length,t=new Array(e),r=0;r":doc(">",function(){for(var e=arguments.length,t=new Array(e),r=0;r",t,["bigint","float","rational"]);return seq_compare(function(e,t){return LNumber(e).cmp(t)===1},t)},"(> x1 x2 x3 ...)\n\n Function that compares its numerical arguments and checks if they are\n monotonically decreasing, i.e. x1 > x2 and x2 > x3 and so on."),"<":doc("<",function(){for(var e=arguments.length,t=new Array(e),r=0;r=":doc(">=",function(){for(var e=arguments.length,t=new Array(e),r=0;r=",t,["bigint","float","rational"]);return seq_compare(function(e,t){return[0,1].includes(LNumber(e).cmp(t))},t)},"(>= x1 x2 ...)\n\n Function that compares its numerical arguments and checks if they are\n monotonically nonincreasing, i.e. x1 >= x2 and x2 >= x3 and so on."),"eq?":doc("eq?",equal,"(eq? a b)\n\n Function that compares two values if they are identical."),or:doc(new Macro("or",function(e,t){var i=t.use_dynamic,a=t.error;var o=global_env.get("list->array")(e);var u=this;var s=u;if(!o.length){return false}var c;return function t(){function e(e){c=e;if(c!==false){return c}else{return t()}}if(!o.length){if(c!==false){return c}else{return false}}else{var r=o.shift();var n=_evaluate(r,{env:u,dynamic_env:s,use_dynamic:i,error:a});return unpromise(n,e)}}()}),"(or . expressions)\n\n Macro that executes the values one by one and returns the first that is\n a truthy value. If there are no expressions that evaluate to true it\n returns false."),and:doc(new Macro("and",function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},r=t.use_dynamic,n=t.error;var i=global_env.get("list->array")(e);var a=this;var o=a;if(!i.length){return true}var u;var s={env:a,dynamic_env:o,use_dynamic:r,error:n};return function t(){function e(e){u=e;if(u===false){return false}else{return t()}}if(!i.length){if(u!==false){return u}else{return false}}else{var r=i.shift();return unpromise(_evaluate(r,s),e)}}()}),"(and . expressions)\n\n Macro that evaluates each expression in sequence and if any value returns false\n it will stop and return false. If each value returns true it will return the\n last value. If it's called without arguments it will return true."),"|":doc("|",function(e,t){return LNumber(e).or(t)},"(| a b)\n\n Function that calculates the bitwise or operation."),"&":doc("&",function(e,t){return LNumber(e).and(t)},"(& a b)\n\n Function that calculates the bitwise and operation."),"~":doc("~",function(e){return LNumber(e).neg()},"(~ number)\n\n Function that calculates the bitwise inverse (flip all the bits)."),">>":doc(">>",function(e,t){return LNumber(e).shr(t)},"(>> a b)\n\n Function that right shifts the value a by value b bits."),"<<":doc("<<",function(e,t){return LNumber(e).shl(t)},"(<< a b)\n\n Function that left shifts the value a by value b bits."),not:doc("not",function e(t){if(is_null(t)){return true}return!t},"(not object)\n\n Function that returns the Boolean negation of its argument.")},undefined,"global");var user_env=global_env.inherit("user-env");function set_interaction_env(e,t){e.constant("**internal-env**",t);e.doc("**internal-env**","**internal-env**\n\n Constant used to hide stdin, stdout and stderr so they don't interfere\n with variables with the same name. Constants are an internal type\n of variable that can't be redefined, defining a variable with the same name\n will throw an error.");global_env.set("**interaction-environment**",e)}set_interaction_env(user_env,internal_env);global_env.doc("**interaction-environment**","**interaction-environment**\n\n Internal dynamic, global variable used to find interpreter environment.\n It's used so the read and write functions can locate **internal-env**\n that contains the references to stdin, stdout and stderr.");function set_fs(e){user_env.get("**internal-env**").set("fs",e)}(function(){var e={ceil:"ceiling"};["floor","round","ceil"].forEach(function(t){var r=e[t]?e[t]:t;global_env.set(r,doc(r,function(e){typecheck(r,e,"number");if(e instanceof LNumber){return e[t]()}},"(".concat(r," number)\n\n Function that calculates the ").concat(r," of a number.")))})})();function allPossibleCases(e){if(e.length===1){return e[0]}else{var t=[];var r=allPossibleCases(e.slice(1));for(var n=0;n3&&arguments[3]!==undefined?arguments[3]:null;var i=e?" in expression `".concat(e,"`"):"";if(n!==null){i+=" (argument ".concat(n,")")}if(is_function(r)){return"Invalid type: got ".concat(t).concat(i)}if(r instanceof Array){if(r.length===1){var a=r[0].toLowerCase();r="a"+("aeiou".includes(a)?"n ":" ")+r[0]}else{r=new Intl.ListFormat("en",{style:"long",type:"disjunction"}).format(r)}}return"Expecting ".concat(r," got ").concat(t).concat(i)}function typecheck_number(e,t,r){var n=arguments.length>3&&arguments[3]!==undefined?arguments[3]:null;typecheck(e,t,"number",n);var i=t.__type__;var a;if(is_pair(r)){r=r.to_array()}if(r instanceof Array){r=r.map(function(e){return e.valueOf()})}if(r instanceof Array){r=r.map(function(e){return e.valueOf().toLowerCase()});if(r.includes(i)){a=true}}else{r=r.valueOf().toLowerCase()}if(!a&&i!==r){throw new Error(typeErrorMessage(e,i,r,n))}}function typecheck_numbers(r,e,n){e.forEach(function(e,t){typecheck_number(r,e,n,t+1)})}function typecheck_args(r,e,n){e.forEach(function(e,t){typecheck(r,e,n,t+1)})}function typecheck_text_port(e,t,r){typecheck(e,t,r);if(t.__type__===binary_port){throw new Error(typeErrorMessage(e,"binary-port","textual-port"))}}function typecheck(e,t,r){var n=arguments.length>3&&arguments[3]!==undefined?arguments[3]:null;e=e.valueOf();var i=type(t).toLowerCase();if(is_function(r)){if(!r(t)){throw new Error(typeErrorMessage(e,i,r,n))}return}var a=false;if(is_pair(r)){r=r.to_array()}if(r instanceof Array){r=r.map(function(e){return e.valueOf()})}if(r instanceof Array){r=r.map(function(e){return e.valueOf().toLowerCase()});if(r.includes(i)){a=true}}else{r=r.valueOf().toLowerCase()}if(!a&&i!==r){throw new Error(typeErrorMessage(e,i,r,n))}}function memoize(r){var n=new WeakMap;return function(e){var t=n.get(e);if(!t){t=r(e)}return t}}type=memoize(type);function type(e){var t=type_constants.get(e);if(t){return t}if(_typeof$1(e)==="object"){for(var r=0,n=Object.entries(type_mapping);r2&&arguments[2]!==undefined?arguments[2]:{},n=r.env,i=r.dynamic_env,a=r.use_dynamic;var o=n===null||n===void 0?void 0:n.new_frame(e,t);var u=i===null||i===void 0?void 0:i.new_frame(e,t);var s=new LambdaContext({env:o,use_dynamic:a,dynamic_env:u});return resolve_promises(e.apply(s,t))}function apply(n,e){var t=arguments.length>2&&arguments[2]!==undefined?arguments[2]:{},i=t.env,a=t.dynamic_env,o=t.use_dynamic,r=t.error,u=r===void 0?function(){}:r;e=evaluate_args(e,{env:i,dynamic_env:a,error:u,use_dynamic:o});return unpromise(e,function(e){if(is_raw_lambda(n)){n=unbind(n)}e=prepare_fn_args(n,e);var t=e.slice();var r=call_function(n,t,{env:i,dynamic_env:a,use_dynamic:o});return unpromise(r,function(e){if(is_pair(e)){e.markCycles();return quote(e)}return box(e)},u)})}var _p_name__=new WeakMap;var Parameter=function(){function n(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:null;var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:null;_classCallCheck(this,n);_defineProperty(this,"__value__",void 0);_defineProperty(this,"__fn__",void 0);_classPrivateFieldInitSpec(this,_p_name__,{writable:true,value:void 0});this.__value__=e;if(t){if(!is_function(t)){throw new Error("Section argument to Parameter need to be function "+"".concat(type(t)," given"))}this.__fn__=t}if(r){_classPrivateFieldSet(this,_p_name__,r)}}_createClass(n,[{key:"__name__",get:function e(){return _classPrivateFieldGet(this,_p_name__)},set:function e(t){_classPrivateFieldSet(this,_p_name__,t);if(this.__fn__){this.__fn__.__name__="fn-".concat(t)}}},{key:"invoke",value:function e(){if(is_function(this.__fn__)){return this.__fn__(this.__value__)}return this.__value__}},{key:"inherit",value:function e(t){return new n(t,this.__fn__,this.__name__)}}]);return n}();var LambdaContext=function(){function t(e){_classCallCheck(this,t);_defineProperty(this,"env",void 0);_defineProperty(this,"dynamic_env",void 0);_defineProperty(this,"use_dynamic",void 0);Object.assign(this,e)}_createClass(t,[{key:"__name__",get:function e(){return this.env.__name__}},{key:"__parent__",get:function e(){return this.env.__parent__}},{key:"get",value:function e(){var t;return(t=this.env).get.apply(t,arguments)}}]);return t}();function search_param(e,t){var r=e.get(t.__name__,{throwError:false});if(is_parameter(r)&&r!==t){return r}var n=user_env.get("**interaction-environment**");while(true){var i=e.get("parent.frame",{throwError:false});e=i(0);if(e===n){break}r=e.get(t.__name__,{throwError:false});if(is_parameter(r)&&r!==t){return r}}return t}var Continuation=function(){function t(e){_classCallCheck(this,t);_defineProperty(this,"__value__",void 0);this.__value__=e}_createClass(t,[{key:"invoke",value:function e(){if(this.__value__===null){throw new Error("Continuations are not implemented yet")}}}]);return t}();function _evaluate(u){var e=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},s=e.env,c=e.dynamic_env,l=e.use_dynamic,t=e.error,f=t===void 0?noop:t,r=_objectWithoutProperties(e,_excluded6);return function(e){try{if(!is_env(c)){c=s===true?user_env:s||user_env}if(l){s=c}else if(s===true){s=user_env}else{s=s||global_env}var t={env:s,dynamic_env:c,use_dynamic:l,error:f};var r;if(is_null(u)){return u}if(u instanceof LSymbol){return s.get(u)}if(!is_pair(u)){return u}var n=u.car;var e=u.cdr;if(is_pair(n)){r=resolve_promises(_evaluate(n,t));if(is_promise(r)){return r.then(function(e){if(!is_callable(e)){throw new Error(type(e)+" "+s.get("repr")(e)+" is not callable while evaluating "+u.toString())}return _evaluate(new Pair(e,u.cdr),t)})}else if(!is_callable(r)){throw new Error(type(r)+" "+s.get("repr")(r)+" is not callable while evaluating "+u.toString())}}if(n instanceof LSymbol){r=s.get(n)}else if(is_function(n)){r=n}var i;if(r instanceof Syntax){i=evaluate_syntax(r,u,t)}else if(r instanceof Macro){i=evaluate_macro(r,e,t)}else if(is_function(r)){i=apply(r,e,t)}else if(r instanceof SyntaxParameter){i=evaluate_syntax(r._syntax,u,t)}else if(is_parameter(r)){var a=search_param(c,r);if(is_null(u.cdr)){i=a.invoke()}else{return unpromise(_evaluate(u.cdr.car,t),function(e){a.__value__=e})}}else if(is_continuation(r)){i=r.invoke()}else if(is_pair(u)){r=n&&n.toString();throw new Error("".concat(type(n)," ").concat(r," is not a function"))}else{return u}var o=s.get(Symbol["for"]("__promise__"),{throwError:false});if(o===true&&is_promise(i)){i=i.then(function(e){if(is_pair(e)&&!r[__data__]){return _evaluate(e,t)}return e});return new QuotedPromise(i)}return i}catch(e){f&&f.call(s,e,u)}}(r)}var compile=exec_collect(function(e){return e});var exec=exec_collect(function(e,t){return t});function exec_with_stacktrace(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},r=t.env,n=t.dynamic_env,i=t.use_dynamic;return _evaluate(e,{env:r,dynamic_env:n,use_dynamic:i,error:function e(t,r){if(t&&t.message){if(t.message.match(/^Error:/)){var n=/^(Error:)\s*([^:]+:\s*)/;t.message=t.message.replace(n,"$1 $2")}if(r){if(!(t.__code__ instanceof Array)){t.__code__=[]}t.__code__.push(r.toString(true))}}if(!(t instanceof IgnoreException)){throw t}}})}function exec_collect(d){return function(){var t=_asyncToGenerator(function(f){var e=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},_=e.env,p=e.dynamic_env,h=e.use_dynamic;return _regeneratorRuntime.mark(function e(){var r,n,i,a,o,u,s,c,l;return _regeneratorRuntime.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(!is_env(p)){p=_===true?user_env:_||user_env}if(_===true){_=user_env}else{_=_||user_env}r=[];if(!is_pair(f)){t.next=8;break}t.next=6;return exec_with_stacktrace(code,{env:_,dynamic_env:p,use_dynamic:h});case 6:t.t0=t.sent;return t.abrupt("return",[t.t0]);case 8:n=Array.isArray(f)?f:_parse(f);i=false;a=false;t.prev=11;u=_asyncIterator(n);case 13:t.next=15;return u.next();case 15:if(!(i=!(s=t.sent).done)){t.next=31;break}c=s.value;t.next=19;return exec_with_stacktrace(c,{env:_,dynamic_env:p,use_dynamic:h});case 19:l=t.sent;t.t1=r;t.t2=d;t.t3=c;t.next=25;return l;case 25:t.t4=t.sent;t.t5=(0,t.t2)(t.t3,t.t4);t.t1.push.call(t.t1,t.t5);case 28:i=false;t.next=13;break;case 31:t.next=37;break;case 33:t.prev=33;t.t6=t["catch"](11);a=true;o=t.t6;case 37:t.prev=37;t.prev=38;if(!(i&&u["return"]!=null)){t.next=42;break}t.next=42;return u["return"]();case 42:t.prev=42;if(!a){t.next=45;break}throw o;case 45:return t.finish(42);case 46:return t.finish(37);case 47:return t.abrupt("return",r);case 48:case"end":return t.stop()}},e,null,[[11,33,37,47],[38,,42,46]])})()});function e(e){return t.apply(this,arguments)}return e}()}function balanced(e){var t={"[":"]","(":")"};var r;if(typeof e==="string"){r=tokenize(e)}else{r=e.map(function(e){return e&&e.token?e.token:e})}var n=Object.keys(t);var i=Object.values(t).concat(n);r=r.filter(function(e){return i.includes(e)});var a=new Stack;var o=_createForOfIteratorHelper(r),u;try{for(o.s();!(u=o.n()).done;){var s=u.value;if(n.includes(s)){a.push(s)}else if(!a.is_empty()){var c=a.top();var l=t[c];if(s===l){a.pop()}else{throw new Error("Syntax error: missing closing ".concat(l))}}else{throw new Error("Syntax error: not matched closing ".concat(s))}}}catch(e){o.e(e)}finally{o.f()}return a.is_empty()}function fworker(e){var t="("+e.toString()+")()";var r=window.URL||window.webkitURL;var n;try{n=new Blob([t],{type:"application/javascript"})}catch(e){var i=window.BlobBuilder||window.WebKitBlobBuilder||window.MozBlobBuilder;n=new i;n.append(t);n=n.getBlob()}return new root.Worker(r.createObjectURL(n))}function is_dev(){return lips.version.match(/^(\{\{VER\}\}|DEV)$/)}function get_current_script(){if(is_node()){return}var e;if(document.currentScript){e=document.currentScript}else{var t=document.querySelectorAll("script");if(!t.length){return}e=t[t.length-1]}var r=e.getAttribute("src");return r}var current_script=get_current_script();function bootstrap(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:"";var t="dist/std.xcb";if(e===""){if(current_script){e=current_script.replace(/[^/]*$/,"std.xcb")}else if(is_dev()){e="https://cdn.jsdelivr.net/gh/jcubic/lips@devel/".concat(t)}else{e="https://cdn.jsdelivr.net/npm/@jcubic/lips@".concat(lips.version,"/").concat(t)}}var r=global_env.get("load");return r.call(user_env,e,global_env)}function Worker(e){this.url=e;var o=this.worker=fworker(function(){var o;var u;self.addEventListener("message",function(e){var r=e.data;var t=r.id;if(r.type!=="RPC"||t===null){return}function n(e){self.postMessage({id:t,type:"RPC",result:e})}function i(e){self.postMessage({id:t,type:"RPC",error:e})}if(r.method==="eval"){if(!u){i("Worker RPC: LIPS not initialized, call init first");return}u.then(function(){var e=r.params[0];var t=r.params[1];o.exec(e,{use_dynamic:t}).then(function(e){e=e.map(function(e){return e&&e.valueOf()});n(e)})["catch"](function(e){i(e)})})}else if(r.method==="init"){var a=r.params[0];if(typeof a!=="string"){i("Worker RPC: url is not a string")}else{importScripts("".concat(a,"/dist/lips.min.js"));o=new lips.Interpreter("worker");u=bootstrap(a);u.then(function(){n(true)})}}})});this.rpc=function(){var n=0;return function e(t,r){var a=++n;return new Promise(function(n,i){o.addEventListener("message",function e(t){var r=t.data;if(r&&r.type==="RPC"&&r.id===a){if(r.error){i(r.error)}else{n(r.result)}o.removeEventListener("message",e)}});o.postMessage({type:"RPC",method:t,id:a,params:r})})}}();this.rpc("init",[e])["catch"](function(e){console.error(e)});this.exec=function(e,t){var r=t.use_dynamic,n=r===void 0?false:r;return this.rpc("eval",[e,n])}}var serialization_map={pair:function e(t){var r=_slicedToArray(t,2),n=r[0],i=r[1];return Pair(n,i)},number:function e(t){if(LString.isString(t)){return LNumber([t,10])}return LNumber(t)},regex:function e(t){var r=_slicedToArray(t,2),n=r[0],i=r[1];return new RegExp(n,i)},nil:function e(){return _nil},symbol:function e(t){if(LString.isString(t)){return LSymbol(t)}else if(Array.isArray(t)){return LSymbol(Symbol["for"](t[0]))}},string:LString,character:LCharacter};var available_class=Object.keys(serialization_map);var class_map={};for(var _i6=0,_Object$entries3=Object.entries(available_class);_i6<_Object$entries3.length;_i6++){var _Object$entries3$_i=_slicedToArray(_Object$entries3[_i6],2),i=_Object$entries3$_i[0],cls=_Object$entries3$_i[1];class_map[cls]=+i}function mangle_name(e){return class_map[e]}function resolve_name(e){return available_class[e]}function serialize(e){return JSON.stringify(e,function(e,t){var r=this[e];if(r){if(r instanceof RegExp){return{"@":mangle_name("regex"),"#":[r.source,r.flags]}}var n=mangle_name(r.constructor.__class__);if(!is_undef(n)){return{"@":n,"#":r.serialize()}}}return t})}function unserialize(e){return JSON.parse(e,function(e,t){if(t&&_typeof$1(t)==="object"){if(!is_undef(t["@"])){var r=resolve_name(t["@"]);if(serialization_map[r]){return serialization_map[r](t["#"])}}}return t})}var cbor=function(){var e={pair:Pair,symbol:LSymbol,number:LNumber,string:LString,character:LCharacter,nil:_nil.constructor,regex:RegExp};function t(e,t){return{deserialize:t,Class:e}}var r=new Encoder;var a={};for(var n=0,i=Object.entries(serialization_map);n1){var n=t.reduce(function(e,t){return e+t.length},0);var i=new Uint8Array(n);var a=0;t.forEach(function(e){i.set(e,a);a+=e.length});return i}else if(t.length){return t[0]}}function encode_magic(){var e=1;var t=new TextEncoder("utf-8");return t.encode("LIPS".concat(e.toString().padStart(3," ")))}var MAGIC_LENGTH=7;function decode_magic(e){var t=new TextDecoder("utf-8");var r=t.decode(e.slice(0,MAGIC_LENGTH));var n=r.substring(0,4);if(n==="LIPS"){var i=r.match(/^(....).*([0-9]+)$/);if(i){return{type:i[1],version:Number(i[2])}}}return{type:"unknown"}}function serialize_bin(e){var t=encode_magic();var r=cbor.encode(e);return merge_uint8_array(t,pack_1(r,{magic:false}))}function unserialize_bin(e){var t=decode_magic(e),r=t.type,n=t.version;if(r==="LIPS"&&n===1){var i=unpack_1(e.slice(MAGIC_LENGTH),{magic:false});return cbor.decode(i)}else{throw new Error("Invalid file format ".concat(r))}}function execError(e){console.error(e.message||e);if(Array.isArray(e.code)){console.error(e.code.map(function(e,t){return"[".concat(t+1,"]: ").concat(e)}))}}function init(){var u=["text/x-lips","text/x-scheme"];var s;function c(r){return new Promise(function(t){var e=r.getAttribute("src");if(e){return fetch(e).then(function(e){return e.text()}).then(exec).then(t)["catch"](function(e){execError(e);t()})}else{return exec(r.innerHTML).then(t)["catch"](function(e){execError(e);t()})}})}function e(){return new Promise(function(a){var o=Array.from(document.querySelectorAll("script"));return function e(){var t=o.shift();if(!t){a()}else{var r=t.getAttribute("type");if(u.includes(r)){var n;var i=(n=t.getAttribute("bootstrap"))!==null&&n!==void 0?n:t.getAttribute("data-bootstrap");if(!s&&typeof i==="string"){return bootstrap(i).then(function(){return c(t)}).then(e)}else{return c(t).then(e)}}else if(r&&r.match(/lips|lisp/)){console.warn("Expecting "+u.join(" or ")+" found "+r)}return e()}}()})}if(!window.document){return Promise.resolve()}else if(currentScript){var t=currentScript;var r=t.getAttribute("bootstrap");if(typeof r==="string"){return bootstrap(r).then(function(){s=true;return e()})}}return e()}var currentScript=typeof window!=="undefined"&&window.document&&document.currentScript;if(typeof window!=="undefined"){contentLoaded(window,init)}var banner=function(){var e=LString("Mon, 12 Feb 2024 14:25:33 +0000").valueOf();var t=e==="{{"+"DATE}}"?new Date:new Date(e);var r=function e(t){return t.toString().padStart(2,"0")};var n=t.getFullYear();var i=[n,r(t.getMonth()+1),r(t.getDate())].join("-");var a="\n __ __ __\n / / \\ \\ _ _ ___ ___ \\ \\\n| | \\ \\ | | | || . \\/ __> | |\n| | > \\ | |_ | || _/\\__ \\ | |\n| | / ^ \\ |___||_||_| <___/ | |\n \\_\\ /_/ \\_\\ /_/\n\nLIPS Interpreter DEV (".concat(i,") \nCopyright (c) 2018-").concat(n," Jakub T. Jankiewicz\n\nType (env) to see environment with functions macros and variables. You can also\nuse (help name) to display help for specific function or macro, (apropos name)\nto display list of matched names in environment and (dir object) to list\nproperties of an object.\n").replace(/^.*\n/,"");return a}();read_only(Ahead,"__class__","ahead");read_only(Pair,"__class__","pair");read_only(Nil,"__class__","nil");read_only(Pattern,"__class__","pattern");read_only(Formatter,"__class__","formatter");read_only(Macro,"__class__","macro");read_only(Syntax,"__class__","syntax");read_only(Syntax.Parameter,"__class__","syntax-parameter");read_only(Environment,"__class__","environment");read_only(InputPort,"__class__","input-port");read_only(OutputPort,"__class__","output-port");read_only(BufferedOutputPort,"__class__","output-port");read_only(OutputStringPort,"__class__","output-string-port");read_only(InputStringPort,"__class__","input-string-port");read_only(InputFilePort,"__class__","input-file-port");read_only(OutputFilePort,"__class__","output-file-port");read_only(LipsError,"__class__","lips-error");[LNumber,LComplex,LRational,LFloat,LBigInteger].forEach(function(e){read_only(e,"__class__","number")});read_only(LCharacter,"__class__","character");read_only(LSymbol,"__class__","symbol");read_only(LString,"__class__","string");read_only(QuotedPromise,"__class__","promise");read_only(Parameter,"__class__","parameter");var version="DEV";var date="Mon, 12 Feb 2024 14:25:33 +0000";var parse=compose(uniterate_async,_parse);var lips={version:version,banner:banner,date:date,exec:exec,parse:parse,tokenize:tokenize,evaluate:_evaluate,compile:compile,serialize:serialize,unserialize:unserialize,serialize_bin:serialize_bin,unserialize_bin:unserialize_bin,bootstrap:bootstrap,Environment:Environment,env:user_env,Worker:Worker,Interpreter:Interpreter,balanced_parenthesis:balanced,balancedParenthesis:balanced,balanced:balanced,Macro:Macro,Syntax:Syntax,Pair:Pair,Values:Values,QuotedPromise:QuotedPromise,Error:LipsError,quote:quote,InputPort:InputPort,OutputPort:OutputPort,BufferedOutputPort:BufferedOutputPort,InputFilePort:InputFilePort,OutputFilePort:OutputFilePort,InputStringPort:InputStringPort,OutputStringPort:OutputStringPort,InputByteVectorPort:InputByteVectorPort,OutputByteVectorPort:OutputByteVectorPort,InputBinaryFilePort:InputBinaryFilePort,OutputBinaryFilePort:OutputBinaryFilePort,set_fs:set_fs,Formatter:Formatter,Parser:Parser,Lexer:Lexer,specials:specials,repr:repr,nil:_nil,eof:eof,LSymbol:LSymbol,LNumber:LNumber,LFloat:LFloat,LComplex:LComplex,LRational:LRational,LBigInteger:LBigInteger,LCharacter:LCharacter,LString:LString,Parameter:Parameter,rationalize:rationalize};global_env.set("lips",lips);var empty={};var empty$1=Object.freeze({__proto__:null,default:empty});function normalizeArray(e,t){var r=0;for(var n=e.length-1;n>=0;n--){var i=e[n];if(i==="."){e.splice(n,1)}else if(i===".."){e.splice(n,1);r++}else if(r){e.splice(n,1);r--}}if(t){for(;r--;r){e.unshift("..")}}return e}var splitPathRe=/^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/;var splitPath=function(e){return splitPathRe.exec(e).slice(1)};function resolve(){var e="",t=false;for(var r=arguments.length-1;r>=-1&&!t;r--){var n=r>=0?arguments[r]:"/";if(typeof n!=="string"){throw new TypeError("Arguments to path.resolve must be strings")}else if(!n){continue}e=n+"/"+e;t=n.charAt(0)==="/"}e=normalizeArray(filter(e.split("/"),function(e){return!!e}),!t).join("/");return(t?"/":"")+e||"."}function normalize(e){var t=isAbsolute(e),r=substr(e,-1)==="/";e=normalizeArray(filter(e.split("/"),function(e){return!!e}),!t).join("/");if(!e&&!t){e="."}if(e&&r){e+="/"}return(t?"/":"")+e}function isAbsolute(e){return e.charAt(0)==="/"}function join(){var e=Array.prototype.slice.call(arguments,0);return normalize(filter(e,function(e,t){if(typeof e!=="string"){throw new TypeError("Arguments to path.join must be strings")}return e}).join("/"))}function relative(e,t){e=resolve(e).substr(1);t=resolve(t).substr(1);function r(e){var t=0;for(;t=0;r--){if(e[r]!=="")break}if(t>r)return[];return e.slice(t,r-t+1)}var n=r(e.split("/"));var i=r(t.split("/"));var a=Math.min(n.length,i.length);var o=a;for(var u=0;u 0 && arguments[0] !== undefined ? arguments[0] : true; var visited = new Map(); function clone(node) { - if (node instanceof Pair) { + if (is_pair(node)) { if (visited.has(node)) { return visited.get(node); } @@ -8383,7 +8383,7 @@ Pair.prototype.to_array = function () { var deep = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true; var result = []; - if (this.car instanceof Pair) { + if (is_pair(this.car)) { if (deep) { result.push(this.car.to_array()); } else { @@ -8392,7 +8392,7 @@ } else { result.push(this.car.valueOf()); } - if (this.cdr instanceof Pair) { + if (is_pair(this.cdr)) { result = result.concat(this.cdr.to_array(deep)); } return result; @@ -8404,7 +8404,7 @@ Pair.fromArray = function (array) { var deep = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; var quote = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; - if (array instanceof Pair || quote && array instanceof Array && array[__data__]) { + if (is_pair(array) || quote && array instanceof Array && array[__data__]) { return array; } if (deep === false) { @@ -8443,7 +8443,7 @@ var node = this; var result = {}; while (true) { - if (node instanceof Pair && node.car instanceof Pair) { + if (is_pair(node) && is_pair(node.car)) { var pair = node.car; var name = pair.car; if (name instanceof LSymbol) { @@ -8453,7 +8453,7 @@ name = name.valueOf(); } var cdr = pair.cdr; - if (cdr instanceof Pair) { + if (is_pair(cdr)) { cdr = cdr.to_object(literal); } if (is_native(cdr)) { @@ -8490,7 +8490,7 @@ var node = this; var result = _nil; while (true) { - if (node !== _nil) { + if (!is_nil(node)) { result = fn(result, node.car); node = node.cdr; } else { @@ -8507,7 +8507,7 @@ } var node = this; var prev = _nil; - while (node !== _nil) { + while (!is_nil(node)) { var next = node.cdr; node.cdr = prev; prev = node; @@ -8519,17 +8519,17 @@ // ---------------------------------------------------------------------- Pair.prototype.transform = function (fn) { function recur(pair) { - if (pair instanceof Pair) { + if (is_pair(pair)) { if (pair.replace) { delete pair.replace; return pair; } var car = fn(pair.car); - if (car instanceof Pair) { + if (is_pair(car)) { car = recur(car); } var cdr = fn(pair.cdr); - if (cdr instanceof Pair) { + if (is_pair(cdr)) { cdr = recur(cdr); } return new Pair(car, cdr); @@ -8542,7 +8542,7 @@ // ---------------------------------------------------------------------- Pair.prototype.map = function (fn) { if (typeof this.car !== 'undefined') { - return new Pair(fn(this.car), this.cdr === _nil ? _nil : this.cdr.map(fn)); + return new Pair(fn(this.car), is_nil(this.cdr) ? _nil : this.cdr.map(fn)); } else { return _nil; } @@ -8837,7 +8837,7 @@ } } function set(node, type, child, parents) { - if (child instanceof Pair) { + if (is_pair(child)) { if (parents.includes(child)) { if (!refs.includes(child)) { refs.push(child); @@ -8854,7 +8854,7 @@ } } var detect = trampoline(function detect_thunk(pair, parents) { - if (pair instanceof Pair) { + if (is_pair(pair)) { delete pair.ref; delete pair[__cycles__]; visit(pair); @@ -8872,7 +8872,7 @@ } }); function mark_node(node, type) { - if (node[__cycles__][type] instanceof Pair) { + if (is_pair(node[__cycles__][type])) { var count = ref_nodes.indexOf(node[__cycles__][type]); node[__cycles__][type] = "#".concat(count, "#"); } @@ -8910,7 +8910,7 @@ if (value !== undefined) { arr.push(value); } - if (this.cdr instanceof Pair) { + if (is_pair(this.cdr)) { if (this[__cycles__] && this[__cycles__].cdr) { arr.push(' . '); arr.push(this[__cycles__].cdr); @@ -8925,7 +8925,7 @@ }); arr.push(cdr); } - } else if (this.cdr !== _nil) { + } else if (!is_nil(this.cdr)) { arr = arr.concat([' . ', toString(this.cdr, quote, true)]); } if (!nested || this[__ref__]) { @@ -8937,7 +8937,7 @@ // ---------------------------------------------------------------------- Pair.prototype.set = function (prop, value) { this[prop] = value; - if (value instanceof Pair) { + if (is_pair(value)) { this.markCycles(); } }; @@ -8949,15 +8949,15 @@ } var p = this; if (p.car === undefined) { - if (arg instanceof Pair) { + if (is_pair(arg)) { this.car = arg.car; this.cdr = arg.cdr; } else { this.car = arg; } - } else if (arg !== _nil) { + } else if (!is_nil(arg)) { while (true) { - if (p instanceof Pair && p.cdr !== _nil) { + if (is_pair(p) && !is_nil(p.cdr)) { p = p.cdr; } else { break; @@ -8980,7 +8980,7 @@ next: function next() { var cur = node; node = cur.cdr; - if (cur === _nil) { + if (is_nil(cur)) { return { value: undefined, done: true @@ -9084,7 +9084,7 @@ } // ---------------------------------------------------------------------- function is_atom(obj) { - return obj instanceof LSymbol || LString.isString(obj) || obj === _nil || obj === null || obj instanceof LCharacter || obj instanceof LNumber || obj === true || obj === false; + return obj instanceof LSymbol || LString.isString(obj) || is_nil(obj) || obj === null || obj instanceof LCharacter || obj instanceof LNumber || obj === true || obj === false; } // ---------------------------------------------------------------------- var truncate = function () { @@ -9159,7 +9159,7 @@ return _regeneratorRuntime.wrap(function _callee11$(_context11) { while (1) switch (_context11.prev = _context11.next) { case 0: - if (!(node instanceof Pair && node.car instanceof LSymbol)) { + if (!(is_pair(node) && node.car instanceof LSymbol)) { _context11.next = 50; break; } @@ -9175,7 +9175,7 @@ }); is_let = is_let_macro(node.car); is_binding = is_let || is_procedure(value, node) || is_lambda(value); - if (!(is_binding && node.cdr.car instanceof Pair)) { + if (!(is_binding && is_pair(node.cdr.car))) { _context11.next = 28; break; } @@ -9221,7 +9221,7 @@ break; } _result = result, expr = _result.expr, scope = _result.scope; - if (!(expr instanceof Pair)) { + if (!is_pair(expr)) { _context11.next = 40; break; } @@ -9244,7 +9244,7 @@ } return _context11.abrupt("return", quote(result)); case 43: - if (!(result instanceof Pair)) { + if (!is_pair(result)) { _context11.next = 48; break; } @@ -9267,7 +9267,7 @@ case 50: // TODO: CYCLE DETECT car = node.car; - if (!(car instanceof Pair)) { + if (!is_pair(car)) { _context11.next = 55; break; } @@ -9277,7 +9277,7 @@ car = _context11.sent; case 55: cdr = node.cdr; - if (!(cdr instanceof Pair)) { + if (!is_pair(cdr)) { _context11.next = 60; break; } @@ -9305,7 +9305,7 @@ return _regeneratorRuntime.wrap(function _callee10$(_context10) { while (1) switch (_context10.prev = _context10.next) { case 0: - if (!(node === _nil)) { + if (!is_nil(node)) { _context10.next = 2; break; } @@ -9341,7 +9341,7 @@ }; let_binding = function _let_binding(node) { return [].concat(_toConsumableArray(bindings), _toConsumableArray(node.to_array(false).map(function (node) { - if (node instanceof Pair) { + if (is_pair(node)) { return node.car.valueOf(); } var t = type(node); @@ -9352,7 +9352,7 @@ proc_bindings = function _proc_bindings(node) { var names = []; while (true) { - if (node !== _nil) { + if (!is_nil(node)) { if (node instanceof LSymbol) { names.push(node.valueOf()); break; @@ -9369,7 +9369,7 @@ return value === lambda; }; is_procedure = function _is_procedure(value, node) { - return value === define && node.cdr.car instanceof Pair; + return value === define && is_pair(node.cdr.car); }; is_let_macro = function _is_let_macro(symbol) { var name = symbol.valueOf(); @@ -9380,7 +9380,7 @@ let_macros = ['let', 'let*', 'letrec']; lambda = global_env.get('lambda'); define = global_env.get('define'); //var this.__code__ = code; - if (!(code.cdr instanceof Pair && LNumber.isNumber(code.cdr.car))) { + if (!(is_pair(code.cdr) && LNumber.isNumber(code.cdr.car))) { _context12.next = 21; break; } @@ -9555,9 +9555,9 @@ return first && rest; } // pattern (a b (x ...)) and (x ...) match nil - if (pattern instanceof Pair && pattern.car instanceof Pair && pattern.car.cdr instanceof Pair && LSymbol.is(pattern.car.cdr.car, ellipsis_symbol)) { + if (is_pair(pattern) && is_pair(pattern.car) && is_pair(pattern.car.cdr) && LSymbol.is(pattern.car.cdr.car, ellipsis_symbol)) { log('>> 0'); - if (code === _nil) { + if (is_nil(code)) { log({ pattern: pattern }); @@ -9570,10 +9570,10 @@ } } } - if (pattern instanceof Pair && pattern.cdr instanceof Pair && LSymbol.is(pattern.cdr.car, ellipsis_symbol)) { + if (is_pair(pattern) && is_pair(pattern.cdr) && LSymbol.is(pattern.cdr.car, ellipsis_symbol)) { // pattern (... ???) - SRFI-46 - if (pattern.cdr.cdr !== _nil) { - if (pattern.cdr.cdr instanceof Pair) { + if (!is_nil(pattern.cdr.cdr)) { + if (is_pair(pattern.cdr.cdr)) { // if we have (x ... a b) we need to remove two from the end var list_len = pattern.cdr.cdr.length(); if (!is_pair(code)) { @@ -9598,7 +9598,7 @@ throw new Error('syntax: named ellipsis can only appear onces'); } log('>> 1'); - if (code === _nil) { + if (is_nil(code)) { log('>> 2'); if (ellipsis) { log('NIL'); @@ -9607,12 +9607,12 @@ log('NULL'); bindings['...'].symbols[_name3] = null; } - } else if (code instanceof Pair && (code.car instanceof Pair || code.car === _nil)) { + } else if (is_pair(code) && (is_pair(code.car) || is_nil(code.car))) { log('>> 3 ' + ellipsis); if (ellipsis) { if (bindings['...'].symbols[_name3]) { var _node = bindings['...'].symbols[_name3]; - if (_node === _nil) { + if (is_nil(_node)) { _node = new Pair(_nil, new Pair(code, _nil)); } else { _node = _node.append(new Pair(code, _nil)); @@ -9627,11 +9627,11 @@ } } else { log('>> 6'); - if (code instanceof Pair) { + if (is_pair(code)) { // cons (a . b) => (var ... . x) - if (!(code.cdr instanceof Pair) && code.cdr !== _nil) { + if (!is_pair(code.cdr) && !is_nil(code.cdr)) { log('>> 7 (b)'); - if (pattern.cdr.cdr === _nil) { + if (is_nil(pattern.cdr.cdr)) { return false; } else if (!bindings['...'].symbols[_name3]) { bindings['...'].symbols[_name3] = new Pair(code.car, _nil); @@ -9640,8 +9640,8 @@ } // code as improper list var last_pair = code.last_pair(); - if (last_pair.cdr !== _nil) { - if (pattern.cdr.cdr === _nil) { + if (!is_nil(last_pair.cdr)) { + if (is_nil(pattern.cdr.cdr)) { // case (a ...) for (a b . x) return false; } else { @@ -9663,7 +9663,7 @@ log({ IIIIII: bindings['...'].symbols[_name3] }); - } else if (pattern.car instanceof LSymbol && pattern.cdr instanceof Pair && LSymbol.is(pattern.cdr.car, ellipsis_symbol)) { + } else if (pattern.car instanceof LSymbol && is_pair(pattern.cdr) && LSymbol.is(pattern.cdr.car, ellipsis_symbol)) { // empty ellipsis with rest (a b ... . d) #290 log('>> 8'); bindings['...'].symbols[_name3] = null; @@ -9675,16 +9675,16 @@ } } return true; - } else if (pattern.car instanceof Pair) { + } else if (is_pair(pattern.car)) { var names = _toConsumableArray(pattern_names); - if (code === _nil) { + if (is_nil(code)) { log('>> 10'); bindings['...'].lists.push(_nil); return true; } log('>> 11'); var _node3 = code; - while (_node3 instanceof Pair) { + while (is_pair(_node3)) { if (!traverse(pattern.car, _node3.car, names, true)) { return false; } @@ -9695,7 +9695,7 @@ if (Array.isArray(pattern.car)) { var names = _toConsumableArray(pattern_names); var _node4 = code; - while (_node4 instanceof Pair) { + while (is_pair(_node4)) { if (!traverse(pattern.car, _node4.car, names, true)) { return false; } @@ -9724,14 +9724,14 @@ } return true; } - if (pattern instanceof Pair && code instanceof Pair) { + if (is_pair(pattern) && is_pair(code)) { log('>> 13'); log({ a: 13, code: code, pattern: pattern }); - if (code.cdr === _nil) { + if (is_nil(code.cdr)) { // last item in in call using in recursive calls on // last element of the list // case of pattern (p . rest) and code (0) @@ -9759,7 +9759,7 @@ code: code }); // case (x y) ===> (var0 var1 ... warn) where var1 match nil - if (pattern.cdr instanceof Pair && pattern.cdr.cdr instanceof Pair && pattern.cdr.car instanceof LSymbol && LSymbol.is(pattern.cdr.cdr.car, ellipsis_symbol) && pattern.cdr.cdr.cdr instanceof Pair && !LSymbol.is(pattern.cdr.cdr.cdr.car, ellipsis_symbol) && traverse(pattern.car, code.car, pattern_names, ellipsis) && traverse(pattern.cdr.cdr.cdr, code.cdr, pattern_names, ellipsis)) { + if (is_pair(pattern.cdr) && is_pair(pattern.cdr.cdr) && pattern.cdr.car instanceof LSymbol && LSymbol.is(pattern.cdr.cdr.car, ellipsis_symbol) && is_pair(pattern.cdr.cdr.cdr) && !LSymbol.is(pattern.cdr.cdr.cdr.car, ellipsis_symbol) && traverse(pattern.car, code.car, pattern_names, ellipsis) && traverse(pattern.cdr.cdr.cdr, code.cdr, pattern_names, ellipsis)) { var _name6 = pattern.cdr.car.__name__; log({ pattern: pattern, @@ -9791,11 +9791,11 @@ if (car && cdr) { return true; } - } else if (pattern === _nil && (code === _nil || code === undefined)) { + } else if (is_nil(pattern) && (is_nil(code) || code === undefined)) { // undefined is case when you don't have body ... // and you do recursive call return true; - } else if (pattern.car instanceof Pair && LSymbol.is(pattern.car.car, ellipsis_symbol)) { + } else if (is_pair(pattern.car) && LSymbol.is(pattern.car.car, ellipsis_symbol)) { // pattern (...) throw new Error('syntax: invalid usage of ellipsis'); } else { @@ -9814,7 +9814,7 @@ // ---------------------------------------------------------------------- function clear_gensyms(node, gensyms) { function traverse(node) { - if (node instanceof Pair) { + if (is_pair(node)) { if (!gensyms.length) { return node; } @@ -9944,19 +9944,19 @@ if (is_gensym(expr) && !bindings[name]) ; log('[t 1'); if (bindings[name]) { - if (bindings[name] instanceof Pair) { + if (is_pair(bindings[name])) { var _bindings$name = bindings[name], car = _bindings$name.car, cdr = _bindings$name.cdr; if (nested) { var caar = car.car, cadr = car.cdr; - if (cadr !== _nil) { + if (!is_nil(cadr)) { next(name, new Pair(cadr, _nil)); } return caar; } - if (cdr !== _nil) { + if (!is_nil(cdr)) { next(name, cdr); } return car; @@ -9968,7 +9968,7 @@ return transform(expr); } var is_array = Array.isArray(expr); - if (expr instanceof Pair || is_array) { + if (is_pair(expr) || is_array) { var first = is_array ? expr[0] : expr.car; var second = is_array ? expr[1] : is_pair(expr.cdr) && expr.cdr.car; if (first instanceof LSymbol && LSymbol.is(second, ellipsis_symbol)) { @@ -9983,17 +9983,17 @@ name: _name7, binding: bindings[_name7] }); - if (item instanceof Pair) { + if (is_pair(item)) { log('[t 2 Pair ' + nested); var _car = item.car, _cdr = item.cdr; var _rest_expr = is_array ? expr.slice(2) : expr.cdr.cdr; if (nested) { - if (_cdr !== _nil) { + if (!is_nil(_cdr)) { log('|| next 1'); next(_name7, _cdr); } - if (is_array && _rest_expr.length || _rest_expr !== _nil && !is_array) { + if (is_array && _rest_expr.length || !is_nil(_rest_expr) && !is_array) { var _rest7 = transform_ellipsis_expr(_rest_expr, bindings, state, next); if (is_array) { return _car.concat(_rest7); @@ -10004,13 +10004,13 @@ } } return _car; - } else if (_car instanceof Pair) { - if (_car.cdr !== _nil) { + } else if (is_pair(_car)) { + if (!is_nil(_car.cdr)) { log('|| next 2'); next(_name7, new Pair(_car.cdr, _cdr)); } return _car.car; - } else if (_cdr === _nil) { + } else if (is_nil(_cdr)) { return _car; } else { var last_pair = expr.last_pair(); @@ -10064,7 +10064,7 @@ if (x === null) { return !skip_nulls; } - return x instanceof Pair || x === _nil || x instanceof Array && x.length; + return is_pair(x) || is_nil(x) || Array.isArray(x) && x.length; }); } function get_names(object) { @@ -10079,7 +10079,7 @@ if (is_array && expr.length === 0) { return expr; } - if (expr instanceof Pair || is_array) { + if (is_pair(expr) || is_array) { var first = is_array ? expr[0] : expr.car; var second, rest_second; if (is_array) { @@ -10127,7 +10127,7 @@ // lists is free ellipsis on pairs ((???) ...) // TODO: will this work in every case? Do we need to handle // nesting here? - if (bindings['...'].lists[0] === _nil) { + if (is_nil(bindings['...'].lists[0])) { if (!is_spread) { return traverse(rest_second, { disabled: disabled @@ -10175,7 +10175,7 @@ log('ZONK {1}'); } } else { - if (result === _nil) { + if (is_nil(result)) { result = car; } else { result = result.append(car); @@ -10192,7 +10192,7 @@ while (true) { if (_loop()) break; } - if (result !== _nil && !is_spread && !is_array) { + if (!is_nil(result) && !is_spread && !is_array) { result = result.reverse(); } // case of (list) ... (rest code) @@ -10209,7 +10209,7 @@ } return result; } - if (expr.cdr.cdr !== _nil && !LSymbol.is(expr.cdr.cdr.car, ellipsis_symbol)) { + if (!is_nil(expr.cdr.cdr) && !LSymbol.is(expr.cdr.cdr.car, ellipsis_symbol)) { var _rest10 = traverse(expr.cdr.cdr, { disabled: disabled }); @@ -10271,14 +10271,14 @@ while (true) { if (_loop2()) break; } - if (_result3 !== _nil && !is_array) { + if (!is_nil(_result3) && !is_array) { _result3 = _result3.reverse(); } // case if (x ... y ...) second spread is not processed // and (??? . x) last symbol // by ellipsis transformation - if (expr.cdr instanceof Pair) { - if (expr.cdr.cdr instanceof Pair || expr.cdr.cdr instanceof LSymbol) { + if (is_pair(expr.cdr)) { + if (is_pair(expr.cdr.cdr) || expr.cdr.cdr instanceof LSymbol) { var node = traverse(expr.cdr.cdr, { disabled: disabled }); @@ -10288,7 +10288,7 @@ if (_is_null) { return node; } - if (_result3 === _nil) { + if (is_nil(_result3)) { _result3 = node; } else { _result3.append(node); @@ -10364,7 +10364,11 @@ // :: Check for nullish values // ---------------------------------------------------------------------- function is_null(value) { - return is_undef(value) || value === _nil || value === null; + return is_undef(value) || is_nil(value) || value === null; + } + // ---------------------------------------------------------------------- + function is_nil(value) { + return value === _nil; } // ---------------------------------------------------------------------- function is_function(o) { @@ -10502,7 +10506,7 @@ } // ---------------------------------------------------------------------- function patch_value(value, context) { - if (value instanceof Pair) { + if (is_pair(value)) { value.markCycles(); return quote(value); } @@ -10695,11 +10699,11 @@ // named let: // (let iter ((x 10)) (iter (- x 1))) -> (let* ((iter (lambda (x) ... if (code.car instanceof LSymbol) { - if (!(code.cdr.car instanceof Pair || code.cdr.car === _nil)) { + if (!(is_pair(code.cdr.car) || is_nil(code.cdr.car))) { throw new Error('let require list of pairs'); } var params; - if (code.cdr.car === _nil) { + if (is_nil(code.cdr.car)) { args = _nil; params = _nil; } else { @@ -10811,7 +10815,7 @@ var dynamic_env = this; var results = []; var node = code; - while (node instanceof Pair) { + while (is_pair(node)) { results.push(_evaluate(node.car, { env: env, dynamic_env: dynamic_env, @@ -13504,7 +13508,7 @@ if (is_promise(value)) { return value.then(quote); } - if (value instanceof Pair || value instanceof LSymbol) { + if (is_pair(value) || value instanceof LSymbol) { value[__data__] = true; } return value; @@ -13711,7 +13715,7 @@ }(), "(read [string])\n\n This function, if used with a string, will parse it and\n return the LIPS code, if there is any. If called with a\n port, it will parse the next item from the port. If called\n without an input, it will read a string from standard input\n (using the browser's prompt or a user defined input method)\n and calls itself with that string. This function can be used\n together with `eval` to evaluate code from a string."), // ------------------------------------------------------------------ pprint: doc('pprint', function pprint(arg) { - if (arg instanceof Pair) { + if (is_pair(arg)) { arg = new lips.Formatter(arg.toString(true))["break"]().format(); global_env.get('display').call(global_env, arg); } else { @@ -13819,7 +13823,7 @@ var symbol; if (code.car instanceof LSymbol) { symbol = code.car; - } else if (code.car instanceof Pair && code.car.car instanceof LSymbol) { + } else if (is_pair(code.car) && code.car.car instanceof LSymbol) { symbol = code.car.car; } else { var env = this; @@ -13898,7 +13902,7 @@ env.get('set-obj!').call(env, object, key, value); return value; } - if (code.car instanceof Pair && LSymbol.is(code.car.car, '.')) { + if (is_pair(code.car) && LSymbol.is(code.car.car, '.')) { var second = code.car.cdr.car; var third = code.car.cdr.cdr.car; var object = _evaluate(second, eval_args); @@ -13955,7 +13959,7 @@ }, "(set-cdr! obj value)\n\n Function that sets the cdr (tail) of the list/pair to specified value.\n It will destroy the list. The old tail is lost."), // ------------------------------------------------------------------ 'empty?': doc('empty?', function (x) { - return typeof x === 'undefined' || x === _nil; + return typeof x === 'undefined' || is_nil(x); }, "(empty? object)\n\n Function that returns #t if value is nil (an empty list) or undefined."), // ------------------------------------------------------------------ gensym: doc('gensym', gensym, "(gensym)\n\n Generates a unique symbol that is not bound anywhere,\n to use with macros as meta name."), @@ -14040,7 +14044,7 @@ case 10: _args19 = _context17.sent; case 11: - if (_args19 && _args19 !== _nil) { + if (_args19 && !is_nil(_args19)) { process.cwd(); file = path.join(path.dirname(_args19.car.valueOf()), file); } @@ -14115,7 +14119,7 @@ vars = code.car; test = code.cdr.car; body = code.cdr.cdr; - if (body !== _nil) { + if (!is_nil(body)) { body = new Pair(LSymbol('begin'), body); } eval_args = { @@ -14126,7 +14130,7 @@ }; node = vars; case 9: - if (!(node !== _nil)) { + if (is_nil(node)) { _context19.next = 20; break; } @@ -14152,7 +14156,7 @@ return _regeneratorRuntime.wrap(function _loop3$(_context18) { while (1) switch (_context18.prev = _context18.next) { case 0: - if (!(body !== _nil)) { + if (is_nil(body)) { _context18.next = 3; break; } @@ -14162,12 +14166,12 @@ node = vars; next = {}; case 5: - if (!(node !== _nil)) { + if (is_nil(node)) { _context18.next = 15; break; } _item = node.car; - if (!(_item.cdr.cdr !== _nil)) { + if (is_nil(_item.cdr.cdr)) { _context18.next = 12; break; } @@ -14205,7 +14209,7 @@ _context19.next = 22; break; case 29: - if (!(test.cdr !== _nil)) { + if (is_nil(test.cdr)) { _context19.next = 33; break; } @@ -14243,7 +14247,7 @@ return _evaluate(code.cdr.car, eval_args); } }; - if (code === _nil) { + if (is_nil(code)) { throw new Error('too few expressions for `if`'); } var cond = _evaluate(code.car, eval_args); @@ -14287,7 +14291,7 @@ shuffle: doc('shuffle', function (arg) { typecheck('shuffle', arg, ['pair', 'nil', 'array']); var random = global_env.get('random'); - if (arg === _nil) { + if (is_nil(arg)) { return _nil; } if (Array.isArray(arg)) { @@ -14380,7 +14384,7 @@ eval_args.dynamic_env; var init = _evaluate(code.car, eval_args); var fn; - if (code.cdr.car instanceof Pair) { + if (is_pair(code.cdr.car)) { fn = _evaluate(code.cdr.car, eval_args); } return new Parameter(init, fn); @@ -14401,7 +14405,7 @@ syntax.__name__ = syntax.__name__.valueOf(); } var __doc__; - if (code.cdr.cdr instanceof Pair && LString.isString(code.cdr.cdr.car)) { + if (is_pair(code.cdr.cdr) && LString.isString(code.cdr.cdr.car)) { __doc__ = code.cdr.cdr.car.valueOf(); } env.set(code.car, new SyntaxParameter(syntax), __doc__, true); @@ -14448,7 +14452,7 @@ // ------------------------------------------------------------------ define: doc(Macro.defmacro('define', function (code, eval_args) { var env = this; - if (code.car instanceof Pair && code.car.car instanceof LSymbol) { + if (is_pair(code.car) && code.car.car instanceof LSymbol) { var new_code = new Pair(new LSymbol("define"), new Pair(code.car.car, new Pair(new Pair(new LSymbol("lambda"), new Pair(code.car.cdr, code.cdr))))); return new_code; } else if (eval_args.macro_expand) { @@ -14459,7 +14463,7 @@ eval_args.env = env; var value = code.cdr.car; var new_expr; - if (value instanceof Pair) { + if (is_pair(value)) { value = _evaluate(value, eval_args); new_expr = true; } else if (value instanceof LSymbol) { @@ -14477,7 +14481,7 @@ } } var __doc__; - if (code.cdr.cdr instanceof Pair && LString.isString(code.cdr.cdr.car)) { + if (is_pair(code.cdr.cdr) && LString.isString(code.cdr.cdr.car)) { __doc__ = code.cdr.cdr.car.valueOf(); } env.set(code.car, value, __doc__, true); @@ -14499,7 +14503,7 @@ } else if (is_prototype(obj) && is_function(value)) { obj[key] = unbind(value); obj[key][__prototype__] = true; - } else if (is_function(value) || is_native(value) || value === _nil) { + } else if (is_function(value) || is_native(value) || is_nil(value)) { obj[key] = value; } else { obj[key] = value && !is_prototype(value) ? value.valueOf() : value; @@ -14569,7 +14573,7 @@ error = _ref34.error; var self = this; var __doc__; - if (code.cdr instanceof Pair && LString.isString(code.cdr.car) && code.cdr.cdr !== _nil) { + if (is_pair(code.cdr) && LString.isString(code.cdr.car) && !is_nil(code.cdr.cdr)) { __doc__ = code.cdr.car.valueOf(); } function lambda() { @@ -14616,9 +14620,9 @@ } var name = code.car; var i = 0; - if (name instanceof LSymbol || name !== _nil) { + if (name instanceof LSymbol || !is_nil(name)) { while (true) { - if (name.car !== _nil) { + if (!is_nil(name.car)) { if (name instanceof LSymbol) { // rest argument, can also be first argument var value = quote(Pair.fromArray(args.slice(i), false)); @@ -14629,7 +14633,7 @@ set(name.car, _value6); } } - if (name.cdr === _nil) { + if (is_nil(name.cdr)) { break; } i++; @@ -14646,10 +14650,10 @@ }; return _evaluate(output, eval_args); } - var length = code.car instanceof Pair ? code.car.length() : null; + var length = is_pair(code.car) ? code.car.length() : null; lambda.__code__ = new Pair(new LSymbol('lambda'), code); lambda[__lambda__] = true; - if (!(code.car instanceof Pair)) { + if (!is_pair(code.car)) { return doc(lambda, __doc__, true); // variable arguments } // wrap and decorate with __doc__ @@ -14661,10 +14665,10 @@ 'define-macro': doc(new Macro(macro, function (macro, _ref36) { var use_dynamic = _ref36.use_dynamic, error = _ref36.error; - if (macro.car instanceof Pair && macro.car.car instanceof LSymbol) { + if (is_pair(macro.car) && macro.car.car instanceof LSymbol) { var name = macro.car.car.__name__; var __doc__; - if (LString.isString(macro.cdr.car) && macro.cdr.cdr instanceof Pair) { + if (LString.isString(macro.cdr.car) && is_pair(macro.cdr.cdr)) { __doc__ = macro.cdr.car.valueOf(); } var makro_instance = Macro.defmacro(name, function (code) { @@ -14672,26 +14676,26 @@ var name = macro.car.cdr; var arg = code; while (true) { - if (name === _nil) { + if (is_nil(name)) { break; } if (name instanceof LSymbol) { env.__env__[name.__name__] = arg; break; - } else if (name.car !== _nil) { - if (arg === _nil) { + } else if (!is_nil(name.car)) { + if (is_nil(arg)) { env.__env__[name.car.__name__] = _nil; } else { - if (arg.car instanceof Pair) { + if (is_pair(arg.car)) { arg.car[__data__] = true; } env.__env__[name.car.__name__] = arg.car; } } - if (name.cdr === _nil) { + if (is_nil(name.cdr)) { break; } - if (arg !== _nil) { + if (!is_nil(arg)) { arg = arg.cdr; } name = name.cdr; @@ -14703,7 +14707,7 @@ error: error }; // evaluate macro - if (macro.cdr instanceof Pair) { + if (is_pair(macro.cdr)) { // this eval will return lips code var rest = __doc__ ? macro.cdr.cdr : macro.cdr; var result = rest.reduce(function (result, node) { @@ -14729,7 +14733,7 @@ var env = this; function get_identifiers(node) { var symbols = []; - while (node !== _nil) { + while (!is_nil(node)) { var x = node.car; symbols.push(x.valueOf()); node = node.cdr; @@ -14737,7 +14741,7 @@ return symbols; } function validate_identifiers(node) { - while (node !== _nil) { + while (!is_nil(node)) { var x = node.car; if (!(x instanceof LSymbol)) { throw new Error('syntax-rules: wrong identifier'); @@ -14784,7 +14788,7 @@ rules = macro.cdr; } try { - while (rules !== _nil) { + while (!is_nil(rules)) { var rule = rules.car.car; var expr = rules.car.cdr.car; log('[[[ RULE'); @@ -14862,12 +14866,12 @@ var dynamic_env = self; // ----------------------------------------------------------------- function is_struct(value) { - return value instanceof Pair || is_plain_object(value) || Array.isArray(value); + return is_pair(value) || is_plain_object(value) || Array.isArray(value); } // ----------------------------------------------------------------- function resolve_pair(pair, fn) { var test = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : is_struct; - if (pair instanceof Pair) { + if (is_pair(pair)) { var car = pair.car; var cdr = pair.cdr; if (test(car)) { @@ -14891,8 +14895,8 @@ } // ----------------------------------------------------------------- function join(eval_pair, value) { - if (eval_pair instanceof Pair) { - if (value !== _nil) { + if (is_pair(eval_pair)) { + if (!is_nil(value)) { eval_pair.append(value); } } else { @@ -14903,13 +14907,13 @@ // ----------------------------------------------------------------- function unquoted_arr(arr) { return !!arr.filter(function (value) { - return value instanceof Pair && LSymbol.is(value.car, /^(unquote|unquote-splicing)$/); + return is_pair(value) && LSymbol.is(value.car, /^(unquote|unquote-splicing)$/); }).length; } // ----------------------------------------------------------------- function quote_vector(arr, unquote_cnt, max_unq) { return arr.reduce(function (acc, x) { - if (!(x instanceof Pair)) { + if (!is_pair(x)) { acc.push(x); return acc; } @@ -14925,7 +14929,7 @@ error: error }); } - if (!(result instanceof Pair)) { + if (!is_pair(result)) { throw new Error("Expecting list ".concat(type(x), " found")); } return acc.concat(result.to_array()); @@ -14940,7 +14944,7 @@ unquote_cnt++; Object.keys(object).forEach(function (key) { var value = object[key]; - if (value instanceof Pair) { + if (is_pair(value)) { if (LSymbol.is(value.car, 'unquote-splicing')) { throw new Error("You can't call `unquote-splicing` " + "inside object"); } @@ -14979,17 +14983,17 @@ error: error }); lists.push(value); - if (node.cdr instanceof Pair) { + if (is_pair(node.cdr)) { return next(node.cdr); } return unpromise(lists, function (arr) { if (arr.some(function (x) { - return !(x instanceof Pair); + return !is_pair(x); })) { - if (pair.cdr instanceof Pair && LSymbol.is(pair.cdr.car, '.') && pair.cdr.cdr instanceof Pair && pair.cdr.cdr.cdr === _nil) { + if (is_pair(pair.cdr) && LSymbol.is(pair.cdr.car, '.') && is_pair(pair.cdr.cdr) && is_nil(pair.cdr.cdr.cdr)) { return pair.cdr.cdr.car; } - if (!(pair.cdr === _nil || pair.cdr instanceof Pair)) { + if (!(is_nil(pair.cdr) || is_pair(pair.cdr))) { var msg = "You can't splice atom inside list"; throw new Error(msg); } @@ -14997,7 +15001,7 @@ var _msg = "You can't splice multiple atoms inside list"; throw new Error(_msg); } - if (!(pair.cdr instanceof Pair && arr[0] === _nil)) { + if (!(is_pair(pair.cdr) && is_nil(arr[0]))) { return arr[0]; } } @@ -15011,11 +15015,11 @@ } }); var value = recur(pair.cdr, 0, 1); - if (value === _nil && arr[0] === _nil) { + if (is_nil(value) && is_nil(arr[0])) { return undefined; } return unpromise(value, function (value) { - if (arr[0] === _nil) { + if (is_nil(arr[0])) { return value; } if (arr.length === 1) { @@ -15032,22 +15036,22 @@ // ----------------------------------------------------------------- var splices = new Set(); function recur(pair, unquote_cnt, max_unq) { - if (pair instanceof Pair) { - if (pair.car instanceof Pair) { + if (is_pair(pair)) { + if (is_pair(pair.car)) { if (LSymbol.is(pair.car.car, 'unquote-splicing')) { return unquote_splice(pair, unquote_cnt + 1, max_unq); } if (LSymbol.is(pair.car.car, 'unquote')) { // + 2 - one for unquote and one for unquote splicing - if (unquote_cnt + 2 === max_unq && pair.car.cdr instanceof Pair && pair.car.cdr.car instanceof Pair && LSymbol.is(pair.car.cdr.car.car, 'unquote-splicing')) { + if (unquote_cnt + 2 === max_unq && is_pair(pair.car.cdr) && is_pair(pair.car.cdr.car) && LSymbol.is(pair.car.cdr.car.car, 'unquote-splicing')) { var rest = pair.car.cdr; return new Pair(new Pair(new LSymbol('unquote'), unquote_splice(rest, unquote_cnt + 2, max_unq)), _nil); - } else if (pair.car.cdr instanceof Pair && pair.car.cdr.cdr !== _nil) { - if (pair.car.cdr.car instanceof Pair) { + } else if (is_pair(pair.car.cdr) && !is_nil(pair.car.cdr.cdr)) { + if (is_pair(pair.car.cdr.car)) { // values inside unquote are lists var result = []; return function recur(node) { - if (node === _nil) { + if (is_nil(node)) { return Pair.fromArray(result); } return unpromise(_evaluate(node.car, { @@ -15084,9 +15088,9 @@ if (unquote_cnt > max_unq) { throw new Error("You can't call `unquote` outside " + "of quasiquote"); } - if (pair.cdr instanceof Pair) { - if (pair.cdr.cdr !== _nil) { - if (pair.cdr.car instanceof Pair) { + if (is_pair(pair.cdr)) { + if (!is_nil(pair.cdr.cdr)) { + if (is_pair(pair.cdr.car)) { // TODO: test if this part is needed // this part was duplicated in previous section // if (LSymbol.is(pair.car.car, 'unquote')) { @@ -15094,7 +15098,7 @@ var _result4 = []; // evaluate all values in unquote return function recur(node) { - if (node === _nil) { + if (is_nil(node)) { return Pair.fromArray(_result4); } return unpromise(_evaluate(node.car, { @@ -15133,7 +15137,7 @@ } // ----------------------------------------------------------------- function clear(node) { - if (node instanceof Pair) { + if (is_pair(node)) { delete node[__data__]; if (!node.haveCycles('car')) { clear(node.car); @@ -15150,7 +15154,7 @@ if (Array.isArray(arg.car) && !unquoted_arr(arg.car)) { return quote(arg.car); } - if (arg.car instanceof Pair && !arg.car.find('unquote') && !arg.car.find('unquote-splicing') && !arg.car.find('quasiquote')) { + if (is_pair(arg.car) && !arg.car.find('unquote') && !arg.car.find('unquote-splicing') && !arg.car.find('quasiquote')) { return quote(arg.car); } var x = recur(arg.car, 0, 1); @@ -15172,7 +15176,7 @@ items[_key25] = arguments[_key25]; } items = items.map(function (item) { - if (item instanceof Pair) { + if (is_pair(item)) { return item.clone(); } return item; @@ -15187,11 +15191,11 @@ } return items.reduce(function (acc, item) { typecheck('append!', acc, ['nil', 'pair']); - if ((item instanceof Pair || item === _nil) && !is_list(item)) { + if ((is_pair(item) || is_nil(item)) && !is_list(item)) { throw new Error('append!: Invalid argument, value is not a list'); } - if (acc === _nil) { - if (item === _nil) { + if (is_nil(acc)) { + if (is_nil(item)) { return _nil; } return item; @@ -15205,10 +15209,10 @@ // ------------------------------------------------------------------ reverse: doc('reverse', function reverse(arg) { typecheck('reverse', arg, ['array', 'pair', 'nil']); - if (arg === _nil) { + if (is_nil(arg)) { return _nil; } - if (arg instanceof Pair) { + if (is_pair(arg)) { var arr = global_env.get('list->array')(arg).reverse(); return global_env.get('array->list')(arr); } else if (Array.isArray(arg)) { @@ -15221,11 +15225,11 @@ nth: doc('nth', function nth(index, obj) { typecheck('nth', index, 'number'); typecheck('nth', obj, ['array', 'pair']); - if (obj instanceof Pair) { + if (is_pair(obj)) { var node = obj; var count = 0; while (count < index) { - if (!node.cdr || node.cdr === _nil || node.haveCycles('cdr')) { + if (!node.cdr || is_nil(node.cdr) || node.haveCycles('cdr')) { return _nil; } node = node.cdr; @@ -15403,9 +15407,7 @@ return LString.isString(obj); }, "(string? expression)\n\n Predicate that tests if value is a string."), // ------------------------------------------------------------------ - 'pair?': doc('pair?', function (obj) { - return obj instanceof Pair; - }, "(pair? expression)\n\n Predicate that tests if value is a pair or list structure."), + 'pair?': doc('pair?', is_pair, "(pair? expression)\n\n Predicate that tests if value is a pair or list structure."), // ------------------------------------------------------------------ 'regex?': doc('regex?', function (obj) { return obj instanceof RegExp; @@ -15428,7 +15430,7 @@ }, "(array? expression)\n\n Predicate that tests if value is an array."), // ------------------------------------------------------------------ 'object?': doc('object?', function (obj) { - return obj !== _nil && obj !== null && !(obj instanceof LCharacter) && !(obj instanceof RegExp) && !(obj instanceof LString) && !(obj instanceof Pair) && !(obj instanceof LNumber) && _typeof$1(obj) === 'object' && !(obj instanceof Array); + return !is_nil(obj) && obj !== null && !(obj instanceof LCharacter) && !(obj instanceof RegExp) && !(obj instanceof LString) && !is_pair(obj) && !(obj instanceof LNumber) && _typeof$1(obj) === 'object' && !(obj instanceof Array); }, "(object? expression)\n\n Predicate that tests if value is an plain object (not another LIPS type)."), // ------------------------------------------------------------------ flatten: doc('flatten', function flatten(list) { @@ -15457,10 +15459,10 @@ }, "(apply fn list)\n\n Function that calls fn with the list of arguments."), // ------------------------------------------------------------------ length: doc('length', function length(obj) { - if (!obj || obj === _nil) { + if (!obj || is_nil(obj)) { return 0; } - if (obj instanceof Pair) { + if (is_pair(obj)) { return obj.length(); } if ("length" in obj) { @@ -15498,7 +15500,7 @@ var catch_clause, finally_clause; if (LSymbol.is(code.cdr.car.car, 'catch')) { catch_clause = code.cdr.car; - if (code.cdr.cdr instanceof Pair && LSymbol.is(code.cdr.cdr.car.car, 'finally')) { + if (is_pair(code.cdr.cdr) && LSymbol.is(code.cdr.cdr.car.car, 'finally')) { finally_clause = code.cdr.cdr.car; } } else if (LSymbol.is(code.cdr.car.car, 'finally')) { @@ -15587,7 +15589,7 @@ } var fn = matcher('find', arg); return unpromise(fn(list.car), function (value) { - if (value && value !== _nil) { + if (value && !is_nil(value)) { return list.car; } return find(arg, list.cdr); @@ -15622,16 +15624,14 @@ lists.forEach(function (arg, i) { typecheck('map', arg, ['pair', 'nil'], i + 1); // detect cycles - if (arg instanceof Pair && !is_list.call(_this27, arg)) { + if (is_pair(arg) && !is_list.call(_this27, arg)) { throw new Error("map: argument ".concat(i + 1, " is not a list")); } }); if (lists.length === 0) { return _nil; } - if (lists.some(function (x) { - return x === _nil; - })) { + if (lists.some(is_nil)) { return _nil; } var args = lists.map(function (l) { @@ -15657,10 +15657,10 @@ 'list?': doc('list?', function (obj) { var node = obj; while (true) { - if (node === _nil) { + if (is_nil(node)) { return true; } - if (!(node instanceof Pair)) { + if (!is_pair(node)) { return false; } if (node.haveCycles('cdr')) { @@ -15690,9 +15690,7 @@ lists.forEach(function (arg, i) { typecheck('fold', arg, ['pair', 'nil'], i + 1); }); - if (lists.some(function (x) { - return x === _nil; - })) { + if (lists.some(is_nil)) { return init; } var value = fold.call.apply(fold, [this, fn, init].concat(_toConsumableArray(lists.map(function (l) { @@ -15738,9 +15736,7 @@ lists.forEach(function (arg, i) { typecheck('reduce', arg, ['pair', 'nil'], i + 1); }); - if (lists.some(function (x) { - return x === _nil; - })) { + if (lists.some(is_nil)) { return init; } return unpromise(fn.apply(void 0, _toConsumableArray(lists.map(function (l) { @@ -15760,7 +15756,7 @@ var fn = matcher('filter', arg); return function loop(i) { function next(value) { - if (value && value !== _nil) { + if (value && !is_nil(value)) { result.push(item); } return loop(++i); @@ -16283,7 +16279,7 @@ typecheck(fn, arg, 'number', position); var arg_type = arg.__type__; var match; - if (expected instanceof Pair) { + if (is_pair(expected)) { expected = expected.to_array(); } if (expected instanceof Array) { @@ -16338,7 +16334,7 @@ return; } var match = false; - if (expected instanceof Pair) { + if (is_pair(expected)) { expected = expected.to_array(); } if (expected instanceof Array) { @@ -16431,7 +16427,7 @@ function traverse(node) { if (is_promise(node)) { promises.push(node); - } else if (node instanceof Pair) { + } else if (is_pair(node)) { if (!node.haveCycles('car')) { traverse(node.car); } @@ -16497,7 +16493,7 @@ if (node instanceof Array) { return promise_all(node.map(resolve)); } - if (node instanceof Pair && promises.length) { + if (is_pair(node) && promises.length) { return promise(node); } return node; @@ -16514,7 +16510,7 @@ return args; } return function loop() { - if (node instanceof Pair) { + if (is_pair(node)) { var arg = _evaluate(node.car, _objectSpread({ use_dynamic: use_dynamic }, options)); @@ -16535,7 +16531,7 @@ node = node.cdr; return loop(); }); - } else if (node === _nil) { + } else if (is_nil(node)) { return next(); } else { throw new Error('Syntax Error: improper list found in apply'); @@ -16546,7 +16542,7 @@ function evaluate_syntax(macro, code, eval_args) { var value = macro.invoke(code, eval_args); return unpromise(resolve_promises(value), function (value) { - if (value instanceof Pair) { + if (is_pair(value)) { value.markCycles(); } return quote(value); @@ -16555,7 +16551,7 @@ // ------------------------------------------------------------------------- function evaluate_macro(macro, code, eval_args) { function finalize(result) { - if (result instanceof Pair) { + if (is_pair(result)) { result.markCycles(); return result; } @@ -16657,7 +16653,7 @@ use_dynamic: use_dynamic }); return unpromise(result, function (result) { - if (result instanceof Pair) { + if (is_pair(result)) { result.markCycles(); return quote(result); } @@ -16823,12 +16819,12 @@ if (code instanceof LSymbol) { return env.get(code); } - if (!(code instanceof Pair)) { + if (!is_pair(code)) { return code; } var first = code.car; var rest = code.cdr; - if (first instanceof Pair) { + if (is_pair(first)) { value = resolve_promises(_evaluate(first, eval_args)); if (is_promise(value)) { return value.then(function (value) { @@ -16867,7 +16863,7 @@ } } else if (is_continuation(value)) { result = value.invoke(); - } else if (code instanceof Pair) { + } else if (is_pair(code)) { value = first && first.toString(); throw new Error("".concat(type(first), " ").concat(value, " is not a function")); } else { @@ -16882,7 +16878,7 @@ // When promise is not quoted it happen automatically, when returning // promise from evaluate. result = result.then(function (result) { - if (result instanceof Pair && !value[__data__]) { + if (is_pair(result) && !value[__data__]) { return _evaluate(result, eval_args); } return result; @@ -17568,10 +17564,10 @@ // ------------------------------------------------------------------------- var banner = function () { // Rollup tree-shaking is removing the variable if it's normal string because - // obviously 'Mon, 12 Feb 2024 12:58:05 +0000' == '{{' + 'DATE}}'; can be removed + // obviously 'Mon, 12 Feb 2024 14:25:33 +0000' == '{{' + 'DATE}}'; can be removed // but disabling Tree-shaking is adding lot of not used code so we use this // hack instead - var date = LString('Mon, 12 Feb 2024 12:58:05 +0000').valueOf(); + var date = LString('Mon, 12 Feb 2024 14:25:33 +0000').valueOf(); var _date = date === '{{' + 'DATE}}' ? new Date() : new Date(date); var _format = function _format(x) { return x.toString().padStart(2, '0'); @@ -17611,7 +17607,7 @@ read_only(Parameter, '__class__', 'parameter'); // ------------------------------------------------------------------------- var version = 'DEV'; - var date = 'Mon, 12 Feb 2024 12:58:05 +0000'; + var date = 'Mon, 12 Feb 2024 14:25:33 +0000'; // unwrap async generator into Promise var parse = compose(uniterate_async, _parse); diff --git a/dist/lips.min.js b/dist/lips.min.js index 72e2bb192..611f4dedb 100644 --- a/dist/lips.min.js +++ b/dist/lips.min.js @@ -31,15 +31,15 @@ * Copyright (c) 2014-present, Facebook, Inc. * released under MIT license * - * build: Mon, 12 Feb 2024 12:58:05 +0000 + * build: Mon, 12 Feb 2024 14:25:33 +0000 */ -(function(e,t){typeof exports==="object"&&typeof module!=="undefined"?t(exports):typeof define==="function"&&define.amd?define(["exports"],t):(e=typeof globalThis!=="undefined"?globalThis:e||self,t(e.lips={}))})(this,function(e){"use strict";var o=typeof document!=="undefined"?document.currentScript:null;function n(e,t){if(t.get){return t.get.call(e)}return t.value}function i(e,t,r){if(!t.has(e)){throw new TypeError("attempted to "+r+" private field on non-instance")}return t.get(e)}function r(e,t){var r=i(e,t,"get");return n(e,r)}function u(e,t,r){if(t.set){t.set.call(e,r)}else{if(!t.writable){throw new TypeError("attempted to set read only private field")}t.value=r}}function I(e,t,r){var n=i(e,t,"set");u(e,n,r);return r}function P(e){P=Object.setPrototypeOf?Object.getPrototypeOf.bind():function e(t){return t.__proto__||Object.getPrototypeOf(t)};return P(e)}function N(e,t){N=Object.setPrototypeOf?Object.setPrototypeOf.bind():function e(t,r){t.__proto__=r;return t};return N(e,t)}function R(t){try{return Function.toString.call(t).indexOf("[native code]")!==-1}catch(e){return typeof t==="function"}}function T(){try{var t=!Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){}))}catch(t){}return(T=function e(){return!!t})()}function L(e,t,r){if(T())return Reflect.construct.apply(null,arguments);var n=[null];n.push.apply(n,t);var i=new(e.bind.apply(e,n));return r&&N(i,r.prototype),i}function M(e){var n=typeof Map==="function"?new Map:undefined;M=function e(t){if(t===null||!R(t))return t;if(typeof t!=="function"){throw new TypeError("Super expression must either be null or a function")}if(typeof n!=="undefined"){if(n.has(t))return n.get(t);n.set(t,r)}function r(){return L(t,arguments,P(this).constructor)}r.prototype=Object.create(t.prototype,{constructor:{value:r,enumerable:false,writable:true,configurable:true}});return N(r,t)};return M(e)}function p(e){"@babel/helpers - typeof";return p="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},p(e)}function H(e){if(e===void 0){throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}return e}function W(e,t){if(t&&(p(t)==="object"||typeof t==="function")){return t}else if(t!==void 0){throw new TypeError("Derived constructors may only return object or undefined")}return H(e)}function G(e,t){if(typeof t!=="function"&&t!==null){throw new TypeError("Super expression must either be null or a function")}e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,writable:true,configurable:true}});Object.defineProperty(e,"prototype",{writable:false});if(t)N(e,t)}function Q(e){if(Array.isArray(e))return e}function Z(e){if(typeof Symbol!=="undefined"&&e[Symbol.iterator]!=null||e["@@iterator"]!=null)return Array.from(e)}function X(e,t){if(t==null||t>e.length)t=e.length;for(var r=0,n=new Array(t);r=0)continue;r[i]=e[i]}return r}function he(e,t){if(e==null)return{};var r=le(e,t);var n,i;if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(i=0;i=0)continue;if(!Object.prototype.propertyIsEnumerable.call(e,n))continue;r[n]=e[n]}}return r}function pe(e,t){var r=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=r){var n,i,a,u,o=[],s=!0,c=!1;try{if(a=(r=r.call(e)).next,0===t){if(Object(r)!==r)return;s=!1}else for(;!(s=(n=a.call(r)).done)&&(o.push(n.value),o.length!==t);s=!0);}catch(e){c=!0,i=e}finally{try{if(!s&&null!=r["return"]&&(u=r["return"](),Object(u)!==u))return}finally{if(c)throw i}}return o}}function b(e,t){return Q(e)||pe(e,t)||ee(e,t)||te()}function _e(e){if(Array.isArray(e))return X(e)}function de(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function U(e){return _e(e)||Z(e)||ee(e)||de()}function ve(e,t){this.v=e,this.k=t}function ye(e){return new ve(e,0)}function me(u){var a,o;function s(r,e){try{var n=u[r](e),i=n.value,a=i instanceof ve;Promise.resolve(a?i.v:i).then(function(e){if(a){var t="return"===r?"return":"next";if(!i.k||e.done)return s(t,e);e=u[t](e).value}c(n.done?"return":"normal",e)},function(e){s("throw",e)})}catch(e){c("throw",e)}}function c(e,t){switch(e){case"return":a.resolve({value:t,done:!0});break;case"throw":a.reject(t);break;default:a.resolve({value:t,done:!1})}(a=a.next)?s(a.key,a.arg):o=null}this._invoke=function(n,i){return new Promise(function(e,t){var r={key:n,arg:i,resolve:e,reject:t,next:null};o?o=o.next=r:(a=o=r,s(n,i))})},"function"!=typeof u["return"]&&(this["return"]=void 0)}me.prototype["function"==typeof Symbol&&Symbol.asyncIterator||"@@asyncIterator"]=function(){return this},me.prototype.next=function(e){return this._invoke("next",e)},me.prototype["throw"]=function(e){return this._invoke("throw",e)},me.prototype["return"]=function(e){return this._invoke("return",e)};function ge(e){return function(){return new me(e.apply(this,arguments))}}function be(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,"default")?e["default"]:e}var we={exports:{}};var De={exports:{}};(function(t){function r(e){"@babel/helpers - typeof";return t.exports=r="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},t.exports.__esModule=true,t.exports["default"]=t.exports,r(e)}t.exports=r,t.exports.__esModule=true,t.exports["default"]=t.exports})(De);var Ee=De.exports;(function(j){var I=Ee["default"];function P(){j.exports=P=function e(){return u},j.exports.__esModule=true,j.exports["default"]=j.exports;var c,u={},e=Object.prototype,f=e.hasOwnProperty,l=Object.defineProperty||function(e,t,r){e[t]=r.value},t="function"==typeof Symbol?Symbol:{},i=t.iterator||"@@iterator",r=t.asyncIterator||"@@asyncIterator",n=t.toStringTag||"@@toStringTag";function a(e,t,r){return Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}),e[t]}try{a({},"")}catch(c){a=function e(t,r,n){return t[r]=n}}function o(e,t,r,n){var i=t&&t.prototype instanceof s?t:s,a=Object.create(i.prototype),u=new S(n||[]);return l(a,"_invoke",{value:F(e,r,u)}),a}function h(e,t,r){try{return{type:"normal",arg:e.call(t,r)}}catch(e){return{type:"throw",arg:e}}}u.wrap=o;var p="suspendedStart",_="suspendedYield",d="executing",v="completed",y={};function s(){}function m(){}function g(){}var b={};a(b,i,function(){return this});var w=Object.getPrototypeOf,D=w&&w(w(B([])));D&&D!==e&&f.call(D,i)&&(b=D);var E=g.prototype=s.prototype=Object.create(b);function x(e){["next","throw","return"].forEach(function(t){a(e,t,function(e){return this._invoke(t,e)})})}function A(o,s){function c(e,t,r,n){var i=h(o[e],o,t);if("throw"!==i.type){var a=i.arg,u=a.value;return u&&"object"==I(u)&&f.call(u,"__await")?s.resolve(u.__await).then(function(e){c("next",e,r,n)},function(e){c("throw",e,r,n)}):s.resolve(u).then(function(e){a.value=e,r(a)},function(e){return c("throw",e,r,n)})}n(i.arg)}var i;l(this,"_invoke",{value:function e(r,n){function t(){return new s(function(e,t){c(r,n,e,t)})}return i=i?i.then(t,t):t()}})}function F(a,u,o){var s=p;return function(e,t){if(s===d)throw new Error("Generator is already running");if(s===v){if("throw"===e)throw t;return{value:c,done:!0}}for(o.method=e,o.arg=t;;){var r=o.delegate;if(r){var n=k(r,o);if(n){if(n===y)continue;return n}}if("next"===o.method)o.sent=o._sent=o.arg;else if("throw"===o.method){if(s===p)throw s=v,o.arg;o.dispatchException(o.arg)}else"return"===o.method&&o.abrupt("return",o.arg);s=d;var i=h(a,u,o);if("normal"===i.type){if(s=o.done?v:_,i.arg===y)continue;return{value:i.arg,done:o.done}}"throw"===i.type&&(s=v,o.method="throw",o.arg=i.arg)}}}function k(e,t){var r=t.method,n=e.iterator[r];if(n===c)return t.delegate=null,"throw"===r&&e.iterator["return"]&&(t.method="return",t.arg=c,k(e,t),"throw"===t.method)||"return"!==r&&(t.method="throw",t.arg=new TypeError("The iterator does not provide a '"+r+"' method")),y;var i=h(n,e.iterator,t.arg);if("throw"===i.type)return t.method="throw",t.arg=i.arg,t.delegate=null,y;var a=i.arg;return a?a.done?(t[e.resultName]=a.value,t.next=e.nextLoc,"return"!==t.method&&(t.method="next",t.arg=c),t.delegate=null,y):a:(t.method="throw",t.arg=new TypeError("iterator result is not an object"),t.delegate=null,y)}function C(e){var t={tryLoc:e[0]};1 in e&&(t.catchLoc=e[1]),2 in e&&(t.finallyLoc=e[2],t.afterLoc=e[3]),this.tryEntries.push(t)}function O(e){var t=e.completion||{};t.type="normal",delete t.arg,e.completion=t}function S(e){this.tryEntries=[{tryLoc:"root"}],e.forEach(C,this),this.reset(!0)}function B(t){if(t||""===t){var e=t[i];if(e)return e.call(t);if("function"==typeof t.next)return t;if(!isNaN(t.length)){var r=-1,n=function e(){for(;++r=0;--i){var a=this.tryEntries[i],u=a.completion;if("root"===a.tryLoc)return t("end");if(a.tryLoc<=this.prev){var o=f.call(a,"catchLoc"),s=f.call(a,"finallyLoc");if(o&&s){if(this.prev=0;--n){var i=this.tryEntries[n];if(i.tryLoc<=this.prev&&f.call(i,"finallyLoc")&&this.prev=0;--r){var n=this.tryEntries[r];if(n.finallyLoc===t)return this.complete(n.completion,n.afterLoc),O(n),y}},catch:function e(t){for(var r=this.tryEntries.length-1;r>=0;--r){var n=this.tryEntries[r];if(n.tryLoc===t){var i=n.completion;if("throw"===i.type){var a=i.arg;O(n)}return a}}throw new Error("illegal catch attempt")},delegateYield:function e(t,r,n){return this.delegate={iterator:B(t),resultName:r,nextLoc:n},"next"===this.method&&(this.arg=c),y}},u}j.exports=P,j.exports.__esModule=true,j.exports["default"]=j.exports})(we);var xe=we.exports;var Ae=xe();var Fe=Ae;try{regeneratorRuntime=Ae}catch(e){if(typeof globalThis==="object"){globalThis.regeneratorRuntime=Ae}else{Function("r","regeneratorRuntime = r")(Ae)}}var C=be(Fe);var ke=typeof global!=="undefined"?global:typeof self!=="undefined"?self:typeof window!=="undefined"?window:{};var Ce=[];var Oe=[];var Se=typeof Uint8Array!=="undefined"?Uint8Array:Array;var Be=false;function je(){Be=true;var e="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";for(var t=0,r=e.length;t0){throw new Error("Invalid string. Length must be a multiple of 4")}a=e[o-2]==="="?2:e[o-1]==="="?1:0;u=new Se(o*3/4-a);n=a>0?o-4:o;var s=0;for(t=0,r=0;t>16&255;u[s++]=i>>8&255;u[s++]=i&255}if(a===2){i=Oe[e.charCodeAt(t)]<<2|Oe[e.charCodeAt(t+1)]>>4;u[s++]=i&255}else if(a===1){i=Oe[e.charCodeAt(t)]<<10|Oe[e.charCodeAt(t+1)]<<4|Oe[e.charCodeAt(t+2)]>>2;u[s++]=i>>8&255;u[s++]=i&255}return u}function Pe(e){return Ce[e>>18&63]+Ce[e>>12&63]+Ce[e>>6&63]+Ce[e&63]}function Ne(e,t,r){var n;var i=[];for(var a=t;as?s:o+u))}if(n===1){t=e[r-1];i+=Ce[t>>2];i+=Ce[t<<4&63];i+="=="}else if(n===2){t=(e[r-2]<<8)+e[r-1];i+=Ce[t>>10];i+=Ce[t>>4&63];i+=Ce[t<<2&63];i+="="}a.push(i);return a.join("")}function Te(e,t,r,n,i){var a,u;var o=i*8-n-1;var s=(1<>1;var f=-7;var l=r?i-1:0;var h=r?-1:1;var p=e[t+l];l+=h;a=p&(1<<-f)-1;p>>=-f;f+=o;for(;f>0;a=a*256+e[t+l],l+=h,f-=8){}u=a&(1<<-f)-1;a>>=-f;f+=n;for(;f>0;u=u*256+e[t+l],l+=h,f-=8){}if(a===0){a=1-c}else if(a===s){return u?NaN:(p?-1:1)*Infinity}else{u=u+Math.pow(2,n);a=a-c}return(p?-1:1)*u*Math.pow(2,a-n)}function Le(e,t,r,n,i,a){var u,o,s;var c=a*8-i-1;var f=(1<>1;var h=i===23?Math.pow(2,-24)-Math.pow(2,-77):0;var p=n?0:a-1;var _=n?1:-1;var d=t<0||t===0&&1/t<0?1:0;t=Math.abs(t);if(isNaN(t)||t===Infinity){o=isNaN(t)?1:0;u=f}else{u=Math.floor(Math.log(t)/Math.LN2);if(t*(s=Math.pow(2,-u))<1){u--;s*=2}if(u+l>=1){t+=h/s}else{t+=h*Math.pow(2,1-l)}if(t*s>=2){u++;s/=2}if(u+l>=f){o=0;u=f}else if(u+l>=1){o=(t*s-1)*Math.pow(2,i);u=u+l}else{o=t*Math.pow(2,l-1)*Math.pow(2,i);u=0}}for(;i>=8;e[r+p]=o&255,p+=_,o/=256,i-=8){}u=u<0;e[r+p]=u&255,p+=_,u/=256,c-=8){}e[r+p-_]|=d*128}var Me={}.toString;var Ue=Array.isArray||function(e){return Me.call(e)=="[object Array]"}; +(function(e,t){typeof exports==="object"&&typeof module!=="undefined"?t(exports):typeof define==="function"&&define.amd?define(["exports"],t):(e=typeof globalThis!=="undefined"?globalThis:e||self,t(e.lips={}))})(this,function(e){"use strict";var o=typeof document!=="undefined"?document.currentScript:null;function n(e,t){if(t.get){return t.get.call(e)}return t.value}function i(e,t,r){if(!t.has(e)){throw new TypeError("attempted to "+r+" private field on non-instance")}return t.get(e)}function t(e,t){var r=i(e,t,"get");return n(e,r)}function a(e,t,r){if(t.set){t.set.call(e,r)}else{if(!t.writable){throw new TypeError("attempted to set read only private field")}t.value=r}}function j(e,t,r){var n=i(e,t,"set");a(e,n,r);return r}function I(e){I=Object.setPrototypeOf?Object.getPrototypeOf.bind():function e(t){return t.__proto__||Object.getPrototypeOf(t)};return I(e)}function P(e,t){P=Object.setPrototypeOf?Object.setPrototypeOf.bind():function e(t,r){t.__proto__=r;return t};return P(e,t)}function N(t){try{return Function.toString.call(t).indexOf("[native code]")!==-1}catch(e){return typeof t==="function"}}function R(){try{var t=!Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){}))}catch(t){}return(R=function e(){return!!t})()}function T(e,t,r){if(R())return Reflect.construct.apply(null,arguments);var n=[null];n.push.apply(n,t);var i=new(e.bind.apply(e,n));return r&&P(i,r.prototype),i}function r(e){var n=typeof Map==="function"?new Map:undefined;r=function e(t){if(t===null||!N(t))return t;if(typeof t!=="function"){throw new TypeError("Super expression must either be null or a function")}if(typeof n!=="undefined"){if(n.has(t))return n.get(t);n.set(t,r)}function r(){return T(t,arguments,I(this).constructor)}r.prototype=Object.create(t.prototype,{constructor:{value:r,enumerable:false,writable:true,configurable:true}});return P(r,t)};return r(e)}function p(e){"@babel/helpers - typeof";return p="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},p(e)}function L(e){if(e===void 0){throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}return e}function M(e,t){if(t&&(p(t)==="object"||typeof t==="function")){return t}else if(t!==void 0){throw new TypeError("Derived constructors may only return object or undefined")}return L(e)}function G(e,t){if(typeof t!=="function"&&t!==null){throw new TypeError("Super expression must either be null or a function")}e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,writable:true,configurable:true}});Object.defineProperty(e,"prototype",{writable:false});if(t)P(e,t)}function Q(e){if(Array.isArray(e))return e}function Z(e){if(typeof Symbol!=="undefined"&&e[Symbol.iterator]!=null||e["@@iterator"]!=null)return Array.from(e)}function X(e,t){if(t==null||t>e.length)t=e.length;for(var r=0,n=new Array(t);r=0)continue;r[i]=e[i]}return r}function he(e,t){if(e==null)return{};var r=le(e,t);var n,i;if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(e);for(i=0;i=0)continue;if(!Object.prototype.propertyIsEnumerable.call(e,n))continue;r[n]=e[n]}}return r}function pe(e,t){var r=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=r){var n,i,u,a,o=[],s=!0,c=!1;try{if(u=(r=r.call(e)).next,0===t){if(Object(r)!==r)return;s=!1}else for(;!(s=(n=u.call(r)).done)&&(o.push(n.value),o.length!==t);s=!0);}catch(e){c=!0,i=e}finally{try{if(!s&&null!=r["return"]&&(a=r["return"](),Object(a)!==a))return}finally{if(c)throw i}}return o}}function b(e,t){return Q(e)||pe(e,t)||ee(e,t)||te()}function _e(e){if(Array.isArray(e))return X(e)}function de(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function U(e){return _e(e)||Z(e)||ee(e)||de()}function ve(e,t){this.v=e,this.k=t}function ye(e){return new ve(e,0)}function me(a){var u,o;function s(r,e){try{var n=a[r](e),i=n.value,u=i instanceof ve;Promise.resolve(u?i.v:i).then(function(e){if(u){var t="return"===r?"return":"next";if(!i.k||e.done)return s(t,e);e=a[t](e).value}c(n.done?"return":"normal",e)},function(e){s("throw",e)})}catch(e){c("throw",e)}}function c(e,t){switch(e){case"return":u.resolve({value:t,done:!0});break;case"throw":u.reject(t);break;default:u.resolve({value:t,done:!1})}(u=u.next)?s(u.key,u.arg):o=null}this._invoke=function(n,i){return new Promise(function(e,t){var r={key:n,arg:i,resolve:e,reject:t,next:null};o?o=o.next=r:(u=o=r,s(n,i))})},"function"!=typeof a["return"]&&(this["return"]=void 0)}me.prototype["function"==typeof Symbol&&Symbol.asyncIterator||"@@asyncIterator"]=function(){return this},me.prototype.next=function(e){return this._invoke("next",e)},me.prototype["throw"]=function(e){return this._invoke("throw",e)},me.prototype["return"]=function(e){return this._invoke("return",e)};function ge(e){return function(){return new me(e.apply(this,arguments))}}function be(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,"default")?e["default"]:e}var we={exports:{}};var De={exports:{}};(function(t){function r(e){"@babel/helpers - typeof";return t.exports=r="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},t.exports.__esModule=true,t.exports["default"]=t.exports,r(e)}t.exports=r,t.exports.__esModule=true,t.exports["default"]=t.exports})(De);var Ee=De.exports;(function(j){var I=Ee["default"];function P(){j.exports=P=function e(){return a},j.exports.__esModule=true,j.exports["default"]=j.exports;var c,a={},e=Object.prototype,f=e.hasOwnProperty,l=Object.defineProperty||function(e,t,r){e[t]=r.value},t="function"==typeof Symbol?Symbol:{},i=t.iterator||"@@iterator",r=t.asyncIterator||"@@asyncIterator",n=t.toStringTag||"@@toStringTag";function u(e,t,r){return Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}),e[t]}try{u({},"")}catch(c){u=function e(t,r,n){return t[r]=n}}function o(e,t,r,n){var i=t&&t.prototype instanceof s?t:s,u=Object.create(i.prototype),a=new S(n||[]);return l(u,"_invoke",{value:F(e,r,a)}),u}function h(e,t,r){try{return{type:"normal",arg:e.call(t,r)}}catch(e){return{type:"throw",arg:e}}}a.wrap=o;var p="suspendedStart",_="suspendedYield",d="executing",v="completed",y={};function s(){}function m(){}function g(){}var b={};u(b,i,function(){return this});var w=Object.getPrototypeOf,D=w&&w(w(B([])));D&&D!==e&&f.call(D,i)&&(b=D);var E=g.prototype=s.prototype=Object.create(b);function A(e){["next","throw","return"].forEach(function(t){u(e,t,function(e){return this._invoke(t,e)})})}function x(o,s){function c(e,t,r,n){var i=h(o[e],o,t);if("throw"!==i.type){var u=i.arg,a=u.value;return a&&"object"==I(a)&&f.call(a,"__await")?s.resolve(a.__await).then(function(e){c("next",e,r,n)},function(e){c("throw",e,r,n)}):s.resolve(a).then(function(e){u.value=e,r(u)},function(e){return c("throw",e,r,n)})}n(i.arg)}var i;l(this,"_invoke",{value:function e(r,n){function t(){return new s(function(e,t){c(r,n,e,t)})}return i=i?i.then(t,t):t()}})}function F(u,a,o){var s=p;return function(e,t){if(s===d)throw new Error("Generator is already running");if(s===v){if("throw"===e)throw t;return{value:c,done:!0}}for(o.method=e,o.arg=t;;){var r=o.delegate;if(r){var n=k(r,o);if(n){if(n===y)continue;return n}}if("next"===o.method)o.sent=o._sent=o.arg;else if("throw"===o.method){if(s===p)throw s=v,o.arg;o.dispatchException(o.arg)}else"return"===o.method&&o.abrupt("return",o.arg);s=d;var i=h(u,a,o);if("normal"===i.type){if(s=o.done?v:_,i.arg===y)continue;return{value:i.arg,done:o.done}}"throw"===i.type&&(s=v,o.method="throw",o.arg=i.arg)}}}function k(e,t){var r=t.method,n=e.iterator[r];if(n===c)return t.delegate=null,"throw"===r&&e.iterator["return"]&&(t.method="return",t.arg=c,k(e,t),"throw"===t.method)||"return"!==r&&(t.method="throw",t.arg=new TypeError("The iterator does not provide a '"+r+"' method")),y;var i=h(n,e.iterator,t.arg);if("throw"===i.type)return t.method="throw",t.arg=i.arg,t.delegate=null,y;var u=i.arg;return u?u.done?(t[e.resultName]=u.value,t.next=e.nextLoc,"return"!==t.method&&(t.method="next",t.arg=c),t.delegate=null,y):u:(t.method="throw",t.arg=new TypeError("iterator result is not an object"),t.delegate=null,y)}function C(e){var t={tryLoc:e[0]};1 in e&&(t.catchLoc=e[1]),2 in e&&(t.finallyLoc=e[2],t.afterLoc=e[3]),this.tryEntries.push(t)}function O(e){var t=e.completion||{};t.type="normal",delete t.arg,e.completion=t}function S(e){this.tryEntries=[{tryLoc:"root"}],e.forEach(C,this),this.reset(!0)}function B(t){if(t||""===t){var e=t[i];if(e)return e.call(t);if("function"==typeof t.next)return t;if(!isNaN(t.length)){var r=-1,n=function e(){for(;++r=0;--i){var u=this.tryEntries[i],a=u.completion;if("root"===u.tryLoc)return t("end");if(u.tryLoc<=this.prev){var o=f.call(u,"catchLoc"),s=f.call(u,"finallyLoc");if(o&&s){if(this.prev=0;--n){var i=this.tryEntries[n];if(i.tryLoc<=this.prev&&f.call(i,"finallyLoc")&&this.prev=0;--r){var n=this.tryEntries[r];if(n.finallyLoc===t)return this.complete(n.completion,n.afterLoc),O(n),y}},catch:function e(t){for(var r=this.tryEntries.length-1;r>=0;--r){var n=this.tryEntries[r];if(n.tryLoc===t){var i=n.completion;if("throw"===i.type){var u=i.arg;O(n)}return u}}throw new Error("illegal catch attempt")},delegateYield:function e(t,r,n){return this.delegate={iterator:B(t),resultName:r,nextLoc:n},"next"===this.method&&(this.arg=c),y}},a}j.exports=P,j.exports.__esModule=true,j.exports["default"]=j.exports})(we);var Ae=we.exports;var xe=Ae();var Fe=xe;try{regeneratorRuntime=xe}catch(e){if(typeof globalThis==="object"){globalThis.regeneratorRuntime=xe}else{Function("r","regeneratorRuntime = r")(xe)}}var C=be(Fe);var ke=typeof global!=="undefined"?global:typeof self!=="undefined"?self:typeof window!=="undefined"?window:{};var Ce=[];var Oe=[];var Se=typeof Uint8Array!=="undefined"?Uint8Array:Array;var Be=false;function je(){Be=true;var e="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";for(var t=0,r=e.length;t0){throw new Error("Invalid string. Length must be a multiple of 4")}u=e[o-2]==="="?2:e[o-1]==="="?1:0;a=new Se(o*3/4-u);n=u>0?o-4:o;var s=0;for(t=0,r=0;t>16&255;a[s++]=i>>8&255;a[s++]=i&255}if(u===2){i=Oe[e.charCodeAt(t)]<<2|Oe[e.charCodeAt(t+1)]>>4;a[s++]=i&255}else if(u===1){i=Oe[e.charCodeAt(t)]<<10|Oe[e.charCodeAt(t+1)]<<4|Oe[e.charCodeAt(t+2)]>>2;a[s++]=i>>8&255;a[s++]=i&255}return a}function Pe(e){return Ce[e>>18&63]+Ce[e>>12&63]+Ce[e>>6&63]+Ce[e&63]}function Ne(e,t,r){var n;var i=[];for(var u=t;us?s:o+a))}if(n===1){t=e[r-1];i+=Ce[t>>2];i+=Ce[t<<4&63];i+="=="}else if(n===2){t=(e[r-2]<<8)+e[r-1];i+=Ce[t>>10];i+=Ce[t>>4&63];i+=Ce[t<<2&63];i+="="}u.push(i);return u.join("")}function Te(e,t,r,n,i){var u,a;var o=i*8-n-1;var s=(1<>1;var f=-7;var l=r?i-1:0;var h=r?-1:1;var p=e[t+l];l+=h;u=p&(1<<-f)-1;p>>=-f;f+=o;for(;f>0;u=u*256+e[t+l],l+=h,f-=8){}a=u&(1<<-f)-1;u>>=-f;f+=n;for(;f>0;a=a*256+e[t+l],l+=h,f-=8){}if(u===0){u=1-c}else if(u===s){return a?NaN:(p?-1:1)*Infinity}else{a=a+Math.pow(2,n);u=u-c}return(p?-1:1)*a*Math.pow(2,u-n)}function Le(e,t,r,n,i,u){var a,o,s;var c=u*8-i-1;var f=(1<>1;var h=i===23?Math.pow(2,-24)-Math.pow(2,-77):0;var p=n?0:u-1;var _=n?1:-1;var d=t<0||t===0&&1/t<0?1:0;t=Math.abs(t);if(isNaN(t)||t===Infinity){o=isNaN(t)?1:0;a=f}else{a=Math.floor(Math.log(t)/Math.LN2);if(t*(s=Math.pow(2,-a))<1){a--;s*=2}if(a+l>=1){t+=h/s}else{t+=h*Math.pow(2,1-l)}if(t*s>=2){a++;s/=2}if(a+l>=f){o=0;a=f}else if(a+l>=1){o=(t*s-1)*Math.pow(2,i);a=a+l}else{o=t*Math.pow(2,l-1)*Math.pow(2,i);a=0}}for(;i>=8;e[r+p]=o&255,p+=_,o/=256,i-=8){}a=a<0;e[r+p]=a&255,p+=_,a/=256,c-=8){}e[r+p-_]|=d*128}var Me={}.toString;var Ue=Array.isArray||function(e){return Me.call(e)=="[object Array]"}; /*! * The buffer module from node.js, for the browser. * * @author Feross Aboukhadijeh * @license MIT - */var qe=50;c.TYPED_ARRAY_SUPPORT=ke.TYPED_ARRAY_SUPPORT!==undefined?ke.TYPED_ARRAY_SUPPORT:true;ze();function ze(){return c.TYPED_ARRAY_SUPPORT?2147483647:1073741823}function Ye(e,t){if(ze()=ze()){throw new RangeError("Attempt to allocate Buffer larger than maximum "+"size: 0x"+ze().toString(16)+" bytes")}return e|0}c.isBuffer=Rt;function Xe(e){return!!(e!=null&&e._isBuffer)}c.compare=function e(t,r){if(!Xe(t)||!Xe(r)){throw new TypeError("Arguments must be Buffers")}if(t===r)return 0;var n=t.length;var i=r.length;for(var a=0,u=Math.min(n,i);a>>1;case"base64":return It(e).length;default:if(n)return St(e).length;t=(""+t).toLowerCase();n=true}}}c.byteLength=et;function tt(e,t,r){var n=false;if(t===undefined||t<0){t=0}if(t>this.length){return""}if(r===undefined||r>this.length){r=this.length}if(r<=0){return""}r>>>=0;t>>>=0;if(r<=t){return""}if(!e)e="utf8";while(true){switch(e){case"hex":return yt(this,t,r);case"utf8":case"utf-8":return ht(this,t,r);case"ascii":return dt(this,t,r);case"latin1":case"binary":return vt(this,t,r);case"base64":return lt(this,t,r);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return mt(this,t,r);default:if(n)throw new TypeError("Unknown encoding: "+e);e=(e+"").toLowerCase();n=true}}}c.prototype._isBuffer=true;function rt(e,t,r){var n=e[t];e[t]=e[r];e[r]=n}c.prototype.swap16=function e(){var t=this.length;if(t%2!==0){throw new RangeError("Buffer size must be a multiple of 16-bits")}for(var r=0;r0){t=this.toString("hex",0,r).match(/.{2}/g).join(" ");if(this.length>r)t+=" ... "}return""};c.prototype.compare=function e(t,r,n,i,a){if(!Xe(t)){throw new TypeError("Argument must be a Buffer")}if(r===undefined){r=0}if(n===undefined){n=t?t.length:0}if(i===undefined){i=0}if(a===undefined){a=this.length}if(r<0||n>t.length||i<0||a>this.length){throw new RangeError("out of range index")}if(i>=a&&r>=n){return 0}if(i>=a){return-1}if(r>=n){return 1}r>>>=0;n>>>=0;i>>>=0;a>>>=0;if(this===t)return 0;var u=a-i;var o=n-r;var s=Math.min(u,o);var c=this.slice(i,a);var f=t.slice(r,n);for(var l=0;l2147483647){r=2147483647}else if(r<-2147483648){r=-2147483648}r=+r;if(isNaN(r)){r=i?0:e.length-1}if(r<0)r=e.length+r;if(r>=e.length){if(i)return-1;else r=e.length-1}else if(r<0){if(i)r=0;else return-1}if(typeof t==="string"){t=c.from(t,n)}if(Xe(t)){if(t.length===0){return-1}return it(e,t,r,n,i)}else if(typeof t==="number"){t=t&255;if(c.TYPED_ARRAY_SUPPORT&&typeof Uint8Array.prototype.indexOf==="function"){if(i){return Uint8Array.prototype.indexOf.call(e,t,r)}else{return Uint8Array.prototype.lastIndexOf.call(e,t,r)}}return it(e,[t],r,n,i)}throw new TypeError("val must be string, number or Buffer")}function it(e,t,r,n,i){var a=1;var u=e.length;var o=t.length;if(n!==undefined){n=String(n).toLowerCase();if(n==="ucs2"||n==="ucs-2"||n==="utf16le"||n==="utf-16le"){if(e.length<2||t.length<2){return-1}a=2;u/=2;o/=2;r/=2}}function s(e,t){if(a===1){return e[t]}else{return e.readUInt16BE(t*a)}}var c;if(i){var f=-1;for(c=r;cu)r=u-o;for(c=r;c>=0;c--){var l=true;for(var h=0;hi){n=i}}var a=t.length;if(a%2!==0)throw new TypeError("Invalid hex string");if(n>a/2){n=a/2}for(var u=0;ua)n=a;if(t.length>0&&(n<0||r<0)||r>this.length){throw new RangeError("Attempt to write outside buffer bounds")}if(!i)i="utf8";var u=false;for(;;){switch(i){case"hex":return at(this,t,r,n);case"utf8":case"utf-8":return ut(this,t,r,n);case"ascii":return ot(this,t,r,n);case"latin1":case"binary":return st(this,t,r,n);case"base64":return ct(this,t,r,n);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return ft(this,t,r,n);default:if(u)throw new TypeError("Unknown encoding: "+i);i=(""+i).toLowerCase();u=true}}};c.prototype.toJSON=function e(){return{type:"Buffer",data:Array.prototype.slice.call(this._arr||this,0)}};function lt(e,t,r){if(t===0&&r===e.length){return Re(e)}else{return Re(e.slice(t,r))}}function ht(e,t,r){r=Math.min(e.length,r);var n=[];var i=t;while(i239?4:a>223?3:a>191?2:1;if(i+o<=r){var s,c,f,l;switch(o){case 1:if(a<128){u=a}break;case 2:s=e[i+1];if((s&192)===128){l=(a&31)<<6|s&63;if(l>127){u=l}}break;case 3:s=e[i+1];c=e[i+2];if((s&192)===128&&(c&192)===128){l=(a&15)<<12|(s&63)<<6|c&63;if(l>2047&&(l<55296||l>57343)){u=l}}break;case 4:s=e[i+1];c=e[i+2];f=e[i+3];if((s&192)===128&&(c&192)===128&&(f&192)===128){l=(a&15)<<18|(s&63)<<12|(c&63)<<6|f&63;if(l>65535&&l<1114112){u=l}}}}if(u===null){u=65533;o=1}else if(u>65535){u-=65536;n.push(u>>>10&1023|55296);u=56320|u&1023}n.push(u);i+=o}return _t(n)}var pt=4096;function _t(e){var t=e.length;if(t<=pt){return String.fromCharCode.apply(String,e)}var r="";var n=0;while(nn)r=n;var i="";for(var a=t;an){t=n}if(r<0){r+=n;if(r<0)r=0}else if(r>n){r=n}if(rr)throw new RangeError("Trying to access beyond buffer length")}c.prototype.readUIntLE=function e(t,r,n){t=t|0;r=r|0;if(!n)gt(t,r,this.length);var i=this[t];var a=1;var u=0;while(++u0&&(a*=256)){i+=this[t+--r]*a}return i};c.prototype.readUInt8=function e(t,r){if(!r)gt(t,1,this.length);return this[t]};c.prototype.readUInt16LE=function e(t,r){if(!r)gt(t,2,this.length);return this[t]|this[t+1]<<8};c.prototype.readUInt16BE=function e(t,r){if(!r)gt(t,2,this.length);return this[t]<<8|this[t+1]};c.prototype.readUInt32LE=function e(t,r){if(!r)gt(t,4,this.length);return(this[t]|this[t+1]<<8|this[t+2]<<16)+this[t+3]*16777216};c.prototype.readUInt32BE=function e(t,r){if(!r)gt(t,4,this.length);return this[t]*16777216+(this[t+1]<<16|this[t+2]<<8|this[t+3])};c.prototype.readIntLE=function e(t,r,n){t=t|0;r=r|0;if(!n)gt(t,r,this.length);var i=this[t];var a=1;var u=0;while(++u=a)i-=Math.pow(2,8*r);return i};c.prototype.readIntBE=function e(t,r,n){t=t|0;r=r|0;if(!n)gt(t,r,this.length);var i=r;var a=1;var u=this[t+--i];while(i>0&&(a*=256)){u+=this[t+--i]*a}a*=128;if(u>=a)u-=Math.pow(2,8*r);return u};c.prototype.readInt8=function e(t,r){if(!r)gt(t,1,this.length);if(!(this[t]&128))return this[t];return(255-this[t]+1)*-1};c.prototype.readInt16LE=function e(t,r){if(!r)gt(t,2,this.length);var n=this[t]|this[t+1]<<8;return n&32768?n|4294901760:n};c.prototype.readInt16BE=function e(t,r){if(!r)gt(t,2,this.length);var n=this[t+1]|this[t]<<8;return n&32768?n|4294901760:n};c.prototype.readInt32LE=function e(t,r){if(!r)gt(t,4,this.length);return this[t]|this[t+1]<<8|this[t+2]<<16|this[t+3]<<24};c.prototype.readInt32BE=function e(t,r){if(!r)gt(t,4,this.length);return this[t]<<24|this[t+1]<<16|this[t+2]<<8|this[t+3]};c.prototype.readFloatLE=function e(t,r){if(!r)gt(t,4,this.length);return Te(this,t,true,23,4)};c.prototype.readFloatBE=function e(t,r){if(!r)gt(t,4,this.length);return Te(this,t,false,23,4)};c.prototype.readDoubleLE=function e(t,r){if(!r)gt(t,8,this.length);return Te(this,t,true,52,8)};c.prototype.readDoubleBE=function e(t,r){if(!r)gt(t,8,this.length);return Te(this,t,false,52,8)};function bt(e,t,r,n,i,a){if(!Xe(e))throw new TypeError('"buffer" argument must be a Buffer instance');if(t>i||te.length)throw new RangeError("Index out of range")}c.prototype.writeUIntLE=function e(t,r,n,i){t=+t;r=r|0;n=n|0;if(!i){var a=Math.pow(2,8*n)-1;bt(this,t,r,n,a,0)}var u=1;var o=0;this[r]=t&255;while(++o=0&&(o*=256)){this[r+u]=t/o&255}return r+n};c.prototype.writeUInt8=function e(t,r,n){t=+t;r=r|0;if(!n)bt(this,t,r,1,255,0);if(!c.TYPED_ARRAY_SUPPORT)t=Math.floor(t);this[r]=t&255;return r+1};function wt(e,t,r,n){if(t<0)t=65535+t+1;for(var i=0,a=Math.min(e.length-r,2);i>>(n?i:1-i)*8}}c.prototype.writeUInt16LE=function e(t,r,n){t=+t;r=r|0;if(!n)bt(this,t,r,2,65535,0);if(c.TYPED_ARRAY_SUPPORT){this[r]=t&255;this[r+1]=t>>>8}else{wt(this,t,r,true)}return r+2};c.prototype.writeUInt16BE=function e(t,r,n){t=+t;r=r|0;if(!n)bt(this,t,r,2,65535,0);if(c.TYPED_ARRAY_SUPPORT){this[r]=t>>>8;this[r+1]=t&255}else{wt(this,t,r,false)}return r+2};function Dt(e,t,r,n){if(t<0)t=4294967295+t+1;for(var i=0,a=Math.min(e.length-r,4);i>>(n?i:3-i)*8&255}}c.prototype.writeUInt32LE=function e(t,r,n){t=+t;r=r|0;if(!n)bt(this,t,r,4,4294967295,0);if(c.TYPED_ARRAY_SUPPORT){this[r+3]=t>>>24;this[r+2]=t>>>16;this[r+1]=t>>>8;this[r]=t&255}else{Dt(this,t,r,true)}return r+4};c.prototype.writeUInt32BE=function e(t,r,n){t=+t;r=r|0;if(!n)bt(this,t,r,4,4294967295,0);if(c.TYPED_ARRAY_SUPPORT){this[r]=t>>>24;this[r+1]=t>>>16;this[r+2]=t>>>8;this[r+3]=t&255}else{Dt(this,t,r,false)}return r+4};c.prototype.writeIntLE=function e(t,r,n,i){t=+t;r=r|0;if(!i){var a=Math.pow(2,8*n-1);bt(this,t,r,n,a-1,-a)}var u=0;var o=1;var s=0;this[r]=t&255;while(++u>0)-s&255}return r+n};c.prototype.writeIntBE=function e(t,r,n,i){t=+t;r=r|0;if(!i){var a=Math.pow(2,8*n-1);bt(this,t,r,n,a-1,-a)}var u=n-1;var o=1;var s=0;this[r+u]=t&255;while(--u>=0&&(o*=256)){if(t<0&&s===0&&this[r+u+1]!==0){s=1}this[r+u]=(t/o>>0)-s&255}return r+n};c.prototype.writeInt8=function e(t,r,n){t=+t;r=r|0;if(!n)bt(this,t,r,1,127,-128);if(!c.TYPED_ARRAY_SUPPORT)t=Math.floor(t);if(t<0)t=255+t+1;this[r]=t&255;return r+1};c.prototype.writeInt16LE=function e(t,r,n){t=+t;r=r|0;if(!n)bt(this,t,r,2,32767,-32768);if(c.TYPED_ARRAY_SUPPORT){this[r]=t&255;this[r+1]=t>>>8}else{wt(this,t,r,true)}return r+2};c.prototype.writeInt16BE=function e(t,r,n){t=+t;r=r|0;if(!n)bt(this,t,r,2,32767,-32768);if(c.TYPED_ARRAY_SUPPORT){this[r]=t>>>8;this[r+1]=t&255}else{wt(this,t,r,false)}return r+2};c.prototype.writeInt32LE=function e(t,r,n){t=+t;r=r|0;if(!n)bt(this,t,r,4,2147483647,-2147483648);if(c.TYPED_ARRAY_SUPPORT){this[r]=t&255;this[r+1]=t>>>8;this[r+2]=t>>>16;this[r+3]=t>>>24}else{Dt(this,t,r,true)}return r+4};c.prototype.writeInt32BE=function e(t,r,n){t=+t;r=r|0;if(!n)bt(this,t,r,4,2147483647,-2147483648);if(t<0)t=4294967295+t+1;if(c.TYPED_ARRAY_SUPPORT){this[r]=t>>>24;this[r+1]=t>>>16;this[r+2]=t>>>8;this[r+3]=t&255}else{Dt(this,t,r,false)}return r+4};function Et(e,t,r,n,i,a){if(r+n>e.length)throw new RangeError("Index out of range");if(r<0)throw new RangeError("Index out of range")}function xt(e,t,r,n,i){if(!i){Et(e,t,r,4)}Le(e,t,r,n,23,4);return r+4}c.prototype.writeFloatLE=function e(t,r,n){return xt(this,t,r,true,n)};c.prototype.writeFloatBE=function e(t,r,n){return xt(this,t,r,false,n)};function At(e,t,r,n,i){if(!i){Et(e,t,r,8)}Le(e,t,r,n,52,8);return r+8}c.prototype.writeDoubleLE=function e(t,r,n){return At(this,t,r,true,n)};c.prototype.writeDoubleBE=function e(t,r,n){return At(this,t,r,false,n)};c.prototype.copy=function e(t,r,n,i){if(!n)n=0;if(!i&&i!==0)i=this.length;if(r>=t.length)r=t.length;if(!r)r=0;if(i>0&&i=this.length)throw new RangeError("sourceStart out of bounds");if(i<0)throw new RangeError("sourceEnd out of bounds");if(i>this.length)i=this.length;if(t.length-r=0;--u){t[u+r]=this[u+n]}}else if(a<1e3||!c.TYPED_ARRAY_SUPPORT){for(u=0;u>>0;n=n===undefined?this.length:n>>>0;if(!t)t=0;var u;if(typeof t==="number"){for(u=r;u55295&&r<57344){if(!i){if(r>56319){if((t-=3)>-1)a.push(239,191,189);continue}else if(u+1===n){if((t-=3)>-1)a.push(239,191,189);continue}i=r;continue}if(r<56320){if((t-=3)>-1)a.push(239,191,189);i=r;continue}r=(i-55296<<10|r-56320)+65536}else if(i){if((t-=3)>-1)a.push(239,191,189)}i=null;if(r<128){if((t-=1)<0)break;a.push(r)}else if(r<2048){if((t-=2)<0)break;a.push(r>>6|192,r&63|128)}else if(r<65536){if((t-=3)<0)break;a.push(r>>12|224,r>>6&63|128,r&63|128)}else if(r<1114112){if((t-=4)<0)break;a.push(r>>18|240,r>>12&63|128,r>>6&63|128,r&63|128)}else{throw new Error("Invalid code point")}}return a}function Bt(e){var t=[];for(var r=0;r>8;i=r%256;a.push(i);a.push(n)}return a}function It(e){return Ie(kt(e))}function Pt(e,t,r,n){for(var i=0;i=t.length||i>=e.length)break;t[i+r]=e[i]}return i}function Nt(e){return e!==e}function Rt(e){return e!=null&&(!!e._isBuffer||Tt(e)||Lt(e))}function Tt(e){return!!e.constructor&&typeof e.constructor.isBuffer==="function"&&e.constructor.isBuffer(e)}function Lt(e){return typeof e.readFloatLE==="function"&&typeof e.slice==="function"&&Tt(e.slice(0,0))}let Mt;try{Mt=new TextDecoder}catch(e){}let v;let Ut;let y=0;const qt=105;const zt=57342;const Yt=57343;const Vt=57337;const $t=6;const Jt={};let _={};let Kt;let Ht;let Wt=0;let Gt=0;let Qt;let Zt;let Xt=[];let er=[];let tr;let rr;let nr;let ir={useRecords:false,mapsAsObjects:true};let ar=false;let ur=2;try{new Function("")}catch(e){ur=Infinity}class or{constructor(r){if(r){if((r.keyMap||r._keyMap)&&!r.useRecords){r.useRecords=false;r.mapsAsObjects=true}if(r.useRecords===false&&r.mapsAsObjects===undefined)r.mapsAsObjects=true;if(r.getStructures)r.getShared=r.getStructures;if(r.getShared&&!r.structures)(r.structures=[]).uninitialized=true;if(r.keyMap){this.mapKey=new Map;for(let[e,t]of Object.entries(r.keyMap))this.mapKey.set(t,e)}}Object.assign(this,r)}decodeKey(e){return this.keyMap?this.mapKey.get(e)||e:e}encodeKey(e){return this.keyMap&&this.keyMap.hasOwnProperty(e)?this.keyMap[e]:e}encodeKeys(r){if(!this._keyMap)return r;let n=new Map;for(let[e,t]of Object.entries(r))n.set(this._keyMap.hasOwnProperty(e)?this._keyMap[e]:e,t);return n}decodeKeys(e){if(!this._keyMap||e.constructor.name!="Map")return e;if(!this._mapKey){this._mapKey=new Map;for(let[e,t]of Object.entries(this._keyMap))this._mapKey.set(t,e)}let r={};e.forEach((e,t)=>r[lr(this._mapKey.has(t)?this._mapKey.get(t):t)]=e);return r}mapDecode(e,t){let r=this.decode(e);if(this._keyMap){switch(r.constructor.name){case"Array":return r.map(e=>this.decodeKeys(e))}}return r}decode(t,e){if(v){return Nr(()=>{Rr();return this?this.decode(t,e):or.prototype.decode.call(ir,t,e)})}Ut=e>-1?e:t.length;y=0;Gt=0;Ht=null;Qt=null;v=t;try{rr=t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))}catch(e){v=null;if(t instanceof Uint8Array)throw e;throw new Error("Source must be a Uint8Array or Buffer but was a "+(t&&typeof t=="object"?t.constructor.name:typeof t))}if(this instanceof or){_=this;tr=this.sharedValues&&(this.pack?new Array(this.maxPrivatePackedValues||16).concat(this.sharedValues):this.sharedValues);if(this.structures){Kt=this.structures;return sr()}else if(!Kt||Kt.length>0){Kt=[]}}else{_=ir;if(!Kt||Kt.length>0)Kt=[];tr=null}return sr()}decodeMultiple(r,n){let i,a=0;try{let e=r.length;ar=true;let t=this?this.decode(r,e):Mr.decode(r,e);if(n){if(n(t)===false){return}while(y=Qt.postBundlePosition){let e=new Error("Unexpected bundle position");e.incomplete=true;throw e}y=Qt.postBundlePosition;Qt=null}if(y==Ut){Kt=null;v=null;if(Zt)Zt=null}else if(y>Ut){let e=new Error("Unexpected end of CBOR data");e.incomplete=true;throw e}else if(!ar){throw new Error("Data read, but end of buffer not reached")}return e}catch(e){Rr();if(e instanceof RangeError||e.message.startsWith("Unexpected end of buffer")){e.incomplete=true}throw e}}function a(){let n=v[y++];let i=n>>5;n=n&31;if(n>23){switch(n){case 24:n=v[y++];break;case 25:if(i==7){return br()}n=rr.getUint16(y);y+=2;break;case 26:if(i==7){let t=rr.getFloat32(y);if(_.useFloat32>2){let e=Lr[(v[y]&127)<<1|v[y+1]>>7];y+=4;return(e*t+(t>0?.5:-.5)>>0)/e}y+=4;return t}n=rr.getUint32(y);y+=4;break;case 27:if(i==7){let e=rr.getFloat64(y);y+=8;return e}if(i>1){if(rr.getUint32(y)>0)throw new Error("JavaScript does not support arrays, maps, or strings with length over 4294967295");n=rr.getUint32(y+4)}else if(_.int64AsNumber){n=rr.getUint32(y)*4294967296;n+=rr.getUint32(y+4)}else n=rr.getBigUint64(y);y+=8;break;case 31:switch(i){case 2:case 3:throw new Error("Indefinite length not supported for byte or text strings");case 4:let e=[];let t,r=0;while((t=a())!=Jt){e[r++]=t}return i==4?e:i==3?e.join(""):c.concat(e);case 5:let n;if(_.mapsAsObjects){let e={};if(_.keyMap)while((n=a())!=Jt)e[lr(_.decodeKey(n))]=a();else while((n=a())!=Jt)e[lr(n)]=a();return e}else{if(nr){_.mapsAsObjects=true;nr=false}let e=new Map;if(_.keyMap)while((n=a())!=Jt)e.set(_.decodeKey(n),a());else while((n=a())!=Jt)e.set(n,a());return e}case 7:return Jt;default:throw new Error("Invalid major type for indefinite length "+i)}default:throw new Error("Unknown token "+n)}}switch(i){case 0:return n;case 1:return~n;case 2:return yr(n);case 3:if(Gt>=y){return Ht.slice(y-Wt,(y+=n)-Wt)}if(Gt==0&&Ut<140&&n<32){let e=n<16?vr(n):dr(n);if(e!=null)return e}return hr(n);case 4:let t=new Array(n);for(let e=0;e=Vt){let e=Kt[n&8191];if(e){if(!e.read)e.read=fr(e);return e.read()}if(n<65536){if(n==Yt){let e=Ir();let t=a();let r=a();Dr(t,r);let n={};if(_.keyMap)for(let t=2;t23){switch(t){case 24:t=v[y++];break;case 25:t=rr.getUint16(y);y+=2;break;case 26:t=rr.getUint32(y);y+=4;break;default:throw new Error("Expected array header, but got "+v[y-1])}}let r=this.compiledReader;while(r){if(r.propertyCount===t)return r(a);r=r.next}if(this.slowReads++>=ur){let e=this.length==t?this:this.slice(0,t);r=_.keyMap?new Function("r","return {"+e.map(e=>_.decodeKey(e)).map(e=>cr.test(e)?lr(e)+":r()":"["+JSON.stringify(e)+"]:r()").join(",")+"}"):new Function("r","return {"+e.map(e=>cr.test(e)?lr(e)+":r()":"["+JSON.stringify(e)+"]:r()").join(",")+"}");if(this.compiledReader)r.next=this.compiledReader;r.propertyCount=t;this.compiledReader=r;return r(a)}let n={};if(_.keyMap)for(let e=0;e64&&Mt)return Mt.decode(v.subarray(y,y+=e));const r=y+e;const n=[];t="";while(y65535){e-=65536;n.push(e>>>10&1023|55296);e=56320|e&1023}n.push(e)}else{n.push(i)}if(n.length>=4096){t+=_r.apply(String,n);n.length=0}}if(n.length>0){t+=_r.apply(String,n)}return t}let _r=String.fromCharCode;function dr(t){let r=y;let n=new Array(t);for(let e=0;e0){y=r;return}n[e]=i}return _r.apply(String,n)}function vr(d){if(d<4){if(d<2){if(d===0)return"";else{let e=v[y++];if((e&128)>1){y-=1;return}return _r(e)}}else{let e=v[y++];let t=v[y++];if((e&128)>0||(t&128)>0){y-=2;return}if(d<3)return _r(e,t);let r=v[y++];if((r&128)>0){y-=3;return}return _r(e,t,r)}}else{let l=v[y++];let h=v[y++];let p=v[y++];let _=v[y++];if((l&128)>0||(h&128)>0||(p&128)>0||(_&128)>0){y-=4;return}if(d<6){if(d===4)return _r(l,h,p,_);else{let e=v[y++];if((e&128)>0){y-=5;return}return _r(l,h,p,_,e)}}else if(d<8){let e=v[y++];let t=v[y++];if((e&128)>0||(t&128)>0){y-=6;return}if(d<7)return _r(l,h,p,_,e,t);let r=v[y++];if((r&128)>0){y-=7;return}return _r(l,h,p,_,e,t,r)}else{let o=v[y++];let s=v[y++];let c=v[y++];let f=v[y++];if((o&128)>0||(s&128)>0||(c&128)>0||(f&128)>0){y-=8;return}if(d<10){if(d===8)return _r(l,h,p,_,o,s,c,f);else{let e=v[y++];if((e&128)>0){y-=9;return}return _r(l,h,p,_,o,s,c,f,e)}}else if(d<12){let e=v[y++];let t=v[y++];if((e&128)>0||(t&128)>0){y-=10;return}if(d<11)return _r(l,h,p,_,o,s,c,f,e,t);let r=v[y++];if((r&128)>0){y-=11;return}return _r(l,h,p,_,o,s,c,f,e,t,r)}else{let n=v[y++];let i=v[y++];let a=v[y++];let u=v[y++];if((n&128)>0||(i&128)>0||(a&128)>0||(u&128)>0){y-=12;return}if(d<14){if(d===12)return _r(l,h,p,_,o,s,c,f,n,i,a,u);else{let e=v[y++];if((e&128)>0){y-=13;return}return _r(l,h,p,_,o,s,c,f,n,i,a,u,e)}}else{let e=v[y++];let t=v[y++];if((e&128)>0||(t&128)>0){y-=14;return}if(d<15)return _r(l,h,p,_,o,s,c,f,n,i,a,u,e,t);let r=v[y++];if((r&128)>0){y-=15;return}return _r(l,h,p,_,o,s,c,f,n,i,a,u,e,t,r)}}}}}function yr(e){return _.copyBuffers?Uint8Array.prototype.slice.call(v,y,y+=e):v.subarray(y,y+=e)}let mr=new Float32Array(1);let gr=new Uint8Array(mr.buffer,0,4);function br(){let t=v[y++];let r=v[y++];let e=(t&127)>>2;if(e===31){if(r||t&3)return NaN;return t&128?-Infinity:Infinity}if(e===0){let e=((t&3)<<8|r)/(1<<24);return t&128?-e:e}gr[3]=t&128|(e>>1)+56;gr[2]=(t&7)<<5|r>>3;gr[1]=r<<5;gr[0]=0;return mr[0]}new Array(4096);class wr{constructor(e,t){this.value=e;this.tag=t}}Xt[0]=e=>{return new Date(e)};Xt[1]=e=>{return new Date(Math.round(e*1e3))};Xt[2]=r=>{let n=BigInt(0);for(let e=0,t=r.byteLength;e{return BigInt(-1)-Xt[2](e)};Xt[4]=e=>{return+(e[1]+"e"+e[0])};Xt[5]=e=>{return e[1]*Math.exp(e[0]*Math.log(2))};const Dr=(e,t)=>{e=e-57344;let r=Kt[e];if(r&&r.isShared){(Kt.restoreStructures||(Kt.restoreStructures=[]))[e]=r}Kt[e]=t;t.read=fr(t)};Xt[qt]=r=>{let e=r.length;let n=r[1];Dr(r[0],n);let i={};for(let t=2;t{if(Qt)return Qt[0].slice(Qt.position0,Qt.position0+=e);return new wr(e,14)};Xt[15]=e=>{if(Qt)return Qt[1].slice(Qt.position1,Qt.position1+=e);return new wr(e,15)};let Er={Error:Error,RegExp:RegExp};Xt[27]=e=>{return(Er[e[0]]||Error)(e[1],e[2])};const xr=e=>{if(v[y++]!=132){let e=new Error("Packed values structure must be followed by a 4 element array");if(v.length{if(!tr){if(_.getShared)Pr();else return new wr(e,$t)}if(typeof e=="number")return tr[16+(e>=0?2*e:-2*e-1)];let t=new Error("No support for non-integer packed references yet");if(e===undefined)t.incomplete=true;throw t};Xt[28]=e=>{if(!Zt){Zt=new Map;Zt.id=0}let t=Zt.id++;let r=v[y];let n;if(r>>5==4)n=[];else n={};let i={target:n};Zt.set(t,i);let a=e();if(i.used)return Object.assign(n,a);i.target=a;return a};Xt[28].handlesRead=true;Xt[29]=e=>{let t=Zt.get(e);t.used=true;return t.target};Xt[258]=e=>new Set(e);(Xt[259]=e=>{if(_.mapsAsObjects){_.mapsAsObjects=false;nr=true}return e()}).handlesRead=true;function Ar(e,t){if(typeof e==="string")return e+t;if(e instanceof Array)return e.concat(t);return Object.assign({},e,t)}function Fr(){if(!tr){if(_.getShared)Pr();else throw new Error("No packed values available")}return tr}const kr=1399353956;er.push((e,t)=>{if(e>=225&&e<=255)return Ar(Fr().prefixes[e-224],t);if(e>=28704&&e<=32767)return Ar(Fr().prefixes[e-28672],t);if(e>=1879052288&&e<=2147483647)return Ar(Fr().prefixes[e-1879048192],t);if(e>=216&&e<=223)return Ar(t,Fr().suffixes[e-216]);if(e>=27647&&e<=28671)return Ar(t,Fr().suffixes[e-27639]);if(e>=1811940352&&e<=1879048191)return Ar(t,Fr().suffixes[e-1811939328]);if(e==kr){return{packedValues:tr,structures:Kt.slice(0),version:t}}if(e==55799)return t});const Cr=new Uint8Array(new Uint16Array([1]).buffer)[0]==1;const Or=[Uint8Array,Uint8ClampedArray,Uint16Array,Uint32Array,typeof BigUint64Array=="undefined"?{name:"BigUint64Array"}:BigUint64Array,Int8Array,Int16Array,Int32Array,typeof BigInt64Array=="undefined"?{name:"BigInt64Array"}:BigInt64Array,Float32Array,Float64Array];const Sr=[64,68,69,70,71,72,77,78,79,85,86];for(let e=0;e{if(!o)throw new Error("Could not find typed array for code "+s);if(!_.copyBuffers){if(t===1||t===2&&!(e.byteOffset&1)||t===4&&!(e.byteOffset&3)||t===8&&!(e.byteOffset&7))return new o(e.buffer,e.byteOffset,e.byteLength)}return new o(Uint8Array.prototype.slice.call(e,0).buffer)}:e=>{if(!o)throw new Error("Could not find typed array for code "+s);let t=new DataView(e.buffer,e.byteOffset,e.byteLength);let r=e.length>>a;let n=new o(r);let i=t[c];for(let e=0;e23){switch(e){case 24:e=v[y++];break;case 25:e=rr.getUint16(y);y+=2;break;case 26:e=rr.getUint32(y);y+=4;break}}return e}function Pr(){if(_.getShared){let e=Nr(()=>{v=null;return _.getShared()})||{};let t=e.structures||[];_.sharedVersion=e.version;tr=_.sharedValues=e.packedValues;if(Kt===true)_.structures=Kt=t;else Kt.splice.apply(Kt,[0,t.length].concat(t))}}function Nr(e){let t=Ut;let r=y;let n=Wt;let i=Gt;let a=Ht;let u=Zt;let o=Qt;let s=new Uint8Array(v.slice(0,Ut));let c=Kt;let f=_;let l=ar;let h=e();Ut=t;y=r;Wt=n;Gt=i;Ht=a;Zt=u;Qt=o;v=s;ar=l;Kt=c;_=f;rr=new DataView(v.buffer,v.byteOffset,v.byteLength);return h}function Rr(){v=null;Zt=null;Kt=null}function Tr(e){Xt[e.tag]=e.decode}const Lr=new Array(147);for(let e=0;e<256;e++){Lr[e]=+("1e"+Math.floor(45.15-e*.30103))}let Mr=new or({useRecords:false});Mr.decode;Mr.decodeMultiple;let Ur;try{Ur=new TextEncoder}catch(e){}let qr,zr;const Yr=typeof globalThis==="object"&&globalThis.Buffer;const Vr=typeof Yr!=="undefined";const $r=Vr?Yr.allocUnsafeSlow:Uint8Array;const Jr=Vr?Yr:Uint8Array;const Kr=256;const Hr=Vr?4294967296:2144337920;let Wr;let O;let S;let B=0;let Gr;let Qr=null;const Zr=61440;const Xr=/[\u0080-\uFFFF]/;const en=Symbol("record-id");class tn extends or{constructor(r){super(r);this.offset=0;let s;let u;let f;let l;let n;r=r||{};let c=Jr.prototype.utf8Write?function(e,t,r){return O.utf8Write(e,t,r)}:Ur&&Ur.encodeInto?function(e,t){return Ur.encodeInto(e,O.subarray(t)).written}:false;let a=this;let e=r.structures||r.saveStructures;let h=r.maxSharedStructures;if(h==null)h=e?128:0;if(h>8190)throw new Error("Maximum maxSharedStructure is 8190");let i=r.sequential;if(i){h=0}if(!this.structures)this.structures=[];if(this.saveStructures)this.saveShared=this.saveStructures;let p,_,o=r.sharedValues;let d;if(o){d=Object.create(null);for(let e=0,t=o.length;ethis.encodeKeys(e));break}}return this.encode(e,t)};this.encode=function(t,e){if(!O){O=new $r(8192);S=new DataView(O.buffer,0,8192);B=0}Gr=O.length-10;if(Gr-B<2048){O=new $r(O.length);S=new DataView(O.buffer,0,O.length);Gr=O.length-10;B=0}else if(e===vn)B=B+7&2147483640;s=B;if(a.useSelfDescribedHeader){S.setUint32(B,3654940416);B+=3}n=a.structuredClone?new Map:null;if(a.bundleStrings&&typeof t!=="string"){Qr=[];Qr.size=Infinity}else Qr=null;u=a.structures;if(u){if(u.uninitialized){let e=a.getShared()||{};a.structures=u=e.structures||[];a.sharedVersion=e.version;let r=a.sharedValues=e.packedValues;if(r){d={};for(let e=0,t=r.length;eh&&!i)e=h;if(!u.transitions){u.transitions=Object.create(null);for(let a=0;a0){O[B++]=216;O[B++]=51;an(4);let r=e.values;g(r);an(0);an(0);_=Object.create(d||null);for(let e=0,t=r.length;eGr)w(B);a.offset=B;let e=hn(O.subarray(s,B),n.idsToInsert);n=null;return e}if(e&vn){O.start=s;O.end=B;return O}return O.subarray(s,B)}finally{if(u){if(m<10)m++;if(u.length>h)u.length=h;if(y>1e4){u.transitions=null;m=0;y=0;if(v.length>0)v=[]}else if(v.length>0&&!i){for(let e=0,t=v.length;eh){a.structures=a.structures.slice(0,h)}let e=O.subarray(s,B);if(a.updateSharedData()===false)return a.encode(t);return e}if(e&yn)B=s}};this.findCommonStringsToPack=()=>{p=new Map;if(!d)d=Object.create(null);return e=>{let r=e&&e.threshold||4;let n=this.pack?e.maxPrivatePackedValues||16:0;if(!o)o=this.sharedValues=[];for(let[e,t]of p){if(t.count>r){d[e]=n++;o.push(e);f=true}}while(this.saveShared&&this.updateSharedData()===false){}p=null}};const g=u=>{if(B>Gr)O=w(B);var e=typeof u;var o;if(e==="string"){if(_){let e=_[u];if(e>=0){if(e<16)O[B++]=e+224;else{O[B++]=198;if(e&1)g(15-e>>1);else g(e-16>>1)}return}else if(p&&!r.pack){let e=p.get(u);if(e)e.count++;else p.set(u,{count:1})}}let i=u.length;if(Qr&&i>=4&&i<1024){if((Qr.size+=i)>Zr){let e;let t=(Qr[0]?Qr[0].length*3+Qr[1].length:0)+10;if(B+t>Gr)O=w(B+t);O[B++]=217;O[B++]=223;O[B++]=249;O[B++]=Qr.position?132:130;O[B++]=26;e=B-s;B+=4;if(Qr.position){pn(s,g)}Qr=["",""];Qr.size=0;Qr.position=e}let e=Xr.test(u);Qr[e?0:1]+=u;O[B++]=e?206:207;g(i);return}let a;if(i<32){a=1}else if(i<256){a=2}else if(i<65536){a=3}else{a=5}let e=i*3;if(B+e>Gr)O=w(B+e);if(i<64||!c){let e,t,r,n=B+a;for(e=0;e>6|192;O[n++]=t&63|128}else if((t&64512)===55296&&((r=u.charCodeAt(e+1))&64512)===56320){t=65536+((t&1023)<<10)+(r&1023);e++;O[n++]=t>>18|240;O[n++]=t>>12&63|128;O[n++]=t>>6&63|128;O[n++]=t&63|128}else{O[n++]=t>>12|224;O[n++]=t>>6&63|128;O[n++]=t&63|128}}o=n-B-a}else{o=c(u,B+a,e)}if(o<24){O[B++]=96|o}else if(o<256){if(a<2){O.copyWithin(B+2,B+1,B+1+o)}O[B++]=120;O[B++]=o}else if(o<65536){if(a<3){O.copyWithin(B+3,B+2,B+2+o)}O[B++]=121;O[B++]=o>>8;O[B++]=o&255}else{if(a<5){O.copyWithin(B+5,B+3,B+3+o)}O[B++]=122;S.setUint32(B,o);B+=4}B+=o}else if(e==="number"){if(!this.alwaysUseFloat&&u>>>0===u){if(u<24){O[B++]=u}else if(u<256){O[B++]=24;O[B++]=u}else if(u<65536){O[B++]=25;O[B++]=u>>8;O[B++]=u&255}else{O[B++]=26;S.setUint32(B,u);B+=4}}else if(!this.alwaysUseFloat&&u>>0===u){if(u>=-24){O[B++]=31-u}else if(u>=-256){O[B++]=56;O[B++]=~u}else if(u>=-65536){O[B++]=57;S.setUint16(B,~u);B+=2}else{O[B++]=58;S.setUint32(B,~u);B+=4}}else{let t;if((t=this.useFloat32)>0&&u<4294967296&&u>=-2147483648){O[B++]=250;S.setFloat32(B,u);let e;if(t<4||(e=u*Lr[(O[B]&127)<<1|O[B+1]>>7])>>0===e){B+=4;return}else B--}O[B++]=251;S.setFloat64(B,u);B+=8}}else if(e==="object"){if(!u)O[B++]=246;else{if(n){let t=n.get(u);if(t){O[B++]=216;O[B++]=29;O[B++]=25;if(!t.references){let e=n.idsToInsert||(n.idsToInsert=[]);t.references=[];e.push(t)}t.references.push(B-s);B+=2;return}else n.set(u,{offset:B-s})}let e=u.constructor;if(e===Object){b(u,true)}else if(e===Array){o=u.length;if(o<24){O[B++]=128|o}else{an(o)}for(let e=0;e>8;O[B++]=o&255}else{O[B++]=186;S.setUint32(B,o);B+=4}if(a.keyMap){for(let[e,t]of u){g(a.encodeKey(e));g(t)}}else{for(let[e,t]of u){g(e);g(t)}}}else{for(let r=0,e=qr.length;r>8;O[B++]=t&255}else if(t>-1){O[B++]=218;S.setUint32(B,t);B+=4}e.encode.call(this,u,g,w);return}}if(u[Symbol.iterator]){if(Wr){let e=new Error("Iterable should be serialized as iterator");e.iteratorNotHandled=true;throw e}O[B++]=159;for(let e of u){g(e)}O[B++]=255;return}if(u[Symbol.asyncIterator]||on(u)){let e=new Error("Iterable/blob should be serialized as iterator");e.iteratorNotHandled=true;throw e}if(this.useToJSON&&u.toJSON){const t=u.toJSON();if(t!==u)return g(t)}b(u,!u.hasOwnProperty)}}}else if(e==="boolean"){O[B++]=u?245:244}else if(e==="bigint"){if(u=0){O[B++]=27;S.setBigUint64(B,u)}else if(u>-(BigInt(1)<{let t=Object.keys(e);let r=Object.values(e);let n=t.length;if(n<24){O[B++]=160|n}else if(n<256){O[B++]=184;O[B++]=n}else if(n<65536){O[B++]=185;O[B++]=n>>8;O[B++]=n&255}else{O[B++]=186;S.setUint32(B,n);B+=4}if(a.keyMap){for(let e=0;e{O[B++]=185;let e=B-s;B+=2;let n=0;if(a.keyMap){for(let e in t)if(r||t.hasOwnProperty(e)){g(a.encodeKey(e));g(t[e]);n++}}else{for(let e in t)if(r||t.hasOwnProperty(e)){g(e);g(t[e]);n++}}O[e+++s]=n>>8;O[e+s]=n&255}:(t,r)=>{let n,i=l.transitions||(l.transitions=Object.create(null));let a=0;let u=0;let o;let s;if(this.keyMap){s=Object.keys(t).map(e=>this.encodeKey(e));u=s.length;for(let t=0;t>8|224;O[B++]=c&255}else{if(!s)s=i.__keys__||(i.__keys__=Object.keys(t));if(o===undefined){c=l.nextId++;if(!c){c=0;l.nextId=1}if(c>=Kr){l.nextId=(c=h)+1}}else{c=o}l[c]=s;if(c>8|224;O[B++]=c&255;i=l.transitions;for(let e=0;e=Kr-h)v.shift()[en]=undefined;v.push(i);an(u+2);g(57344+c);g(s);if(r===null)return;for(let e in t)if(r||t.hasOwnProperty(e))g(t[e]);return}}if(u<24){O[B++]=128|u}else{an(u)}if(r===null)return;for(let e in t)if(r||t.hasOwnProperty(e))g(t[e])};const w=e=>{let t;if(e>16777216){if(e-s>Hr)throw new Error("Encoded buffer would be larger than maximum buffer size");t=Math.min(Hr,Math.round(Math.max((e-s)*(e>67108864?1.25:2),4194304)/4096)*4096)}else t=(Math.max(e-s<<2,O.length-1)>>12)+1<<12;let r=new $r(t);S=new DataView(r.buffer,0,t);if(O.copy)O.copy(r,0,s,e);else r.set(O.slice(s,e));B-=s;s=0;Gr=r.length-10;return O=r};let D=100;let E=1e3;this.encodeAsIterable=function(e,t){return k(e,t,x)};this.encodeAsAsyncIterable=function(e,t){return k(e,t,C)};function*x(n,i,e){let t=n.constructor;if(t===Object){let r=a.useRecords!==false;if(r)b(n,null);else rn(Object.keys(n).length,160);for(let t in n){let e=n[t];if(!r)g(t);if(e&&typeof e==="object"){if(i[t])yield*x(e,i[t]);else yield*A(e,i,t)}else g(e)}}else if(t===Array){let e=n.length;an(e);for(let t=0;tD)){if(i.element)yield*x(e,i.element);else yield*A(e,i,"element")}else g(e)}}else if(n[Symbol.iterator]){O[B++]=159;for(let e of n){if(e&&(typeof e==="object"||B-s>D)){if(i.element)yield*x(e,i.element);else yield*A(e,i,"element")}else g(e)}O[B++]=255}else if(on(n)){rn(n.size,64);yield O.subarray(s,B);yield n;F()}else if(n[Symbol.asyncIterator]){O[B++]=159;yield O.subarray(s,B);yield n;F();O[B++]=255}else{g(n)}if(e&&B>s)yield O.subarray(s,B);else if(B-s>D){yield O.subarray(s,B);F()}}function*A(t,r,n){let i=B-s;try{g(t);if(B-s>D){yield O.subarray(s,B);F()}}catch(e){if(e.iteratorNotHandled){r[n]={};B=s+i;yield*x.call(this,t,r[n])}else throw e}}function F(){D=E;a.encode(null,mn)}function k(e,t,r){if(t&&t.chunkThreshold)D=E=t.chunkThreshold;else D=100;if(e&&typeof e==="object"){a.encode(null,mn);return r(e,a.iterateProperties||(a.iterateProperties={}),true)}return[a.encode(e)]}async function*C(e,t){for(let r of x(e,t,true)){let e=r.constructor;if(e===Jr||e===Uint8Array)yield r;else if(on(r)){let e=r.stream().getReader();let t;while(!(t=await e.read()).done){yield t.value}}else if(r[Symbol.asyncIterator]){for await(let e of r){F();if(e)yield*C(e,t.async||(t.async={}));else yield a.encode(e)}}else{yield r}}}}useBuffer(e){O=e;S=new DataView(O.buffer,O.byteOffset,O.byteLength);B=0}clearSharedData(){if(this.structures)this.structures=[];if(this.sharedValues)this.sharedValues=undefined}updateSharedData(){let t=this.sharedVersion||0;this.sharedVersion=t+1;let e=this.structures.slice(0);let r=new nn(e,this.sharedValues,this.sharedVersion);let n=this.saveShared(r,e=>(e&&e.version||0)==t);if(n===false){r=this.getShared()||{};this.structures=r.structures||[];this.sharedValues=r.packedValues;this.sharedVersion=r.version;this.structures.nextId=this.structures.length}else{e.forEach((e,t)=>this.structures[t]=e)}return n}}function rn(e,t){if(e<24)O[B++]=t|e;else if(e<256){O[B++]=t|24;O[B++]=e}else if(e<65536){O[B++]=t|25;O[B++]=e>>8;O[B++]=e&255}else{O[B++]=t|26;S.setUint32(B,e);B+=4}}class nn{constructor(e,t,r){this.structures=e;this.packedValues=t;this.version=r}}function an(e){if(e<24)O[B++]=128|e;else if(e<256){O[B++]=152;O[B++]=e}else if(e<65536){O[B++]=153;O[B++]=e>>8;O[B++]=e&255}else{O[B++]=154;S.setUint32(B,e);B+=4}}const un=typeof Blob==="undefined"?function(){}:Blob;function on(e){if(e instanceof un)return true;let t=e[Symbol.toStringTag];return t==="Blob"||t==="File"}function sn(r,n){switch(typeof r){case"string":if(r.length>3){if(n.objectMap[r]>-1||n.values.length>=n.maxValues)return;let e=n.get(r);if(e){if(++e.count==2){n.values.push(r)}}else{n.set(r,{count:1});if(n.samplingPackedValues){let e=n.samplingPackedValues.get(r);if(e)e.count++;else n.samplingPackedValues.set(r,{count:1})}}}break;case"object":if(r){if(r instanceof Array){for(let e=0,t=r.length;e=0&&r<4294967296){O[B++]=26;S.setUint32(B,r);B+=4}else{O[B++]=251;S.setFloat64(B,r);B+=8}}},{tag:258,encode(e,t){let r=Array.from(e);t(r)}},{tag:27,encode(e,t){t([e.name,e.message])}},{tag:27,encode(e,t){t(["RegExp",e.source,e.flags])}},{getTag(e){return e.tag},encode(e,t){t(e.value)}},{encode(e,t,r){ln(e,r)}},{getTag(e){if(e.constructor===Uint8Array){if(this.tagUint8Array||Vr&&this.tagUint8Array!==false)return 64}},encode(e,t,r){ln(e,r)}},fn(68,1),fn(69,2),fn(70,4),fn(71,8),fn(72,1),fn(77,2),fn(78,4),fn(79,8),fn(85,4),fn(86,8),{encode(t,n){let e=t.packedValues||[];let r=t.structures||[];if(e.values.length>0){O[B++]=216;O[B++]=51;an(4);let r=e.values;n(r);an(0);an(0);packedObjectMap=Object.create(sharedPackedObjectMap||null);for(let e=0,t=r.length;e1)e-=4;return{tag:e,encode:function e(t,r){let n=t.byteLength;let i=t.byteOffset||0;let a=t.buffer||t;r(Vr?Yr.from(a,i,n):new Uint8Array(a,i,n))}}}function ln(e,t){let r=e.byteLength;if(r<24){O[B++]=64+r}else if(r<256){O[B++]=88;O[B++]=r}else if(r<65536){O[B++]=89;O[B++]=r>>8;O[B++]=r&255}else{O[B++]=90;S.setUint32(B,r);B+=4}if(B+r>=O.length){t(B+r)}O.set(e.buffer?e:new Uint8Array(e),B);B+=r}function hn(n,e){let r;let i=e.length*2;let a=n.length-i;e.sort((e,t)=>e.offset>t.offset?1:-1);for(let r=0;r>8;n[e]=r&255}}while(r=e.pop()){let e=r.offset;n.copyWithin(e+i,e,a);i-=2;let t=e+i;n[t++]=216;n[t++]=28;a=e}return n}function pn(e,t){S.setUint32(Qr.position+e,B-Qr.position-e+1);let r=Qr;Qr=null;t(r[0]);t(r[1])}function _n(e){if(e.Class){if(!e.encode)throw new Error("Extension has no encode function");zr.unshift(e.Class);qr.unshift(e)}Tr(e)}let dn=new tn({useRecords:false});dn.encode;dn.encodeAsIterable;dn.encodeAsAsyncIterable;const vn=512;const yn=1024;const mn=2048;var gn={}; + */var qe=50;c.TYPED_ARRAY_SUPPORT=ke.TYPED_ARRAY_SUPPORT!==undefined?ke.TYPED_ARRAY_SUPPORT:true;ze();function ze(){return c.TYPED_ARRAY_SUPPORT?2147483647:1073741823}function Ye(e,t){if(ze()=ze()){throw new RangeError("Attempt to allocate Buffer larger than maximum "+"size: 0x"+ze().toString(16)+" bytes")}return e|0}c.isBuffer=Rt;function Xe(e){return!!(e!=null&&e._isBuffer)}c.compare=function e(t,r){if(!Xe(t)||!Xe(r)){throw new TypeError("Arguments must be Buffers")}if(t===r)return 0;var n=t.length;var i=r.length;for(var u=0,a=Math.min(n,i);u>>1;case"base64":return It(e).length;default:if(n)return St(e).length;t=(""+t).toLowerCase();n=true}}}c.byteLength=et;function tt(e,t,r){var n=false;if(t===undefined||t<0){t=0}if(t>this.length){return""}if(r===undefined||r>this.length){r=this.length}if(r<=0){return""}r>>>=0;t>>>=0;if(r<=t){return""}if(!e)e="utf8";while(true){switch(e){case"hex":return yt(this,t,r);case"utf8":case"utf-8":return ht(this,t,r);case"ascii":return dt(this,t,r);case"latin1":case"binary":return vt(this,t,r);case"base64":return lt(this,t,r);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return mt(this,t,r);default:if(n)throw new TypeError("Unknown encoding: "+e);e=(e+"").toLowerCase();n=true}}}c.prototype._isBuffer=true;function rt(e,t,r){var n=e[t];e[t]=e[r];e[r]=n}c.prototype.swap16=function e(){var t=this.length;if(t%2!==0){throw new RangeError("Buffer size must be a multiple of 16-bits")}for(var r=0;r0){t=this.toString("hex",0,r).match(/.{2}/g).join(" ");if(this.length>r)t+=" ... "}return""};c.prototype.compare=function e(t,r,n,i,u){if(!Xe(t)){throw new TypeError("Argument must be a Buffer")}if(r===undefined){r=0}if(n===undefined){n=t?t.length:0}if(i===undefined){i=0}if(u===undefined){u=this.length}if(r<0||n>t.length||i<0||u>this.length){throw new RangeError("out of range index")}if(i>=u&&r>=n){return 0}if(i>=u){return-1}if(r>=n){return 1}r>>>=0;n>>>=0;i>>>=0;u>>>=0;if(this===t)return 0;var a=u-i;var o=n-r;var s=Math.min(a,o);var c=this.slice(i,u);var f=t.slice(r,n);for(var l=0;l2147483647){r=2147483647}else if(r<-2147483648){r=-2147483648}r=+r;if(isNaN(r)){r=i?0:e.length-1}if(r<0)r=e.length+r;if(r>=e.length){if(i)return-1;else r=e.length-1}else if(r<0){if(i)r=0;else return-1}if(typeof t==="string"){t=c.from(t,n)}if(Xe(t)){if(t.length===0){return-1}return it(e,t,r,n,i)}else if(typeof t==="number"){t=t&255;if(c.TYPED_ARRAY_SUPPORT&&typeof Uint8Array.prototype.indexOf==="function"){if(i){return Uint8Array.prototype.indexOf.call(e,t,r)}else{return Uint8Array.prototype.lastIndexOf.call(e,t,r)}}return it(e,[t],r,n,i)}throw new TypeError("val must be string, number or Buffer")}function it(e,t,r,n,i){var u=1;var a=e.length;var o=t.length;if(n!==undefined){n=String(n).toLowerCase();if(n==="ucs2"||n==="ucs-2"||n==="utf16le"||n==="utf-16le"){if(e.length<2||t.length<2){return-1}u=2;a/=2;o/=2;r/=2}}function s(e,t){if(u===1){return e[t]}else{return e.readUInt16BE(t*u)}}var c;if(i){var f=-1;for(c=r;ca)r=a-o;for(c=r;c>=0;c--){var l=true;for(var h=0;hi){n=i}}var u=t.length;if(u%2!==0)throw new TypeError("Invalid hex string");if(n>u/2){n=u/2}for(var a=0;au)n=u;if(t.length>0&&(n<0||r<0)||r>this.length){throw new RangeError("Attempt to write outside buffer bounds")}if(!i)i="utf8";var a=false;for(;;){switch(i){case"hex":return ut(this,t,r,n);case"utf8":case"utf-8":return at(this,t,r,n);case"ascii":return ot(this,t,r,n);case"latin1":case"binary":return st(this,t,r,n);case"base64":return ct(this,t,r,n);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return ft(this,t,r,n);default:if(a)throw new TypeError("Unknown encoding: "+i);i=(""+i).toLowerCase();a=true}}};c.prototype.toJSON=function e(){return{type:"Buffer",data:Array.prototype.slice.call(this._arr||this,0)}};function lt(e,t,r){if(t===0&&r===e.length){return Re(e)}else{return Re(e.slice(t,r))}}function ht(e,t,r){r=Math.min(e.length,r);var n=[];var i=t;while(i239?4:u>223?3:u>191?2:1;if(i+o<=r){var s,c,f,l;switch(o){case 1:if(u<128){a=u}break;case 2:s=e[i+1];if((s&192)===128){l=(u&31)<<6|s&63;if(l>127){a=l}}break;case 3:s=e[i+1];c=e[i+2];if((s&192)===128&&(c&192)===128){l=(u&15)<<12|(s&63)<<6|c&63;if(l>2047&&(l<55296||l>57343)){a=l}}break;case 4:s=e[i+1];c=e[i+2];f=e[i+3];if((s&192)===128&&(c&192)===128&&(f&192)===128){l=(u&15)<<18|(s&63)<<12|(c&63)<<6|f&63;if(l>65535&&l<1114112){a=l}}}}if(a===null){a=65533;o=1}else if(a>65535){a-=65536;n.push(a>>>10&1023|55296);a=56320|a&1023}n.push(a);i+=o}return _t(n)}var pt=4096;function _t(e){var t=e.length;if(t<=pt){return String.fromCharCode.apply(String,e)}var r="";var n=0;while(nn)r=n;var i="";for(var u=t;un){t=n}if(r<0){r+=n;if(r<0)r=0}else if(r>n){r=n}if(rr)throw new RangeError("Trying to access beyond buffer length")}c.prototype.readUIntLE=function e(t,r,n){t=t|0;r=r|0;if(!n)gt(t,r,this.length);var i=this[t];var u=1;var a=0;while(++a0&&(u*=256)){i+=this[t+--r]*u}return i};c.prototype.readUInt8=function e(t,r){if(!r)gt(t,1,this.length);return this[t]};c.prototype.readUInt16LE=function e(t,r){if(!r)gt(t,2,this.length);return this[t]|this[t+1]<<8};c.prototype.readUInt16BE=function e(t,r){if(!r)gt(t,2,this.length);return this[t]<<8|this[t+1]};c.prototype.readUInt32LE=function e(t,r){if(!r)gt(t,4,this.length);return(this[t]|this[t+1]<<8|this[t+2]<<16)+this[t+3]*16777216};c.prototype.readUInt32BE=function e(t,r){if(!r)gt(t,4,this.length);return this[t]*16777216+(this[t+1]<<16|this[t+2]<<8|this[t+3])};c.prototype.readIntLE=function e(t,r,n){t=t|0;r=r|0;if(!n)gt(t,r,this.length);var i=this[t];var u=1;var a=0;while(++a=u)i-=Math.pow(2,8*r);return i};c.prototype.readIntBE=function e(t,r,n){t=t|0;r=r|0;if(!n)gt(t,r,this.length);var i=r;var u=1;var a=this[t+--i];while(i>0&&(u*=256)){a+=this[t+--i]*u}u*=128;if(a>=u)a-=Math.pow(2,8*r);return a};c.prototype.readInt8=function e(t,r){if(!r)gt(t,1,this.length);if(!(this[t]&128))return this[t];return(255-this[t]+1)*-1};c.prototype.readInt16LE=function e(t,r){if(!r)gt(t,2,this.length);var n=this[t]|this[t+1]<<8;return n&32768?n|4294901760:n};c.prototype.readInt16BE=function e(t,r){if(!r)gt(t,2,this.length);var n=this[t+1]|this[t]<<8;return n&32768?n|4294901760:n};c.prototype.readInt32LE=function e(t,r){if(!r)gt(t,4,this.length);return this[t]|this[t+1]<<8|this[t+2]<<16|this[t+3]<<24};c.prototype.readInt32BE=function e(t,r){if(!r)gt(t,4,this.length);return this[t]<<24|this[t+1]<<16|this[t+2]<<8|this[t+3]};c.prototype.readFloatLE=function e(t,r){if(!r)gt(t,4,this.length);return Te(this,t,true,23,4)};c.prototype.readFloatBE=function e(t,r){if(!r)gt(t,4,this.length);return Te(this,t,false,23,4)};c.prototype.readDoubleLE=function e(t,r){if(!r)gt(t,8,this.length);return Te(this,t,true,52,8)};c.prototype.readDoubleBE=function e(t,r){if(!r)gt(t,8,this.length);return Te(this,t,false,52,8)};function bt(e,t,r,n,i,u){if(!Xe(e))throw new TypeError('"buffer" argument must be a Buffer instance');if(t>i||te.length)throw new RangeError("Index out of range")}c.prototype.writeUIntLE=function e(t,r,n,i){t=+t;r=r|0;n=n|0;if(!i){var u=Math.pow(2,8*n)-1;bt(this,t,r,n,u,0)}var a=1;var o=0;this[r]=t&255;while(++o=0&&(o*=256)){this[r+a]=t/o&255}return r+n};c.prototype.writeUInt8=function e(t,r,n){t=+t;r=r|0;if(!n)bt(this,t,r,1,255,0);if(!c.TYPED_ARRAY_SUPPORT)t=Math.floor(t);this[r]=t&255;return r+1};function wt(e,t,r,n){if(t<0)t=65535+t+1;for(var i=0,u=Math.min(e.length-r,2);i>>(n?i:1-i)*8}}c.prototype.writeUInt16LE=function e(t,r,n){t=+t;r=r|0;if(!n)bt(this,t,r,2,65535,0);if(c.TYPED_ARRAY_SUPPORT){this[r]=t&255;this[r+1]=t>>>8}else{wt(this,t,r,true)}return r+2};c.prototype.writeUInt16BE=function e(t,r,n){t=+t;r=r|0;if(!n)bt(this,t,r,2,65535,0);if(c.TYPED_ARRAY_SUPPORT){this[r]=t>>>8;this[r+1]=t&255}else{wt(this,t,r,false)}return r+2};function Dt(e,t,r,n){if(t<0)t=4294967295+t+1;for(var i=0,u=Math.min(e.length-r,4);i>>(n?i:3-i)*8&255}}c.prototype.writeUInt32LE=function e(t,r,n){t=+t;r=r|0;if(!n)bt(this,t,r,4,4294967295,0);if(c.TYPED_ARRAY_SUPPORT){this[r+3]=t>>>24;this[r+2]=t>>>16;this[r+1]=t>>>8;this[r]=t&255}else{Dt(this,t,r,true)}return r+4};c.prototype.writeUInt32BE=function e(t,r,n){t=+t;r=r|0;if(!n)bt(this,t,r,4,4294967295,0);if(c.TYPED_ARRAY_SUPPORT){this[r]=t>>>24;this[r+1]=t>>>16;this[r+2]=t>>>8;this[r+3]=t&255}else{Dt(this,t,r,false)}return r+4};c.prototype.writeIntLE=function e(t,r,n,i){t=+t;r=r|0;if(!i){var u=Math.pow(2,8*n-1);bt(this,t,r,n,u-1,-u)}var a=0;var o=1;var s=0;this[r]=t&255;while(++a>0)-s&255}return r+n};c.prototype.writeIntBE=function e(t,r,n,i){t=+t;r=r|0;if(!i){var u=Math.pow(2,8*n-1);bt(this,t,r,n,u-1,-u)}var a=n-1;var o=1;var s=0;this[r+a]=t&255;while(--a>=0&&(o*=256)){if(t<0&&s===0&&this[r+a+1]!==0){s=1}this[r+a]=(t/o>>0)-s&255}return r+n};c.prototype.writeInt8=function e(t,r,n){t=+t;r=r|0;if(!n)bt(this,t,r,1,127,-128);if(!c.TYPED_ARRAY_SUPPORT)t=Math.floor(t);if(t<0)t=255+t+1;this[r]=t&255;return r+1};c.prototype.writeInt16LE=function e(t,r,n){t=+t;r=r|0;if(!n)bt(this,t,r,2,32767,-32768);if(c.TYPED_ARRAY_SUPPORT){this[r]=t&255;this[r+1]=t>>>8}else{wt(this,t,r,true)}return r+2};c.prototype.writeInt16BE=function e(t,r,n){t=+t;r=r|0;if(!n)bt(this,t,r,2,32767,-32768);if(c.TYPED_ARRAY_SUPPORT){this[r]=t>>>8;this[r+1]=t&255}else{wt(this,t,r,false)}return r+2};c.prototype.writeInt32LE=function e(t,r,n){t=+t;r=r|0;if(!n)bt(this,t,r,4,2147483647,-2147483648);if(c.TYPED_ARRAY_SUPPORT){this[r]=t&255;this[r+1]=t>>>8;this[r+2]=t>>>16;this[r+3]=t>>>24}else{Dt(this,t,r,true)}return r+4};c.prototype.writeInt32BE=function e(t,r,n){t=+t;r=r|0;if(!n)bt(this,t,r,4,2147483647,-2147483648);if(t<0)t=4294967295+t+1;if(c.TYPED_ARRAY_SUPPORT){this[r]=t>>>24;this[r+1]=t>>>16;this[r+2]=t>>>8;this[r+3]=t&255}else{Dt(this,t,r,false)}return r+4};function Et(e,t,r,n,i,u){if(r+n>e.length)throw new RangeError("Index out of range");if(r<0)throw new RangeError("Index out of range")}function At(e,t,r,n,i){if(!i){Et(e,t,r,4)}Le(e,t,r,n,23,4);return r+4}c.prototype.writeFloatLE=function e(t,r,n){return At(this,t,r,true,n)};c.prototype.writeFloatBE=function e(t,r,n){return At(this,t,r,false,n)};function xt(e,t,r,n,i){if(!i){Et(e,t,r,8)}Le(e,t,r,n,52,8);return r+8}c.prototype.writeDoubleLE=function e(t,r,n){return xt(this,t,r,true,n)};c.prototype.writeDoubleBE=function e(t,r,n){return xt(this,t,r,false,n)};c.prototype.copy=function e(t,r,n,i){if(!n)n=0;if(!i&&i!==0)i=this.length;if(r>=t.length)r=t.length;if(!r)r=0;if(i>0&&i=this.length)throw new RangeError("sourceStart out of bounds");if(i<0)throw new RangeError("sourceEnd out of bounds");if(i>this.length)i=this.length;if(t.length-r=0;--a){t[a+r]=this[a+n]}}else if(u<1e3||!c.TYPED_ARRAY_SUPPORT){for(a=0;a>>0;n=n===undefined?this.length:n>>>0;if(!t)t=0;var a;if(typeof t==="number"){for(a=r;a55295&&r<57344){if(!i){if(r>56319){if((t-=3)>-1)u.push(239,191,189);continue}else if(a+1===n){if((t-=3)>-1)u.push(239,191,189);continue}i=r;continue}if(r<56320){if((t-=3)>-1)u.push(239,191,189);i=r;continue}r=(i-55296<<10|r-56320)+65536}else if(i){if((t-=3)>-1)u.push(239,191,189)}i=null;if(r<128){if((t-=1)<0)break;u.push(r)}else if(r<2048){if((t-=2)<0)break;u.push(r>>6|192,r&63|128)}else if(r<65536){if((t-=3)<0)break;u.push(r>>12|224,r>>6&63|128,r&63|128)}else if(r<1114112){if((t-=4)<0)break;u.push(r>>18|240,r>>12&63|128,r>>6&63|128,r&63|128)}else{throw new Error("Invalid code point")}}return u}function Bt(e){var t=[];for(var r=0;r>8;i=r%256;u.push(i);u.push(n)}return u}function It(e){return Ie(kt(e))}function Pt(e,t,r,n){for(var i=0;i=t.length||i>=e.length)break;t[i+r]=e[i]}return i}function Nt(e){return e!==e}function Rt(e){return e!=null&&(!!e._isBuffer||Tt(e)||Lt(e))}function Tt(e){return!!e.constructor&&typeof e.constructor.isBuffer==="function"&&e.constructor.isBuffer(e)}function Lt(e){return typeof e.readFloatLE==="function"&&typeof e.slice==="function"&&Tt(e.slice(0,0))}let Mt;try{Mt=new TextDecoder}catch(e){}let v;let Ut;let y=0;const qt=105;const zt=57342;const Yt=57343;const Vt=57337;const $t=6;const Jt={};let _={};let Kt;let Ht;let Wt=0;let Gt=0;let Qt;let Zt;let Xt=[];let er=[];let tr;let rr;let nr;let ir={useRecords:false,mapsAsObjects:true};let ur=false;let ar=2;try{new Function("")}catch(e){ar=Infinity}class or{constructor(r){if(r){if((r.keyMap||r._keyMap)&&!r.useRecords){r.useRecords=false;r.mapsAsObjects=true}if(r.useRecords===false&&r.mapsAsObjects===undefined)r.mapsAsObjects=true;if(r.getStructures)r.getShared=r.getStructures;if(r.getShared&&!r.structures)(r.structures=[]).uninitialized=true;if(r.keyMap){this.mapKey=new Map;for(let[e,t]of Object.entries(r.keyMap))this.mapKey.set(t,e)}}Object.assign(this,r)}decodeKey(e){return this.keyMap?this.mapKey.get(e)||e:e}encodeKey(e){return this.keyMap&&this.keyMap.hasOwnProperty(e)?this.keyMap[e]:e}encodeKeys(r){if(!this._keyMap)return r;let n=new Map;for(let[e,t]of Object.entries(r))n.set(this._keyMap.hasOwnProperty(e)?this._keyMap[e]:e,t);return n}decodeKeys(e){if(!this._keyMap||e.constructor.name!="Map")return e;if(!this._mapKey){this._mapKey=new Map;for(let[e,t]of Object.entries(this._keyMap))this._mapKey.set(t,e)}let r={};e.forEach((e,t)=>r[lr(this._mapKey.has(t)?this._mapKey.get(t):t)]=e);return r}mapDecode(e,t){let r=this.decode(e);if(this._keyMap){switch(r.constructor.name){case"Array":return r.map(e=>this.decodeKeys(e))}}return r}decode(t,e){if(v){return Nr(()=>{Rr();return this?this.decode(t,e):or.prototype.decode.call(ir,t,e)})}Ut=e>-1?e:t.length;y=0;Gt=0;Ht=null;Qt=null;v=t;try{rr=t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))}catch(e){v=null;if(t instanceof Uint8Array)throw e;throw new Error("Source must be a Uint8Array or Buffer but was a "+(t&&typeof t=="object"?t.constructor.name:typeof t))}if(this instanceof or){_=this;tr=this.sharedValues&&(this.pack?new Array(this.maxPrivatePackedValues||16).concat(this.sharedValues):this.sharedValues);if(this.structures){Kt=this.structures;return sr()}else if(!Kt||Kt.length>0){Kt=[]}}else{_=ir;if(!Kt||Kt.length>0)Kt=[];tr=null}return sr()}decodeMultiple(r,n){let i,u=0;try{let e=r.length;ur=true;let t=this?this.decode(r,e):Mr.decode(r,e);if(n){if(n(t)===false){return}while(y=Qt.postBundlePosition){let e=new Error("Unexpected bundle position");e.incomplete=true;throw e}y=Qt.postBundlePosition;Qt=null}if(y==Ut){Kt=null;v=null;if(Zt)Zt=null}else if(y>Ut){let e=new Error("Unexpected end of CBOR data");e.incomplete=true;throw e}else if(!ur){throw new Error("Data read, but end of buffer not reached")}return e}catch(e){Rr();if(e instanceof RangeError||e.message.startsWith("Unexpected end of buffer")){e.incomplete=true}throw e}}function u(){let n=v[y++];let i=n>>5;n=n&31;if(n>23){switch(n){case 24:n=v[y++];break;case 25:if(i==7){return br()}n=rr.getUint16(y);y+=2;break;case 26:if(i==7){let t=rr.getFloat32(y);if(_.useFloat32>2){let e=Lr[(v[y]&127)<<1|v[y+1]>>7];y+=4;return(e*t+(t>0?.5:-.5)>>0)/e}y+=4;return t}n=rr.getUint32(y);y+=4;break;case 27:if(i==7){let e=rr.getFloat64(y);y+=8;return e}if(i>1){if(rr.getUint32(y)>0)throw new Error("JavaScript does not support arrays, maps, or strings with length over 4294967295");n=rr.getUint32(y+4)}else if(_.int64AsNumber){n=rr.getUint32(y)*4294967296;n+=rr.getUint32(y+4)}else n=rr.getBigUint64(y);y+=8;break;case 31:switch(i){case 2:case 3:throw new Error("Indefinite length not supported for byte or text strings");case 4:let e=[];let t,r=0;while((t=u())!=Jt){e[r++]=t}return i==4?e:i==3?e.join(""):c.concat(e);case 5:let n;if(_.mapsAsObjects){let e={};if(_.keyMap)while((n=u())!=Jt)e[lr(_.decodeKey(n))]=u();else while((n=u())!=Jt)e[lr(n)]=u();return e}else{if(nr){_.mapsAsObjects=true;nr=false}let e=new Map;if(_.keyMap)while((n=u())!=Jt)e.set(_.decodeKey(n),u());else while((n=u())!=Jt)e.set(n,u());return e}case 7:return Jt;default:throw new Error("Invalid major type for indefinite length "+i)}default:throw new Error("Unknown token "+n)}}switch(i){case 0:return n;case 1:return~n;case 2:return yr(n);case 3:if(Gt>=y){return Ht.slice(y-Wt,(y+=n)-Wt)}if(Gt==0&&Ut<140&&n<32){let e=n<16?vr(n):dr(n);if(e!=null)return e}return hr(n);case 4:let t=new Array(n);for(let e=0;e=Vt){let e=Kt[n&8191];if(e){if(!e.read)e.read=fr(e);return e.read()}if(n<65536){if(n==Yt){let e=Ir();let t=u();let r=u();Dr(t,r);let n={};if(_.keyMap)for(let t=2;t23){switch(t){case 24:t=v[y++];break;case 25:t=rr.getUint16(y);y+=2;break;case 26:t=rr.getUint32(y);y+=4;break;default:throw new Error("Expected array header, but got "+v[y-1])}}let r=this.compiledReader;while(r){if(r.propertyCount===t)return r(u);r=r.next}if(this.slowReads++>=ar){let e=this.length==t?this:this.slice(0,t);r=_.keyMap?new Function("r","return {"+e.map(e=>_.decodeKey(e)).map(e=>cr.test(e)?lr(e)+":r()":"["+JSON.stringify(e)+"]:r()").join(",")+"}"):new Function("r","return {"+e.map(e=>cr.test(e)?lr(e)+":r()":"["+JSON.stringify(e)+"]:r()").join(",")+"}");if(this.compiledReader)r.next=this.compiledReader;r.propertyCount=t;this.compiledReader=r;return r(u)}let n={};if(_.keyMap)for(let e=0;e64&&Mt)return Mt.decode(v.subarray(y,y+=e));const r=y+e;const n=[];t="";while(y65535){e-=65536;n.push(e>>>10&1023|55296);e=56320|e&1023}n.push(e)}else{n.push(i)}if(n.length>=4096){t+=_r.apply(String,n);n.length=0}}if(n.length>0){t+=_r.apply(String,n)}return t}let _r=String.fromCharCode;function dr(t){let r=y;let n=new Array(t);for(let e=0;e0){y=r;return}n[e]=i}return _r.apply(String,n)}function vr(d){if(d<4){if(d<2){if(d===0)return"";else{let e=v[y++];if((e&128)>1){y-=1;return}return _r(e)}}else{let e=v[y++];let t=v[y++];if((e&128)>0||(t&128)>0){y-=2;return}if(d<3)return _r(e,t);let r=v[y++];if((r&128)>0){y-=3;return}return _r(e,t,r)}}else{let l=v[y++];let h=v[y++];let p=v[y++];let _=v[y++];if((l&128)>0||(h&128)>0||(p&128)>0||(_&128)>0){y-=4;return}if(d<6){if(d===4)return _r(l,h,p,_);else{let e=v[y++];if((e&128)>0){y-=5;return}return _r(l,h,p,_,e)}}else if(d<8){let e=v[y++];let t=v[y++];if((e&128)>0||(t&128)>0){y-=6;return}if(d<7)return _r(l,h,p,_,e,t);let r=v[y++];if((r&128)>0){y-=7;return}return _r(l,h,p,_,e,t,r)}else{let o=v[y++];let s=v[y++];let c=v[y++];let f=v[y++];if((o&128)>0||(s&128)>0||(c&128)>0||(f&128)>0){y-=8;return}if(d<10){if(d===8)return _r(l,h,p,_,o,s,c,f);else{let e=v[y++];if((e&128)>0){y-=9;return}return _r(l,h,p,_,o,s,c,f,e)}}else if(d<12){let e=v[y++];let t=v[y++];if((e&128)>0||(t&128)>0){y-=10;return}if(d<11)return _r(l,h,p,_,o,s,c,f,e,t);let r=v[y++];if((r&128)>0){y-=11;return}return _r(l,h,p,_,o,s,c,f,e,t,r)}else{let n=v[y++];let i=v[y++];let u=v[y++];let a=v[y++];if((n&128)>0||(i&128)>0||(u&128)>0||(a&128)>0){y-=12;return}if(d<14){if(d===12)return _r(l,h,p,_,o,s,c,f,n,i,u,a);else{let e=v[y++];if((e&128)>0){y-=13;return}return _r(l,h,p,_,o,s,c,f,n,i,u,a,e)}}else{let e=v[y++];let t=v[y++];if((e&128)>0||(t&128)>0){y-=14;return}if(d<15)return _r(l,h,p,_,o,s,c,f,n,i,u,a,e,t);let r=v[y++];if((r&128)>0){y-=15;return}return _r(l,h,p,_,o,s,c,f,n,i,u,a,e,t,r)}}}}}function yr(e){return _.copyBuffers?Uint8Array.prototype.slice.call(v,y,y+=e):v.subarray(y,y+=e)}let mr=new Float32Array(1);let gr=new Uint8Array(mr.buffer,0,4);function br(){let t=v[y++];let r=v[y++];let e=(t&127)>>2;if(e===31){if(r||t&3)return NaN;return t&128?-Infinity:Infinity}if(e===0){let e=((t&3)<<8|r)/(1<<24);return t&128?-e:e}gr[3]=t&128|(e>>1)+56;gr[2]=(t&7)<<5|r>>3;gr[1]=r<<5;gr[0]=0;return mr[0]}new Array(4096);class wr{constructor(e,t){this.value=e;this.tag=t}}Xt[0]=e=>{return new Date(e)};Xt[1]=e=>{return new Date(Math.round(e*1e3))};Xt[2]=r=>{let n=BigInt(0);for(let e=0,t=r.byteLength;e{return BigInt(-1)-Xt[2](e)};Xt[4]=e=>{return+(e[1]+"e"+e[0])};Xt[5]=e=>{return e[1]*Math.exp(e[0]*Math.log(2))};const Dr=(e,t)=>{e=e-57344;let r=Kt[e];if(r&&r.isShared){(Kt.restoreStructures||(Kt.restoreStructures=[]))[e]=r}Kt[e]=t;t.read=fr(t)};Xt[qt]=r=>{let e=r.length;let n=r[1];Dr(r[0],n);let i={};for(let t=2;t{if(Qt)return Qt[0].slice(Qt.position0,Qt.position0+=e);return new wr(e,14)};Xt[15]=e=>{if(Qt)return Qt[1].slice(Qt.position1,Qt.position1+=e);return new wr(e,15)};let Er={Error:Error,RegExp:RegExp};Xt[27]=e=>{return(Er[e[0]]||Error)(e[1],e[2])};const Ar=e=>{if(v[y++]!=132){let e=new Error("Packed values structure must be followed by a 4 element array");if(v.length{if(!tr){if(_.getShared)Pr();else return new wr(e,$t)}if(typeof e=="number")return tr[16+(e>=0?2*e:-2*e-1)];let t=new Error("No support for non-integer packed references yet");if(e===undefined)t.incomplete=true;throw t};Xt[28]=e=>{if(!Zt){Zt=new Map;Zt.id=0}let t=Zt.id++;let r=v[y];let n;if(r>>5==4)n=[];else n={};let i={target:n};Zt.set(t,i);let u=e();if(i.used)return Object.assign(n,u);i.target=u;return u};Xt[28].handlesRead=true;Xt[29]=e=>{let t=Zt.get(e);t.used=true;return t.target};Xt[258]=e=>new Set(e);(Xt[259]=e=>{if(_.mapsAsObjects){_.mapsAsObjects=false;nr=true}return e()}).handlesRead=true;function xr(e,t){if(typeof e==="string")return e+t;if(e instanceof Array)return e.concat(t);return Object.assign({},e,t)}function Fr(){if(!tr){if(_.getShared)Pr();else throw new Error("No packed values available")}return tr}const kr=1399353956;er.push((e,t)=>{if(e>=225&&e<=255)return xr(Fr().prefixes[e-224],t);if(e>=28704&&e<=32767)return xr(Fr().prefixes[e-28672],t);if(e>=1879052288&&e<=2147483647)return xr(Fr().prefixes[e-1879048192],t);if(e>=216&&e<=223)return xr(t,Fr().suffixes[e-216]);if(e>=27647&&e<=28671)return xr(t,Fr().suffixes[e-27639]);if(e>=1811940352&&e<=1879048191)return xr(t,Fr().suffixes[e-1811939328]);if(e==kr){return{packedValues:tr,structures:Kt.slice(0),version:t}}if(e==55799)return t});const Cr=new Uint8Array(new Uint16Array([1]).buffer)[0]==1;const Or=[Uint8Array,Uint8ClampedArray,Uint16Array,Uint32Array,typeof BigUint64Array=="undefined"?{name:"BigUint64Array"}:BigUint64Array,Int8Array,Int16Array,Int32Array,typeof BigInt64Array=="undefined"?{name:"BigInt64Array"}:BigInt64Array,Float32Array,Float64Array];const Sr=[64,68,69,70,71,72,77,78,79,85,86];for(let e=0;e{if(!o)throw new Error("Could not find typed array for code "+s);if(!_.copyBuffers){if(t===1||t===2&&!(e.byteOffset&1)||t===4&&!(e.byteOffset&3)||t===8&&!(e.byteOffset&7))return new o(e.buffer,e.byteOffset,e.byteLength)}return new o(Uint8Array.prototype.slice.call(e,0).buffer)}:e=>{if(!o)throw new Error("Could not find typed array for code "+s);let t=new DataView(e.buffer,e.byteOffset,e.byteLength);let r=e.length>>u;let n=new o(r);let i=t[c];for(let e=0;e23){switch(e){case 24:e=v[y++];break;case 25:e=rr.getUint16(y);y+=2;break;case 26:e=rr.getUint32(y);y+=4;break}}return e}function Pr(){if(_.getShared){let e=Nr(()=>{v=null;return _.getShared()})||{};let t=e.structures||[];_.sharedVersion=e.version;tr=_.sharedValues=e.packedValues;if(Kt===true)_.structures=Kt=t;else Kt.splice.apply(Kt,[0,t.length].concat(t))}}function Nr(e){let t=Ut;let r=y;let n=Wt;let i=Gt;let u=Ht;let a=Zt;let o=Qt;let s=new Uint8Array(v.slice(0,Ut));let c=Kt;let f=_;let l=ur;let h=e();Ut=t;y=r;Wt=n;Gt=i;Ht=u;Zt=a;Qt=o;v=s;ur=l;Kt=c;_=f;rr=new DataView(v.buffer,v.byteOffset,v.byteLength);return h}function Rr(){v=null;Zt=null;Kt=null}function Tr(e){Xt[e.tag]=e.decode}const Lr=new Array(147);for(let e=0;e<256;e++){Lr[e]=+("1e"+Math.floor(45.15-e*.30103))}let Mr=new or({useRecords:false});Mr.decode;Mr.decodeMultiple;let Ur;try{Ur=new TextEncoder}catch(e){}let qr,zr;const Yr=typeof globalThis==="object"&&globalThis.Buffer;const Vr=typeof Yr!=="undefined";const $r=Vr?Yr.allocUnsafeSlow:Uint8Array;const Jr=Vr?Yr:Uint8Array;const Kr=256;const Hr=Vr?4294967296:2144337920;let Wr;let O;let Gr;let S=0;let Qr;let Zr=null;const Xr=61440;const en=/[\u0080-\uFFFF]/;const tn=Symbol("record-id");class rn extends or{constructor(r){super(r);this.offset=0;let s;let a;let f;let l;let n;r=r||{};let c=Jr.prototype.utf8Write?function(e,t,r){return O.utf8Write(e,t,r)}:Ur&&Ur.encodeInto?function(e,t){return Ur.encodeInto(e,O.subarray(t)).written}:false;let u=this;let e=r.structures||r.saveStructures;let h=r.maxSharedStructures;if(h==null)h=e?128:0;if(h>8190)throw new Error("Maximum maxSharedStructure is 8190");let i=r.sequential;if(i){h=0}if(!this.structures)this.structures=[];if(this.saveStructures)this.saveShared=this.saveStructures;let p,_,o=r.sharedValues;let d;if(o){d=Object.create(null);for(let e=0,t=o.length;ethis.encodeKeys(e));break}}return this.encode(e,t)};this.encode=function(t,e){if(!O){O=new $r(8192);Gr=new DataView(O.buffer,0,8192);S=0}Qr=O.length-10;if(Qr-S<2048){O=new $r(O.length);Gr=new DataView(O.buffer,0,O.length);Qr=O.length-10;S=0}else if(e===yn)S=S+7&2147483640;s=S;if(u.useSelfDescribedHeader){Gr.setUint32(S,3654940416);S+=3}n=u.structuredClone?new Map:null;if(u.bundleStrings&&typeof t!=="string"){Zr=[];Zr.size=Infinity}else Zr=null;a=u.structures;if(a){if(a.uninitialized){let e=u.getShared()||{};u.structures=a=e.structures||[];u.sharedVersion=e.version;let r=u.sharedValues=e.packedValues;if(r){d={};for(let e=0,t=r.length;eh&&!i)e=h;if(!a.transitions){a.transitions=Object.create(null);for(let u=0;u0){O[S++]=216;O[S++]=51;an(4);let r=e.values;g(r);an(0);an(0);_=Object.create(d||null);for(let e=0,t=r.length;eQr)w(S);u.offset=S;let e=pn(O.subarray(s,S),n.idsToInsert);n=null;return e}if(e&yn){O.start=s;O.end=S;return O}return O.subarray(s,S)}finally{if(a){if(m<10)m++;if(a.length>h)a.length=h;if(y>1e4){a.transitions=null;m=0;y=0;if(v.length>0)v=[]}else if(v.length>0&&!i){for(let e=0,t=v.length;eh){u.structures=u.structures.slice(0,h)}let e=O.subarray(s,S);if(u.updateSharedData()===false)return u.encode(t);return e}if(e&mn)S=s}};this.findCommonStringsToPack=()=>{p=new Map;if(!d)d=Object.create(null);return e=>{let r=e&&e.threshold||4;let n=this.pack?e.maxPrivatePackedValues||16:0;if(!o)o=this.sharedValues=[];for(let[e,t]of p){if(t.count>r){d[e]=n++;o.push(e);f=true}}while(this.saveShared&&this.updateSharedData()===false){}p=null}};const g=a=>{if(S>Qr)O=w(S);var e=typeof a;var o;if(e==="string"){if(_){let e=_[a];if(e>=0){if(e<16)O[S++]=e+224;else{O[S++]=198;if(e&1)g(15-e>>1);else g(e-16>>1)}return}else if(p&&!r.pack){let e=p.get(a);if(e)e.count++;else p.set(a,{count:1})}}let i=a.length;if(Zr&&i>=4&&i<1024){if((Zr.size+=i)>Xr){let e;let t=(Zr[0]?Zr[0].length*3+Zr[1].length:0)+10;if(S+t>Qr)O=w(S+t);O[S++]=217;O[S++]=223;O[S++]=249;O[S++]=Zr.position?132:130;O[S++]=26;e=S-s;S+=4;if(Zr.position){_n(s,g)}Zr=["",""];Zr.size=0;Zr.position=e}let e=en.test(a);Zr[e?0:1]+=a;O[S++]=e?206:207;g(i);return}let u;if(i<32){u=1}else if(i<256){u=2}else if(i<65536){u=3}else{u=5}let e=i*3;if(S+e>Qr)O=w(S+e);if(i<64||!c){let e,t,r,n=S+u;for(e=0;e>6|192;O[n++]=t&63|128}else if((t&64512)===55296&&((r=a.charCodeAt(e+1))&64512)===56320){t=65536+((t&1023)<<10)+(r&1023);e++;O[n++]=t>>18|240;O[n++]=t>>12&63|128;O[n++]=t>>6&63|128;O[n++]=t&63|128}else{O[n++]=t>>12|224;O[n++]=t>>6&63|128;O[n++]=t&63|128}}o=n-S-u}else{o=c(a,S+u,e)}if(o<24){O[S++]=96|o}else if(o<256){if(u<2){O.copyWithin(S+2,S+1,S+1+o)}O[S++]=120;O[S++]=o}else if(o<65536){if(u<3){O.copyWithin(S+3,S+2,S+2+o)}O[S++]=121;O[S++]=o>>8;O[S++]=o&255}else{if(u<5){O.copyWithin(S+5,S+3,S+3+o)}O[S++]=122;Gr.setUint32(S,o);S+=4}S+=o}else if(e==="number"){if(!this.alwaysUseFloat&&a>>>0===a){if(a<24){O[S++]=a}else if(a<256){O[S++]=24;O[S++]=a}else if(a<65536){O[S++]=25;O[S++]=a>>8;O[S++]=a&255}else{O[S++]=26;Gr.setUint32(S,a);S+=4}}else if(!this.alwaysUseFloat&&a>>0===a){if(a>=-24){O[S++]=31-a}else if(a>=-256){O[S++]=56;O[S++]=~a}else if(a>=-65536){O[S++]=57;Gr.setUint16(S,~a);S+=2}else{O[S++]=58;Gr.setUint32(S,~a);S+=4}}else{let t;if((t=this.useFloat32)>0&&a<4294967296&&a>=-2147483648){O[S++]=250;Gr.setFloat32(S,a);let e;if(t<4||(e=a*Lr[(O[S]&127)<<1|O[S+1]>>7])>>0===e){S+=4;return}else S--}O[S++]=251;Gr.setFloat64(S,a);S+=8}}else if(e==="object"){if(!a)O[S++]=246;else{if(n){let t=n.get(a);if(t){O[S++]=216;O[S++]=29;O[S++]=25;if(!t.references){let e=n.idsToInsert||(n.idsToInsert=[]);t.references=[];e.push(t)}t.references.push(S-s);S+=2;return}else n.set(a,{offset:S-s})}let e=a.constructor;if(e===Object){b(a,true)}else if(e===Array){o=a.length;if(o<24){O[S++]=128|o}else{an(o)}for(let e=0;e>8;O[S++]=o&255}else{O[S++]=186;Gr.setUint32(S,o);S+=4}if(u.keyMap){for(let[e,t]of a){g(u.encodeKey(e));g(t)}}else{for(let[e,t]of a){g(e);g(t)}}}else{for(let r=0,e=qr.length;r>8;O[S++]=t&255}else if(t>-1){O[S++]=218;Gr.setUint32(S,t);S+=4}e.encode.call(this,a,g,w);return}}if(a[Symbol.iterator]){if(Wr){let e=new Error("Iterable should be serialized as iterator");e.iteratorNotHandled=true;throw e}O[S++]=159;for(let e of a){g(e)}O[S++]=255;return}if(a[Symbol.asyncIterator]||sn(a)){let e=new Error("Iterable/blob should be serialized as iterator");e.iteratorNotHandled=true;throw e}if(this.useToJSON&&a.toJSON){const t=a.toJSON();if(t!==a)return g(t)}b(a,!a.hasOwnProperty)}}}else if(e==="boolean"){O[S++]=a?245:244}else if(e==="bigint"){if(a=0){O[S++]=27;Gr.setBigUint64(S,a)}else if(a>-(BigInt(1)<{let t=Object.keys(e);let r=Object.values(e);let n=t.length;if(n<24){O[S++]=160|n}else if(n<256){O[S++]=184;O[S++]=n}else if(n<65536){O[S++]=185;O[S++]=n>>8;O[S++]=n&255}else{O[S++]=186;Gr.setUint32(S,n);S+=4}if(u.keyMap){for(let e=0;e{O[S++]=185;let e=S-s;S+=2;let n=0;if(u.keyMap){for(let e in t)if(r||t.hasOwnProperty(e)){g(u.encodeKey(e));g(t[e]);n++}}else{for(let e in t)if(r||t.hasOwnProperty(e)){g(e);g(t[e]);n++}}O[e+++s]=n>>8;O[e+s]=n&255}:(t,r)=>{let n,i=l.transitions||(l.transitions=Object.create(null));let u=0;let a=0;let o;let s;if(this.keyMap){s=Object.keys(t).map(e=>this.encodeKey(e));a=s.length;for(let t=0;t>8|224;O[S++]=c&255}else{if(!s)s=i.__keys__||(i.__keys__=Object.keys(t));if(o===undefined){c=l.nextId++;if(!c){c=0;l.nextId=1}if(c>=Kr){l.nextId=(c=h)+1}}else{c=o}l[c]=s;if(c>8|224;O[S++]=c&255;i=l.transitions;for(let e=0;e=Kr-h)v.shift()[tn]=undefined;v.push(i);an(a+2);g(57344+c);g(s);if(r===null)return;for(let e in t)if(r||t.hasOwnProperty(e))g(t[e]);return}}if(a<24){O[S++]=128|a}else{an(a)}if(r===null)return;for(let e in t)if(r||t.hasOwnProperty(e))g(t[e])};const w=e=>{let t;if(e>16777216){if(e-s>Hr)throw new Error("Encoded buffer would be larger than maximum buffer size");t=Math.min(Hr,Math.round(Math.max((e-s)*(e>67108864?1.25:2),4194304)/4096)*4096)}else t=(Math.max(e-s<<2,O.length-1)>>12)+1<<12;let r=new $r(t);Gr=new DataView(r.buffer,0,t);if(O.copy)O.copy(r,0,s,e);else r.set(O.slice(s,e));S-=s;s=0;Qr=r.length-10;return O=r};let D=100;let E=1e3;this.encodeAsIterable=function(e,t){return k(e,t,A)};this.encodeAsAsyncIterable=function(e,t){return k(e,t,C)};function*A(n,i,e){let t=n.constructor;if(t===Object){let r=u.useRecords!==false;if(r)b(n,null);else nn(Object.keys(n).length,160);for(let t in n){let e=n[t];if(!r)g(t);if(e&&typeof e==="object"){if(i[t])yield*A(e,i[t]);else yield*x(e,i,t)}else g(e)}}else if(t===Array){let e=n.length;an(e);for(let t=0;tD)){if(i.element)yield*A(e,i.element);else yield*x(e,i,"element")}else g(e)}}else if(n[Symbol.iterator]){O[S++]=159;for(let e of n){if(e&&(typeof e==="object"||S-s>D)){if(i.element)yield*A(e,i.element);else yield*x(e,i,"element")}else g(e)}O[S++]=255}else if(sn(n)){nn(n.size,64);yield O.subarray(s,S);yield n;F()}else if(n[Symbol.asyncIterator]){O[S++]=159;yield O.subarray(s,S);yield n;F();O[S++]=255}else{g(n)}if(e&&S>s)yield O.subarray(s,S);else if(S-s>D){yield O.subarray(s,S);F()}}function*x(t,r,n){let i=S-s;try{g(t);if(S-s>D){yield O.subarray(s,S);F()}}catch(e){if(e.iteratorNotHandled){r[n]={};S=s+i;yield*A.call(this,t,r[n])}else throw e}}function F(){D=E;u.encode(null,gn)}function k(e,t,r){if(t&&t.chunkThreshold)D=E=t.chunkThreshold;else D=100;if(e&&typeof e==="object"){u.encode(null,gn);return r(e,u.iterateProperties||(u.iterateProperties={}),true)}return[u.encode(e)]}async function*C(e,t){for(let r of A(e,t,true)){let e=r.constructor;if(e===Jr||e===Uint8Array)yield r;else if(sn(r)){let e=r.stream().getReader();let t;while(!(t=await e.read()).done){yield t.value}}else if(r[Symbol.asyncIterator]){for await(let e of r){F();if(e)yield*C(e,t.async||(t.async={}));else yield u.encode(e)}}else{yield r}}}}useBuffer(e){O=e;Gr=new DataView(O.buffer,O.byteOffset,O.byteLength);S=0}clearSharedData(){if(this.structures)this.structures=[];if(this.sharedValues)this.sharedValues=undefined}updateSharedData(){let t=this.sharedVersion||0;this.sharedVersion=t+1;let e=this.structures.slice(0);let r=new un(e,this.sharedValues,this.sharedVersion);let n=this.saveShared(r,e=>(e&&e.version||0)==t);if(n===false){r=this.getShared()||{};this.structures=r.structures||[];this.sharedValues=r.packedValues;this.sharedVersion=r.version;this.structures.nextId=this.structures.length}else{e.forEach((e,t)=>this.structures[t]=e)}return n}}function nn(e,t){if(e<24)O[S++]=t|e;else if(e<256){O[S++]=t|24;O[S++]=e}else if(e<65536){O[S++]=t|25;O[S++]=e>>8;O[S++]=e&255}else{O[S++]=t|26;Gr.setUint32(S,e);S+=4}}class un{constructor(e,t,r){this.structures=e;this.packedValues=t;this.version=r}}function an(e){if(e<24)O[S++]=128|e;else if(e<256){O[S++]=152;O[S++]=e}else if(e<65536){O[S++]=153;O[S++]=e>>8;O[S++]=e&255}else{O[S++]=154;Gr.setUint32(S,e);S+=4}}const on=typeof Blob==="undefined"?function(){}:Blob;function sn(e){if(e instanceof on)return true;let t=e[Symbol.toStringTag];return t==="Blob"||t==="File"}function cn(r,n){switch(typeof r){case"string":if(r.length>3){if(n.objectMap[r]>-1||n.values.length>=n.maxValues)return;let e=n.get(r);if(e){if(++e.count==2){n.values.push(r)}}else{n.set(r,{count:1});if(n.samplingPackedValues){let e=n.samplingPackedValues.get(r);if(e)e.count++;else n.samplingPackedValues.set(r,{count:1})}}}break;case"object":if(r){if(r instanceof Array){for(let e=0,t=r.length;e=0&&r<4294967296){O[S++]=26;Gr.setUint32(S,r);S+=4}else{O[S++]=251;Gr.setFloat64(S,r);S+=8}}},{tag:258,encode(e,t){let r=Array.from(e);t(r)}},{tag:27,encode(e,t){t([e.name,e.message])}},{tag:27,encode(e,t){t(["RegExp",e.source,e.flags])}},{getTag(e){return e.tag},encode(e,t){t(e.value)}},{encode(e,t,r){hn(e,r)}},{getTag(e){if(e.constructor===Uint8Array){if(this.tagUint8Array||Vr&&this.tagUint8Array!==false)return 64}},encode(e,t,r){hn(e,r)}},ln(68,1),ln(69,2),ln(70,4),ln(71,8),ln(72,1),ln(77,2),ln(78,4),ln(79,8),ln(85,4),ln(86,8),{encode(t,n){let e=t.packedValues||[];let r=t.structures||[];if(e.values.length>0){O[S++]=216;O[S++]=51;an(4);let r=e.values;n(r);an(0);an(0);packedObjectMap=Object.create(sharedPackedObjectMap||null);for(let e=0,t=r.length;e1)e-=4;return{tag:e,encode:function e(t,r){let n=t.byteLength;let i=t.byteOffset||0;let u=t.buffer||t;r(Vr?Yr.from(u,i,n):new Uint8Array(u,i,n))}}}function hn(e,t){let r=e.byteLength;if(r<24){O[S++]=64+r}else if(r<256){O[S++]=88;O[S++]=r}else if(r<65536){O[S++]=89;O[S++]=r>>8;O[S++]=r&255}else{O[S++]=90;Gr.setUint32(S,r);S+=4}if(S+r>=O.length){t(S+r)}O.set(e.buffer?e:new Uint8Array(e),S);S+=r}function pn(n,e){let r;let i=e.length*2;let u=n.length-i;e.sort((e,t)=>e.offset>t.offset?1:-1);for(let r=0;r>8;n[e]=r&255}}while(r=e.pop()){let e=r.offset;n.copyWithin(e+i,e,u);i-=2;let t=e+i;n[t++]=216;n[t++]=28;u=e}return n}function _n(e,t){Gr.setUint32(Zr.position+e,S-Zr.position-e+1);let r=Zr;Zr=null;t(r[0]);t(r[1])}function dn(e){if(e.Class){if(!e.encode)throw new Error("Extension has no encode function");zr.unshift(e.Class);qr.unshift(e)}Tr(e)}let vn=new rn({useRecords:false});vn.encode;vn.encodeAsIterable;vn.encodeAsAsyncIterable;const yn=512;const mn=1024;const gn=2048;var bn={}; /**@license * * No Dependency fast and small LZJB Compression for Browser and Node @@ -48,4 +48,4 @@ * Released under BSD-3-Clause License * * build: Wed, 27 Oct 2021 10:43:10 GMT - */Object.defineProperty(gn,"__esModule",{value:true});const bn=8,wn=6,Dn=3,En=(1<r-En){t[i++]=e[n++];continue}f=(e[n]+13^e[n+1]-13^e[n+2])&An-1;c=n-l[f]&xn;l[f]=n;a=n-c;if(a>=0&&a!=n&&e[n]==e[a]&&e[n+1]==e[a+1]&&e[n+2]==e[a+2]){t[u]|=o;for(s=Dn;s>bn;t[i++]=c;n+=s}else{t[i++]=e[n++]}}console.assert(e.length>=n);return i}function kn(e,t,r){t=t|0;var n=0,i=0,a=0,u=0,o=1<<(bn-1|0),s=0,c=0;while(n>(bn-wn|0))+Dn|0;c=(e[n]<4){r[i]=r[a];i=i+1|0;a=a+1|0;r[i]=r[a];i=i+1|0;a=a+1|0;r[i]=r[a];i=i+1|0;a=a+1|0;r[i]=r[a];i=i+1|0;a=a+1|0;s=s-4|0}while(s>0){r[i]=r[a];i=i+1|0;a=a+1|0;s=s-1|0}}}else{r[i]=e[n];i=i+1|0;n=n+1|0}}return i}function Cn(){const e=new TextEncoder("utf-8");return e.encode(On)}const On="@lzjb";const Sn=Cn();function Bn(...e){if(e.length>1){const r=e.reduce((e,t)=>e+t.length,0);const n=new Uint8Array(r);let t=0;e.forEach(e=>{n.set(e,t);t+=e.length});return n}else if(e.length){return e[0]}}function jn(t){const e=Math.ceil(Math.log2(t)/8);const r=new Uint8Array(e);for(let e=0;e=0;e--){r=r*256+t[e]}return r}function Pn(e,{magic:t=true}={}){const r=new Uint8Array(Math.max(e.length*1.5|0,16*1024));const n=Fn(e,r);const i=jn(e.length);const a=[Uint8Array.of(i.length),i,r.slice(0,n)];if(t){a.unshift(Sn)}return Bn(...a)}function Nn(t,{magic:e=true}={}){if(e){const e=new TextDecoder("utf-8");const s=e.decode(t.slice(0,Sn.length));if(s!==On){throw new Error("Invalid magic value")}}const r=e?Sn.length:0;const n=t[r];const i=r+1;const a=r+n+1;const u=In(t.slice(i,a));t=t.slice(a);const o=new Uint8Array(u);kn(t,t.length,o);return o}var Rn=gn.pack=Pn;var Tn=gn.unpack=Nn;function Ln(s,c){return c=c||{},new Promise(function(e,t){var r=new XMLHttpRequest,n=[],i=[],a={},u=function(){return{ok:2==(r.status/100|0),statusText:r.statusText,status:r.status,url:r.responseURL,text:function(){return Promise.resolve(r.responseText)},json:function(){return Promise.resolve(r.responseText).then(JSON.parse)},blob:function(){return Promise.resolve(new Blob([r.response]))},clone:u,headers:{keys:function(){return n},entries:function(){return i},get:function(e){return a[e.toLowerCase()]},has:function(e){return e.toLowerCase()in a}}}};for(var o in r.open(c.method||"get",s,!0),r.onload=function(){r.getAllResponseHeaders().replace(/^(.*?):[^\S\n]*([\s\S]*?)$/gm,function(e,t,r){n.push(t=t.toLowerCase()),i.push([t,r]),a[t]=a[t]?a[t]+","+r:r}),e(u())},r.onerror=t,r.withCredentials="include"==c.credentials,c.headers)r.setRequestHeader(o,c.headers[o]);r.send(c.body||null)})}var Mn=["token"],Un=["env"],qn=["stderr","stdin","stdout","command_line"],zn=["use_dynamic"],Yn=["use_dynamic"],Vn=["env","dynamic_env","use_dynamic","error"];function $n(e,t,r){Jn(e,t);t.set(e,r)}function Jn(e,t){if(t.has(e)){throw new TypeError("Cannot initialize the same private elements twice on an object")}}function Kn(e,t,r){return t=P(t),W(e,Hn()?Reflect.construct(t,r||[],P(e).constructor):t.apply(e,r))}function Hn(){try{var t=!Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){}))}catch(t){}return(Hn=function e(){return!!t})()}function Wn(t,e){var r=typeof Symbol!=="undefined"&&t[Symbol.iterator]||t["@@iterator"];if(!r){if(Array.isArray(t)||(r=Gn(t))||e&&t&&typeof t.length==="number"){if(r)t=r;var n=0;var i=function e(){};return{s:i,n:function e(){if(n>=t.length)return{done:true};return{done:false,value:t[n++]}},e:function e(t){throw t},f:i}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var a=true,u=false,o;return{s:function e(){r=r.call(t)},n:function e(){var t=r.next();a=t.done;return t},e:function e(t){u=true;o=t},f:function e(){try{if(!a&&r["return"]!=null)r["return"]()}finally{if(u)throw o}}}}function Gn(e,t){if(!e)return;if(typeof e==="string")return Qn(e,t);var r=Object.prototype.toString.call(e).slice(8,-1);if(r==="Object"&&e.constructor)r=e.constructor.name;if(r==="Map"||r==="Set")return Array.from(e);if(r==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r))return Qn(e,t)}function Qn(e,t){if(t==null||t>e.length)t=e.length;for(var r=0,n=new Array(t);r1?r-1:0),i=1;i0&&arguments[0]!==undefined?arguments[0]:null;var t=As&&As.get("DEBUG",{throwError:false});if(e===null){return t===true}return(t===null||t===void 0?void 0:t.valueOf())===e.valueOf()}function fi(e){return e?"(?:#".concat(e,"(?:#[ie])?|#[ie]#").concat(e,")"):"(?:#[ie])?"}function li(e,t){return"".concat(fi(e),"[+-]?").concat(t,"+/").concat(t,"+")}function hi(e,t){return"".concat(fi(e),"(?:[+-]?(?:").concat(t,"+/").concat(t,"+|nan.0|inf.0|").concat(t,"+))?(?:[+-]i|[+-]?(?:").concat(t,"+/").concat(t,"+|").concat(t,"+|nan.0|inf.0)i)(?=[()[\\]\\s]|$)")}function pi(e,t){return"".concat(fi(e),"[+-]?").concat(t,"+")}var _i=/^#\/((?:\\\/|[^/]|\[[^\]]*\/[^\]]*\])+)\/([gimyus]*)$/;var di="(?:[-+]?(?:[0-9]+(?:[eE][-+]?[0-9]+)|(?:\\.[0-9]+|[0-9]+\\.[0-9]+)(?:[eE][-+]?[0-9]+)?)|[0-9]+\\.)";var vi="(?:#[ie])?(?:[+-]?(?:[0-9]+/[0-9]+|nan.0|inf.0|".concat(di,"|[+-]?[0-9]+))?(?:").concat(di,"|[+-](?:[0-9]+/[0-9]+|[0-9]+|nan.0|inf.0))i");var yi=new RegExp("^(#[ie])?".concat(di,"$"),"i");function mi(e,t){var r=e==="x"?"(?!\\+|".concat(t,")"):"(?!\\.|".concat(t,")");var n="";if(e===""){n="(?:[-+]?(?:[0-9]+(?:[eE][-+]?[0-9]+)|(?:\\.[0-9]+|[0-9]+\\.[0-9]+(?![0-9]))(?:[eE][-+]?[0-9]+)?))"}return new RegExp("^((?:(?:".concat(n,"|[-+]?inf.0|[-+]?nan.0|[+-]?").concat(t,"+/").concat(t,"+(?!").concat(t,")|[+-]?").concat(t,"+)").concat(r,")?)(").concat(n,"|[-+]?inf.0|[-+]?nan.0|[+-]?").concat(t,"+/").concat(t,"+|[+-]?").concat(t,"+|[+-])i$"),"i")}var gi=function(){var a={};[[10,"","[0-9]"],[16,"x","[0-9a-fA-F]"],[8,"o","[0-7]"],[2,"b","[01]"]].forEach(function(e){var t=b(e,3),r=t[0],n=t[1],i=t[2];a[r]=mi(n,i)});return a}();var bi={alarm:"",backspace:"\b",delete:"",escape:"",newline:"\n",null:"\0",return:"\r",space:" ",tab:"\t",dle:"",soh:"",dc1:"",stx:"",dc2:"",etx:"",dc3:"",eot:"",dc4:"",enq:"",nak:"",ack:"",syn:"",bel:"",etb:"",bs:"\b",can:"",ht:"\t",em:"",lf:"\n",sub:"",vt:"\v",esc:"",ff:"\f",fs:"",cr:"\r",gs:"",so:"",rs:"",si:"",us:"",del:""};function wi(e){var t=[];var r=0;var n=e.length;while(r=55296&&i<=56319&&r1&&arguments[1]!==undefined?arguments[1]:10;var r=Ni(e);var n=r.number.split("/");var i=E({num:j([n[0],r.radix||t]),denom:j([n[1],r.radix||t])});if(r.inexact){return i.valueOf()}else{return i}}function Ti(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:10;var r=Ni(e);if(r.inexact){return g(parseInt(r.number,r.radix||t))}return j([r.number,r.radix||t])}function Li(e){var t=e.match(/#\\x([0-9a-f]+)$/i);var r;if(t){var n=parseInt(t[1],16);r=String.fromCodePoint(n)}else{t=e.match(/#\\([\s\S]+)$/);if(t){r=t[1]}}if(r){return h(r)}throw new Error("Parse: invalid character")}function Mi(e){var i=arguments.length>1&&arguments[1]!==undefined?arguments[1]:10;function t(e){var t;if(e==="+"){t=j(1)}else if(e==="-"){t=j(-1)}else if(e.match(Si)){t=j([e,i])}else if(e.match(Bi)){var r=e.split("/");t=E({num:j([r[0],i]),denom:j([r[1],i])})}else if(e.match(yi)){var n=Yi(e);if(a.exact){return n.toRational()}return n}else if(e.match(/nan.0$/)){return j(NaN)}else if(e.match(/inf.0$/)){if(e[0]==="-"){return j(Number.NEGATIVE_INFINITY)}return j(Number.POSITIVE_INFINITY)}else{throw new Error("Internal Parser Error")}if(a.inexact){return g(t.valueOf())}return t}var a=Ni(e);i=a.radix||i;var r;var n=a.number.match(Ii);if(i!==10&&n){r=n}else{r=a.number.match(gi[i])}var u,o;o=t(r[2]);if(r[1]){u=t(r[1])}else{u=j(0)}if(o.cmp(0)===0&&o.__type__==="bigint"){return u}return m({im:o,re:u})}function Ui(e){return parseInt(e.toString(),10)===e}function qi(e){var t=e.match(/^(([-+]?[0-9]*)(?:\.([0-9]+))?)e([-+]?[0-9]+)/i);if(t){var r=parseInt(t[4],10);var n;var i=t[1].replace(/[-+]?([0-9]*)\..+$/,"$1").length;var a=t[3]&&t[3].length;if(i0&&(t.exact||!t.number.match(/\./))){return j(a).mul(o)}}}r=g(r);if(t.exact){return r.toRational()}return r}function Vi(e){e=e.replace(/\\x([0-9a-f]+);/gi,function(e,t){return"\\u"+t.padStart(4,"0")}).replace(/\n/g,"\\n");var t=e.match(/(\\*)(\\x[0-9A-F])/i);if(t&&t[1].length%2===0){throw new Error("Invalid string literal, unclosed ".concat(t[2]))}try{var r=D(JSON.parse(e));r.freeze();return r}catch(e){var n=e.message.replace(/in JSON /,"").replace(/.*Error: /,"");throw new Error("Invalid string literal: ".concat(n))}}function $i(e){if(e.match(/^\|.*\|$/)){e=e.replace(/(^\|)|(\|$)/g,"");var r={t:"\t",r:"\r",n:"\n"};e=e.replace(/\\(x[^;]+);/g,function(e,t){return String.fromCharCode(parseInt("0"+t,16))}).replace(/\\(.)/g,function(e,t){return r[t]||t})}return new Y(e)}function Ji(e){if(xs.hasOwnProperty(e)){return xs[e]}if(e.match(/^"[\s\S]*"$/)){return Vi(e)}else if(e[0]==="#"){var t=e.match(_i);if(t){return new RegExp(t[1],t[2])}else if(e.match(xi)){return Li(e)}var r=e.match(/#\\(.+)/);if(r&&wi(r[1]).length===1){return Li(e)}}if(e.match(/[0-9a-f]|[+-]i/i)){if(e.match(Oi)){return Ti(e)}else if(e.match(yi)){return Yi(e)}else if(e.match(Ci)){return Ri(e)}else if(e.match(ki)){return Mi(e)}}if(e.match(/^#[iexobd]/)){throw new Error("Invalid numeric constant: "+e)}return $i(e)}function Ki(e){return!(["(",")","[","]"].includes(e)||pa.names().includes(e))}function Hi(e){return Ki(e)&&!(e.match(_i)||e.match(/^"[\s\S]*"$/)||e.match(Oi)||e.match(yi)||e.match(ki)||e.match(Ci)||e.match(xi)||["#t","#f","nil"].includes(e))}var Wi=/"(?:\\[\S\s]|[^"])*"?/g;function Gi(e){if(typeof e==="string"){var t=/([-\\^$[\]()+{}?*.|])/g;return e.replace(t,"\\$1")}return e}function Qi(){this.data=[]}Qi.prototype.push=function(e){this.data.push(e)};Qi.prototype.top=function(){return this.data[this.data.length-1]};Qi.prototype.pop=function(){return this.data.pop()};Qi.prototype.is_empty=function(){return!this.data.length};function Zi(e){if(e instanceof D){e=e.valueOf()}var t=new s(e,{whitespace:true});var r=[];while(true){var n=t.peek(true);if(n===fs){break}r.push(n);t.skip()}return r}function Xi(e){var t=e.token,r=he(e,Mn);if(t.match(/^"[\s\S]*"$/)&&t.match(/\n/)){var n=new RegExp("^ {1,"+(e.col+1)+"}","mg");t=t.replace(n,"")}return q({token:t},r)}function ea(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:function(){};this.fn=e;this.cont=t}ea.prototype.toString=function(){return"#"};function ta(n){return function(){for(var e=arguments.length,t=new Array(e),r=0;r1&&arguments[1]!==undefined?arguments[1]:false;if(e instanceof D){e=e.toString()}if(t){return Zi(e)}else{var r=Zi(e).map(function(e){if(e.token==="#\\ "||e.token=="#\\\n"){return e.token}return e.token.trim()}).filter(function(e){return e&&!e.match(/^;/)&&!e.match(/^#\|[\s\S]*\|#$/)});return ia(r)}}function ia(e){var t=0;var r=null;var n=[];for(var i=0;i0&&arguments[0]!==undefined?arguments[0]:null;if(e instanceof Y){if(e.is_gensym()){return e}e=e.valueOf()}if(oa(e)){return Y(e)}if(e!==null){return r(e,Symbol("#:".concat(e)))}t++;return r(t,Symbol("#:g".concat(t)))}}();function ca(e){var r=this;var n={pending:true,rejected:false,fulfilled:false,reason:undefined,type:undefined};e=e.then(function(e){n.type=zs(e);n.fulfilled=true;n.pending=false;return e});f(this,"_promise",e,{hidden:true});if(d(e["catch"])){e=e["catch"](function(e){n.rejected=true;n.pending=false;n.reason=e})}Object.keys(n).forEach(function(t){Object.defineProperty(r,"__".concat(t,"__"),{enumerable:true,get:function e(){return n[t]}})});f(this,"__promise__",e);this.then=false}ca.prototype.then=function(e){return new ca(this.valueOf().then(e))};ca.prototype["catch"]=function(e){return new ca(this.valueOf()["catch"](e))};ca.prototype.valueOf=function(){if(!this._promise){throw new Error("QuotedPromise: invalid promise created")}return this._promise};ca.prototype.toString=function(){if(this.__pending__){return ca.pending_str}if(this.__rejected__){return ca.rejected_str}return"#")};ca.pending_str="#";ca.rejected_str="#";function fa(e){if(Array.isArray(e)){return Promise.all(la(e)).then(ha)}return e}function la(e){var t=new Array(e.length),r=e.length;while(r--){var n=e[r];if(n instanceof ca){t[r]=new ds(n)}else{t[r]=n}}return t}function ha(e){var t=new Array(e.length),r=e.length;while(r--){var n=e[r];if(n instanceof ds){t[r]=n.valueOf()}else{t[r]=n}}return t}var pa={LITERAL:Symbol["for"]("literal"),SPLICE:Symbol["for"]("splice"),SYMBOL:Symbol["for"]("symbol"),names:function e(){return Object.keys(this.__list__)},type:function e(t){try{return this.get(t).type}catch(e){console.log({name:t});console.log(e);return null}},get:function e(t){return this.__list__[t]},off:function e(t){var r=this;var n=arguments.length>1&&arguments[1]!==undefined?arguments[1]:null;if(Array.isArray(t)){t.forEach(function(e){return r.off(e,n)})}else if(n===null){delete this.__events__[t]}else{this.__events__=this.__events__.filter(function(e){return e!==n})}},on:function e(t,r){var n=this;if(Array.isArray(t)){t.forEach(function(e){return n.on(e,r)})}else if(!this.__events__[t]){this.__events__[t]=[r]}else{this.__events__[t].push(r)}},trigger:function e(t){for(var r=arguments.length,n=new Array(r>1?r-1:0),i=1;i",new Y("quote-promise"),pa.LITERAL]];var ga=ma.map(function(e){return e[0]});Object.freeze(ga);Object.defineProperty(pa,"__builtins__",{writable:false,value:ga});ma.forEach(function(e){var t=b(e,3),r=t[0],n=t[1],i=t[2];pa.append(r,n,i)});var s=function(){function p(e){var t=this;var r=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},n=r.whitespace,i=n===void 0?false:n;ae(this,p);f(this,"__input__",e.replace(/\r/g,""));var a={};["_i","_whitespace","_col","_newline","_line","_state","_next","_token","_prev_char"].forEach(function(r){Object.defineProperty(t,r,{configurable:false,enumerable:false,get:function e(){return a[r]},set:function e(t){a[r]=t}})});this._whitespace=i;this._i=this._line=this._col=this._newline=0;this._state=this._next=this._token=null;this._prev_char=""}ce(p,[{key:"get",value:function e(t){return this.__internal[t]}},{key:"set",value:function e(t,r){this.__internal[t]=r}},{key:"token",value:function e(){var t=arguments.length>0&&arguments[0]!==undefined?arguments[0]:false;if(t){var r=this._line;if(this._whitespace&&this._token==="\n"){--r}return{token:this._token,col:this._col,offset:this._i,line:r}}return this._token}},{key:"peek",value:function e(){var t=arguments.length>0&&arguments[0]!==undefined?arguments[0]:false;if(this._i>=this.__input__.length){return fs}if(this._token){return this.token(t)}var r=this.next_token();if(r){this._token=this.__input__.substring(this._i,this._next);return this.token(t)}return fs}},{key:"skip",value:function e(){if(this._next!==null){this._token=null;this._i=this._next}}},{key:"read_line",value:function e(){var t=this.__input__.length;if(this._i>=t){return fs}for(var r=this._i;r=r){return fs}if(t+this._i>=r){return this.read_rest()}var n=this._i+t;var i=this.__input__.substring(this._i,n);var a=i.match(/\n/g);if(a){this._line+=a.length}this._i=n;return i}},{key:"peek_char",value:function e(){if(this._i>=this.__input__.length){return fs}return h(this.__input__[this._i])}},{key:"read_char",value:function e(){var t=this.peek_char();this.skip_char();return t}},{key:"skip_char",value:function e(){if(this._i1&&arguments[1]!==undefined?arguments[1]:{},n=r.prev_char,i=r["char"],a=r.next_char;var u=b(t,4),o=u[0],s=u[1],c=u[2],f=u[3];if(t.length!==5){throw new Error("Lexer: Invalid rule of length ".concat(t.length))}if(!i.match(o)){return false}if(!ba(s,n)){return false}if(!ba(c,a)){return false}if(f!==this._state){return false}return true}},{key:"next_token",value:function e(){if(this._i>=this.__input__.length){return false}var t=true;e:for(var r=this._i,n=this.__input__.length;r2&&arguments[2]!==undefined?arguments[2]:null;var i=arguments.length>3&&arguments[3]!==undefined?arguments[3]:null;if(t.length===0){throw new Error("Lexer: invalid literal rule")}if(t.length===1){return[[t,n,i,null,null]]}var a=[];for(var u=0,o=t.length;u1&&arguments[1]!==undefined?arguments[1]:{},r=t.env,n=t.meta,i=n===void 0?false:n,a=t.formatter,u=a===void 0?Xi:a;ae(this,o);if(e instanceof D){e=e.toString()}f(this,"_formatter",u,{hidden:true});f(this,"__lexer__",new s(e));f(this,"__env__",r);f(this,"_meta",i,{hidden:true});f(this,"_refs",[],{hidden:true});f(this,"_state",{parentheses:0},{hidden:true})}ce(o,[{key:"resolve",value:function e(t){return this.__env__&&this.__env__.get(t,{throwError:false})}},{key:"peek",value:function(){var e=ie(C.mark(function e(){var r;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:r=this.__lexer__.peek(true);if(!(r===fs)){t.next=4;break}return t.abrupt("return",fs);case 4:if(!this.is_comment(r.token)){t.next=7;break}this.skip();return t.abrupt("continue",0);case 7:if(!(r.token==="#;")){t.next=14;break}this.skip();if(!(this.__lexer__.peek()===fs)){t.next=11;break}throw new Error("Lexer: syntax error eof found after comment");case 11:t.next=13;return this._read_object();case 13:return t.abrupt("continue",0);case 14:return t.abrupt("break",17);case 17:r=this._formatter(r);if(!this._meta){t.next=20;break}return t.abrupt("return",r);case 20:return t.abrupt("return",r.token);case 21:case"end":return t.stop()}},e,this)}));function t(){return e.apply(this,arguments)}return t}()},{key:"reset",value:function e(){this._refs.length=0}},{key:"skip",value:function e(){this.__lexer__.skip()}},{key:"read",value:function(){var e=ie(C.mark(function e(){var r;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:t.next=2;return this.peek();case 2:r=t.sent;this.skip();return t.abrupt("return",r);case 5:case"end":return t.stop()}},e,this)}));function t(){return e.apply(this,arguments)}return t}()},{key:"match_datum_label",value:function e(t){var r=t.match(/^#([0-9]+)=$/);return r&&r[1]}},{key:"match_datum_ref",value:function e(t){var r=t.match(/^#([0-9]+)#$/);return r&&r[1]}},{key:"is_open",value:function e(t){var r=["(","["].includes(t);if(r){this._state.parentheses++}return r}},{key:"is_close",value:function e(t){var r=[")","]"].includes(t);if(r){this._state.parentheses--}return r}},{key:"read_list",value:function(){var e=ie(C.mark(function e(){var r,n,i,a,u;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:r=V,n=r;case 1:t.next=4;return this.peek();case 4:a=t.sent;if(!(a===fs)){t.next=7;break}return t.abrupt("break",32);case 7:if(!this.is_close(a)){t.next=10;break}this.skip();return t.abrupt("break",32);case 10:if(!(a==="."&&r!==V)){t.next=18;break}this.skip();t.next=14;return this._read_object();case 14:n.cdr=t.sent;i=true;t.next=30;break;case 18:if(!i){t.next=22;break}throw new Error("Parser: syntax error more than one element after dot");case 22:t.t0=$;t.next=25;return this._read_object();case 25:t.t1=t.sent;t.t2=V;u=new t.t0(t.t1,t.t2);if(r===V){r=u}else{n.cdr=u}n=u;case 30:t.next=1;break;case 32:return t.abrupt("return",r);case 33:case"end":return t.stop()}},e,this)}));function t(){return e.apply(this,arguments)}return t}()},{key:"read_value",value:function(){var e=ie(C.mark(function e(){var r;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:t.next=2;return this.read();case 2:r=t.sent;if(!(r===fs)){t.next=5;break}throw new Error("Parser: Expected token eof found");case 5:return t.abrupt("return",Ji(r));case 6:case"end":return t.stop()}},e,this)}));function t(){return e.apply(this,arguments)}return t}()},{key:"is_comment",value:function e(t){return t.match(/^;/)||t.match(/^#\|/)&&t.match(/\|#$/)}},{key:"evaluate",value:function e(t){return k(t,{env:this.__env__,error:function e(t){throw t}})}},{key:"read_object",value:function(){var e=ie(C.mark(function e(){var r;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:this.reset();t.next=3;return this._read_object();case 3:r=t.sent;if(r instanceof Da){r=r.valueOf()}if(!this._refs.length){t.next=7;break}return t.abrupt("return",this._resolve_object(r));case 7:return t.abrupt("return",r);case 8:case"end":return t.stop()}},e,this)}));function t(){return e.apply(this,arguments)}return t}()},{key:"balanced",value:function e(){return this._state.parentheses===0}},{key:"ballancing_error",value:function e(t,r){var n=this._state.parentheses;var i;if(n<0){i=new Error("Parser: unexpected parenthesis");i.__code__=[r.toString()+")"]}else{i=new Error("Parser: expected parenthesis but eof found");var a=new RegExp("\\){".concat(n,"}$"));i.__code__=[t.toString().replace(a,"")]}throw i}},{key:"_resolve_object",value:function(){var t=ie(C.mark(function e(r){var n=this;var i;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(!Array.isArray(r)){t.next=2;break}return t.abrupt("return",r.map(function(e){return n._resolve_object(e)}));case 2:if(!nu(r)){t.next=6;break}i={};Object.keys(r).forEach(function(e){i[e]=n._resolve_object(r[e])});return t.abrupt("return",i);case 6:if(!(r instanceof $)){t.next=8;break}return t.abrupt("return",this._resolve_pair(r));case 8:return t.abrupt("return",r);case 9:case"end":return t.stop()}},e,this)}));function e(e){return t.apply(this,arguments)}return e}()},{key:"_resolve_pair",value:function(){var t=ie(C.mark(function e(r){return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(!(r instanceof $)){t.next=15;break}if(!(r.car instanceof Da)){t.next=7;break}t.next=4;return r.car.valueOf();case 4:r.car=t.sent;t.next=8;break;case 7:this._resolve_pair(r.car);case 8:if(!(r.cdr instanceof Da)){t.next=14;break}t.next=11;return r.cdr.valueOf();case 11:r.cdr=t.sent;t.next=15;break;case 14:this._resolve_pair(r.cdr);case 15:return t.abrupt("return",r);case 16:case"end":return t.stop()}},e,this)}));function e(e){return t.apply(this,arguments)}return e}()},{key:"_read_object",value:function(){var e=ie(C.mark(function e(){var r,n,i,a,u,o,s,c,f,l,h;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:t.next=2;return this.peek();case 2:r=t.sent;if(!(r===fs)){t.next=5;break}return t.abrupt("return",r);case 5:if(!_a(r)){t.next=38;break}n=pa.get(r);i=da(r);this.skip();u=ya(r);if(!u){t.next=14;break}t.t0=undefined;t.next=17;break;case 14:t.next=16;return this._read_object();case 16:t.t0=t.sent;case 17:o=t.t0;if(i){t.next=25;break}s=this.__env__.get(n.symbol);if(!(typeof s==="function")){t.next=25;break}if(va(r)){c=[o]}else if(o===V){c=[]}else if(o instanceof $){c=o.to_array(false)}if(!(c||u)){t.next=24;break}return t.abrupt("return",Hs(s,u?[]:c,{env:this.__env__,dynamic_env:this.__env__,use_dynamic:false}));case 24:throw new Error("Parse Error: Invalid parser extension "+"invocation ".concat(n.symbol));case 25:if(va(r)){a=new $(n.symbol,new $(o,V))}else{a=new $(n.symbol,o)}if(!i){t.next=28;break}return t.abrupt("return",a);case 28:if(!(s instanceof J)){t.next=37;break}t.next=31;return this.evaluate(a);case 31:f=t.sent;if(!(f instanceof $||f instanceof Y)){t.next=34;break}return t.abrupt("return",$.fromArray([Y("quote"),f]));case 34:return t.abrupt("return",f);case 37:throw new Error("Parse Error: invalid parser extension: "+n.symbol);case 38:l=this.match_datum_ref(r);if(!(l!==null)){t.next=44;break}this.skip();if(!this._refs[l]){t.next=43;break}return t.abrupt("return",new Da(l,this._refs[l]));case 43:throw new Error("Parse Error: invalid datum label #".concat(l,"#"));case 44:h=this.match_datum_label(r);if(!(h!==null)){t.next=51;break}this.skip();this._refs[h]=this._read_object();return t.abrupt("return",this._refs[h]);case 51:if(!this.is_close(r)){t.next=55;break}this.skip();t.next=61;break;case 55:if(!this.is_open(r)){t.next=60;break}this.skip();return t.abrupt("return",this.read_list());case 60:return t.abrupt("return",this.read_value());case 61:case"end":return t.stop()}},e,this)}));function t(){return e.apply(this,arguments)}return t}()}]);return o}();var Da=function(){function r(e,t){ae(this,r);this.name=e;this.data=t}ce(r,[{key:"valueOf",value:function e(){return this.data}}]);return r}();function Ea(e,t){return xa.apply(this,arguments)}function xa(){xa=ge(C.mark(function e(r,n){var i,a,u;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(!n){if(K){n=K.get("**interaction-environment**",{throwError:false})}else{n=As}}i=new wa(r,{env:n});case 3:t.next=6;return ye(i.read_object());case 6:u=t.sent;if(!i.balanced()){i.ballancing_error(u,a)}if(!(u===fs)){t.next=10;break}return t.abrupt("break",15);case 10:a=u;t.next=13;return u;case 13:t.next=3;break;case 15:case"end":return t.stop()}},e)}));return xa.apply(this,arguments)}function w(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:function(e){return e};var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:null;if(qu(e)){var n=e.then(t);if(r===null){return n}else{return n["catch"](r)}}if(e instanceof Array){return Aa(e,t,r)}if(nu(e)){return Fa(e,t,r)}return t(e)}function Aa(t,r,e){if(t.find(qu)){return w(fa(t),function(e){if(Object.isFrozen(t)){Object.freeze(e)}return r(e)},e)}return r(t)}function Fa(t,e,r){var i=Object.keys(t);var n=[],a=[];var u=i.length;while(u--){var o=i[u];var s=t[o];n[u]=s;if(qu(s)){a.push(s)}}if(a.length){return w(fa(n),function(e){var n={};e.forEach(function(e,t){var r=i[t];n[r]=e});if(Object.isFrozen(t)){Object.freeze(n)}return n},r)}return e(t)}function f(e,t,r){var n=arguments.length>3&&arguments[3]!==undefined?arguments[3]:{},i=n.hidden,a=i===void 0?false:i;Object.defineProperty(e,t,{value:r,configurable:true,enumerable:!a})}function ka(e){return Ca.apply(this,arguments)}function Ca(){Ca=ie(C.mark(function e(r){var n,i,a,u,o,s,c;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:n=[];i=false;a=false;t.prev=3;o=Xn(r);case 5:t.next=7;return o.next();case 7:if(!(i=!(s=t.sent).done)){t.next=13;break}c=s.value;n.push(c);case 10:i=false;t.next=5;break;case 13:t.next=19;break;case 15:t.prev=15;t.t0=t["catch"](3);a=true;u=t.t0;case 19:t.prev=19;t.prev=20;if(!(i&&o["return"]!=null)){t.next=24;break}t.next=24;return o["return"]();case 24:t.prev=24;if(!a){t.next=27;break}throw u;case 27:return t.finish(24);case 28:return t.finish(19);case 29:return t.abrupt("return",n);case 30:case"end":return t.stop()}},e,null,[[3,15,19,29],[20,,24,28]])}));return Ca.apply(this,arguments)}function Oa(e,t){if(t instanceof RegExp){return function(e){return String(e).match(t)}}else if(d(t)){return t}throw new Error("Invalid matcher")}function l(e,t,r,n){if(typeof e!=="string"){t=arguments[0];r=arguments[1];n=arguments[2];e=null}if(r){if(n){t.__doc__=r}else{t.__doc__=Sa(r)}}if(e){t.__name__=e}else if(t.name&&!go(t)){t.__name__=t.name}return t}function Sa(e){return e.split("\n").map(function(e){return e.trim()}).join("\n")}function Ba(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:1;var r=e.length;if(t<=0){throw Error("previousSexp: Invalid argument sexp = ".concat(t))}e:while(t--&&r>=0){var n=1;while(n>0){var i=e[--r];if(!i){break e}if(i==="("||i.token==="("){n--}else if(i===")"||i.token===")"){n++}}r--}return e.slice(r+1)}function ja(e){if(!e||!e.length){return 0}var t=e.length;if(e[t-1].token==="\n"){return 0}while(--t){if(e[t].token==="\n"){var r=(e[t+1]||{}).token;if(r){return r.length}}}return 0}function Ia(e,t){return f(e,t)===t.length;function f(r,n){function e(e,t){var r=Wn(e),n;try{for(r.s();!(n=r.n()).done;){var i=n.value;var a=f(i,t);if(a!==-1){return a}}}catch(e){r.e(e)}finally{r.f()}return-1}function t(){return r[a]===Symbol["for"]("symbol")&&!Hi(n[o])}function i(){var e=r[a+1];var t=n[o+1];if(e!==undefined&&t!==undefined){return f([e],[t])}}var a=0;var u={};for(var o=0;o0){continue}}else if(t()){return-1}}else if(r[a]instanceof Array){var c=f(r[a],n.slice(o));if(c===-1||c+o>n.length){return-1}o+=c-1;a++;continue}else{return-1}a++}if(r.length!==a){return-1}return n.length}}function Pa(e){this.__code__=e.replace(/\r/g,"")}Pa.defaults={offset:0,indent:2,exceptions:{specials:[/^(?:#:)?(?:define(?:-values|-syntax|-macro|-class|-record-type)?|(?:call-with-(?:input-file|output-file|port))|lambda|let-env|try|catch|when|unless|while|syntax-rules|(let|letrec)(-syntax|\*?-values|\*)?)$/],shift:{1:["&","#"]}}};Pa.match=Ia;Pa.prototype._options=function e(t){var r=Pa.defaults;if(typeof t==="undefined"){return Object.assign({},r)}var n=t&&t.exceptions||{};var i=n.specials||[];var a=n.shift||{1:[]};return q(q(q({},r),t),{},{exceptions:{specials:[].concat(U(r.exceptions.specials),U(i)),shift:q(q({},a),{},{1:[].concat(U(r.exceptions.shift[1]),U(a[1]))})}})};Pa.prototype.indent=function e(t){var r=na(this.__code__,true);return this._indent(r,t)};Pa.exception_shift=function(a,e){function t(e){if(!e.length){return false}if(e.indexOf(a)!==-1){return true}else{var t=e.filter(function(e){return e instanceof RegExp});if(!t.length){return false}var r=Wn(t),n;try{for(r.s();!(n=r.n()).done;){var i=n.value;if(a.match(i)){return true}}}catch(e){r.e(e)}finally{r.f()}}return false}if(t(e.exceptions.specials)){return e.indent}var r=e.exceptions.shift;for(var n=0,i=Object.entries(r);n0){n.offset=0}if(a.toString()===t.toString()&&ac(a)){return n.offset+a[0].col}else if(a.length===1){return n.offset+a[0].col+1}else{var s=-1;if(u){var c=Pa.exception_shift(u.token,n);if(c!==-1){s=c}}if(s===-1){s=Pa.exception_shift(a[1].token,n)}if(s!==-1){return n.offset+a[0].col+s}else if(a[0].line3&&a[1].line===a[3].line){if(a[1].token==="("||a[1].token==="["){return n.offset+a[1].col}return n.offset+a[3].col}else if(a[0].line===a[1].line){return n.offset+n.indent+a[0].col}else{var f=a.slice(2);for(var l=0;l")};Na.prototype.match=function(e){return e.match(this.pattern)};function Ra(){for(var e=arguments.length,t=new Array(e),r=0;r")};Pa.Pattern=Ra;Pa.Ahead=Na;var t=/^[[(]$/;var Ta=/^[\])]$/;var La=/[^()[\]]/;var Ma=new Na(/[^)\]]/);var Ua=Symbol["for"]("*");var qa=new Ra([t,Ua,Ta],[La],"+");var za=new Ra([t,Ua,Ta],"+");var Ya=new Ra([Symbol["for"]("symbol")],"?");var Va=new Ra([Symbol["for"]("symbol")],"*");var $a=[t,Va,Ta];var Ja=new Ra([t,Symbol["for"]("symbol"),Ua,Ta],"+");var Ka=Qa("syntax-rules");var Ha=Qa("define","lambda","define-macro","syntax-rules");var Wa=/^(?!.*\b(?:[()[\]]|define(?:-macro)?|let(?:\*|rec|-env|-syntax|)?|lambda|syntax-rules)\b).*$/;var Ga=/^(?:#:)?(let(?:\*|rec|-env|-syntax)?)$/;function Qa(){for(var e=arguments.length,t=new Array(e),r=0;r0&&!o[e]){o[e]=Ba(u,e)}});var s=Wn(i),c;try{for(s.s();!(c=s.n()).done;){var f=b(c.value,3),l=f[0],h=f[1],p=f[2];h=h.valueOf();var _=h>0?o[h]:u;var d=_.filter(function(e){return e.trim()&&!_a(e)});var v=r(_);var y=Ia(l,d);var m=n.slice(a).find(function(e){return e.trim()&&!_a(e)});if(y&&(p instanceof Na&&p.match(m)||!p)){var g=a-v;if(n[g]!=="\n"){if(!n[g].trim()){n[g]="\n"}else{n.splice(g,0,"\n");a++}}a+=v;continue e}}}catch(e){s.e(e)}finally{s.f()}}this.__code__=n.join("");return this};Pa.prototype._spaces=function(e){return" ".repeat(e)};Pa.prototype.format=function e(t){var r=this.__code__.replace(/[ \t]*\n[ \t]*/g,"\n ");var n=na(r,true);var i=this._options(t);var a=0;var u=0;for(var o=0;o0){n=Math.floor(t()*r);r--;var i=[e[n],e[r]];e[r]=i[0];e[n]=i[1]}return e}function eu(){}eu.prototype.toString=function(){return"()"};eu.prototype.valueOf=function(){return undefined};eu.prototype.serialize=function(){return 0};eu.prototype.to_object=function(){return{}};eu.prototype.append=function(e){return new $(e,V)};eu.prototype.to_array=function(){return[]};var V=new eu;function $(e,t){if(typeof this!=="undefined"&&this.constructor!==$||typeof this==="undefined"){return new $(e,t)}this.car=e;this.cdr=t}function tu(a,u){return function e(t){F(a,t,["pair","nil"]);if(t===V){return[]}var r=[];var n=t;while(true){if(n instanceof $){if(n.haveCycles("cdr")){break}var i=n.car;if(u&&i instanceof $){i=this.get(a).call(this,i)}r.push(i);n=n.cdr}else if(n===V){break}else{throw new Error("".concat(a,": can't convert improper list"))}}return r}}$.prototype.flatten=function(){return $.fromArray(Za(this.to_array()))};$.prototype.length=function(){var e=0;var t=this;while(true){if(!t||t===V||!(t instanceof $)||t.haveCycles("cdr")){break}e++;t=t.cdr}return e};$.match=function(e,t){if(e instanceof Y){return Y.is(e,t)}else if(e instanceof $){return $.match(e.car,t)||$.match(e.cdr,t)}else if(Array.isArray(e)){return e.some(function(e){return $.match(e,t)})}else if(nu(e)){return Object.values(e).some(function(e){return $.match(e,t)})}return false};$.prototype.find=function(e){return $.match(this,e)};$.prototype.clone=function(){var r=arguments.length>0&&arguments[0]!==undefined?arguments[0]:true;var n=new Map;function i(e){if(e instanceof $){if(n.has(e)){return n.get(e)}var t=new $;n.set(e,t);if(r){t.car=i(e.car)}else{t.car=e.car}t.cdr=i(e.cdr);t[co]=e[co];return t}return e}return i(this)};$.prototype.last_pair=function(){var e=this;while(true){if(!Tu(e.cdr)){return e}if(e.haveCycles("cdr")){break}e=e.cdr}};$.prototype.to_array=function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:true;var t=[];if(this.car instanceof $){if(e){t.push(this.car.to_array())}else{t.push(this.car)}}else{t.push(this.car.valueOf())}if(this.cdr instanceof $){t=t.concat(this.cdr.to_array(e))}return t};$.fromArray=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:true;var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:false;if(e instanceof $||r&&e instanceof Array&&e[oo]){return e}if(t===false){var n=V;for(var i=e.length;i--;){n=new $(e[i],n)}return n}if(e.length&&!(e instanceof Array)){e=U(e)}var a=V;var u=e.length;while(u--){var o=e[u];if(o instanceof Array){o=$.fromArray(o,t,r)}else if(typeof o==="string"){o=D(o)}else if(typeof o==="number"&&!Number.isNaN(o)){o=j(o)}a=new $(o,a)}return a};$.prototype.to_object=function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:false;var t=this;var r={};while(true){if(t instanceof $&&t.car instanceof $){var n=t.car;var i=n.car;if(i instanceof Y){i=i.__name__}if(i instanceof D){i=i.valueOf()}var a=n.cdr;if(a instanceof $){a=a.to_object(e)}if(Ju(a)){if(!e){a=a.valueOf()}}r[i]=a;t=t.cdr}else{break}}return r};$.fromPairs=function(e){return e.reduce(function(e,t){return new $(new $(new Y(t[0]),t[1]),e)},V)};$.fromObject=function(t){var e=Object.keys(t).map(function(e){return[e,t[e]]});return $.fromPairs(e)};$.prototype.reduce=function(e){var t=this;var r=V;while(true){if(t!==V){r=e(r,t.car);t=t.cdr}else{break}}return r};$.prototype.reverse=function(){if(this.haveCycles()){throw new Error("You can't reverse list that have cycles")}var e=this;var t=V;while(e!==V){var r=e.cdr;e.cdr=t;t=e;e=r}return t};$.prototype.transform=function(n){function i(e){if(e instanceof $){if(e.replace){delete e.replace;return e}var t=n(e.car);if(t instanceof $){t=i(t)}var r=n(e.cdr);if(r instanceof $){r=i(r)}return new $(t,r)}return e}return i(this)};$.prototype.map=function(e){if(typeof this.car!=="undefined"){return new $(e(this.car),this.cdr===V?V:this.cdr.map(e))}else{return V}};var ru=new Map;function nu(e){return e&&p(e)==="object"&&e.constructor===Object}var iu=Object.getOwnPropertyNames(Array.prototype);var au=[];iu.forEach(function(e){au.push(Array[e],Array.prototype[e])});function uu(e){e=Zu(e);return au.includes(e)}function ou(e){return d(e)&&(go(e)||e.__doc__)}function su(r){var e=r.constructor||Object;var n=nu(r);var i=d(r[Symbol.asyncIterator])||d(r[Symbol.iterator]);var a;if(ru.has(e)){a=ru.get(e)}else{ru.forEach(function(e,t){t=Zu(t);if(r.constructor===t&&(t===Object&&n&&!i||t!==Object)){a=e}})}return a}var cu=new Map;[[true,"#t"],[false,"#f"],[null,"null"],[undefined,"#"]].forEach(function(e){var t=b(e,2),r=t[0],n=t[1];cu.set(r,n)});function fu(r){if(r&&p(r)==="object"){var n={};var e=Object.getOwnPropertySymbols(r);e.forEach(function(e){var t=e.toString().replace(/Symbol\(([^)]+)\)/,"$1");n[t]=vu(r[e])});var t=Object.getOwnPropertyNames(r);t.forEach(function(e){var t=r[e];if(t&&p(t)==="object"&&t.constructor===Object){n[e]=fu(t)}else{n[e]=vu(t)}});return n}return r}function lu(e){return Object.keys(e).concat(Object.getOwnPropertySymbols(e))}function hu(e,t){return e.hasOwnProperty(t)&&d(e.toString)}function pu(e){if(Do(e)){return"#"}var t=e.prototype&&e.prototype.constructor;if(d(t)&&go(t)){if(e[fo]&&t.hasOwnProperty("__name__")){var r=t.__name__;if(D.isString(r)){r=r.toString();return"#")}return"#"}}if(e.hasOwnProperty("__name__")){var n=e.__name__;if(p(n)==="symbol"){n=ua(n)}if(typeof n==="string"){return"#")}}if(hu(e,"toString")){return e.toString()}else if(e.name&&!go(e)){return"#")}else{return"#"}}var _u=new Map;[[Error,function(e){return e.message}],[$,function(e,t){var r=t.quote,n=t.skip_cycles,i=t.pair_args;if(!n){e.markCycles()}return e.toString.apply(e,[r].concat(U(i)))}],[h,function(e,t){var r=t.quote;if(r){return e.toString()}return e.valueOf()}],[D,function(e,t){var r=t.quote;e=e.toString();if(r){return JSON.stringify(e).replace(/\\n/g,"\n")}return e}],[RegExp,function(e){return"#"+e.toString()}]].forEach(function(e){var t=b(e,2),r=t[0],n=t[1];_u.set(r,n)});var du=[Y,j,J,vs,Qo,Zo,A,ca];function vu(e,t,r){if(typeof jQuery!=="undefined"&&e instanceof jQuery.fn.init){return"#"}if(cu.has(e)){return cu.get(e)}if(yu(e)){return"#"}if(e){var n=e.constructor;if(_u.has(n)){for(var i=arguments.length,a=new Array(i>3?i-3:0),u=3;u"}if(e===null){return"null"}if(p(e)==="object"){var f=e.constructor;if(!f){f=Object}var l;if(typeof f.__class__==="string"){l=f.__class__}else{var h=su(e);if(h){if(d(h)){return h(e,t)}else{throw new Error("toString: Invalid repr value")}}l=f.name}if(d(e.toString)&&go(e.toString)){return e.toString().valueOf()}if(zs(e)==="instance"){if(go(f)&&f.__name__){l=f.__name__.valueOf()}else if(!Do(f)){l="instance"}}if(Yu(e,Symbol.iterator)){if(l){return"#")}return"#"}if(Yu(e,Symbol.asyncIterator)){if(l){return"#")}return"#"}if(l!==""){return"#<"+l+">"}return"#"}if(typeof e!=="string"){return e.toString()}return e}function yu(e){return e&&p(e)==="object"&&e.hasOwnProperty&&e.hasOwnProperty("constructor")&&typeof e.constructor==="function"&&e.constructor.prototype===e}$.prototype.markCycles=function(){mu(this);return this};$.prototype.haveCycles=function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:null;if(!e){return this.haveCycles("car")||this.haveCycles("cdr")}return!!(this[co]&&this[co][e])};function mu(e){var t=[];var i=[];var a=[];function u(e){if(!t.includes(e)){t.push(e)}}function o(e,t,r,n){if(r instanceof $){if(n.includes(r)){if(!a.includes(r)){a.push(r)}if(!e[co]){e[co]={}}e[co][t]=r;if(!i.includes(e)){i.push(e)}return true}}}var s=ta(function e(t,r){if(t instanceof $){delete t.ref;delete t[co];u(t);r.push(t);var n=o(t,"car",t.car,r);var i=o(t,"cdr",t.cdr,r);if(!n){s(t.car,r.slice())}if(!i){return new ea(function(){return e(t.cdr,r.slice())})}}});function r(e,t){if(e[co][t]instanceof $){var r=n.indexOf(e[co][t]);e[co][t]="#".concat(r,"#")}}s(e,[]);var n=t.filter(function(e){return a.includes(e)});n.forEach(function(e,t){e[so]="#".concat(t,"=")});i.forEach(function(e){r(e,"car");r(e,"cdr")})}$.prototype.toString=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},r=t.nested,n=r===void 0?false:r;var i=[];if(this[so]){i.push(this[so]+"(")}else if(!n){i.push("(")}var a;if(this[co]&&this[co].car){a=this[co].car}else{a=vu(this.car,e,true)}if(a!==undefined){i.push(a)}if(this.cdr instanceof $){if(this[co]&&this[co].cdr){i.push(" . ");i.push(this[co].cdr)}else{if(this.cdr[so]){i.push(" . ")}else{i.push(" ")}var u=this.cdr.toString(e,{nested:true});i.push(u)}}else if(this.cdr!==V){i=i.concat([" . ",vu(this.cdr,e,true)])}if(!n||this[so]){i.push(")")}return i.join("")};$.prototype.set=function(e,t){this[e]=t;if(t instanceof $){this.markCycles()}};$.prototype.append=function(e){if(e instanceof Array){return this.append($.fromArray(e))}var t=this;if(t.car===undefined){if(e instanceof $){this.car=e.car;this.cdr=e.cdr}else{this.car=e}}else if(e!==V){while(true){if(t instanceof $&&t.cdr!==V){t=t.cdr}else{break}}t.cdr=e}return this};$.prototype.serialize=function(){return[this.car,this.cdr]};$.prototype[Symbol.iterator]=function(){var r=this;return{next:function e(){var t=r;r=t.cdr;if(t===V){return{value:undefined,done:true}}else{return{value:t.car,done:false}}}}};function gu(e){return e<0?-e:e}function bu(e,t){var r=re(t),n=r[0],i=r.slice(1);while(i.length>0){var a=i,u=b(a,1),o=u[0];if(!e(n,o)){return false}var s=i;var c=re(s);n=c[0];i=c.slice(1)}return true}function wu(e,t){if(d(e)){return d(t)&&Zu(e)===Zu(t)}else if(e instanceof j){if(!(t instanceof j)){return false}var r;if(e.__type__===t.__type__){if(e.__type__==="complex"){r=e.__im__.__type__===t.__im__.__type__&&e.__re__.__type__===t.__re__.__type__}else{r=true}if(r&&e.cmp(t)===0){if(e.valueOf()===0){return Object.is(e.valueOf(),t.valueOf())}return true}}return false}else if(typeof e==="number"){if(typeof t!=="number"){return false}if(Number.isNaN(e)){return Number.isNaN(t)}if(e===Number.NEGATIVE_INFINITY){return t===Number.NEGATIVE_INFINITY}if(e===Number.POSITIVE_INFINITY){return t===Number.POSITIVE_INFINITY}return wu(j(e),j(t))}else if(e instanceof h){if(!(t instanceof h)){return false}return e.__char__===t.__char__}else{return e===t}}function Du(e,t){if(zs(e)!==zs(t)){return false}if(!Eu(e)){return false}if(e instanceof RegExp){return e.source===t.source}if(e instanceof D){return e.valueOf()===t.valueOf()}return wu(e,t)}function Eu(e){return e instanceof Y||D.isString(e)||e===V||e===null||e instanceof h||e instanceof j||e===true||e===false}var xu=function(){if(Math.trunc){return Math.trunc}else{return function(e){if(e===0){return 0}else if(e<0){return Math.ceil(e)}else{return Math.floor(e)}}}}();function J(e,t,r,n){if(typeof this!=="undefined"&&this.constructor!==J||typeof this==="undefined"){return new J(e,t)}F("Macro",e,"string",1);F("Macro",t,"function",2);if(r){if(n){this.__doc__=r}else{this.__doc__=Sa(r)}}this.__name__=e;this.__fn__=t}J.defmacro=function(e,t,r,n){var i=new J(e,t,r,n);i.__defmacro__=true;return i};J.prototype.invoke=function(e,t,r){var n=t.env,i=he(t,Un);var a=q(q({},i),{},{macro_expand:r});var u=this.__fn__.call(n,e,a,this.__name__);return u};J.prototype.toString=function(){return"#")};var Au="define-macro";var Fu=-1e4;function ku(c){return function(){var r=ie(C.mark(function e(r,m){var a,g,n,i,u,b,w,D,E,x,A,F,o,k,s;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:s=function e(){s=ie(C.mark(function e(r,n,i){var a,u,o,s,c,f,l,h,p,_,d,v,y;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(!(r instanceof $&&r.car instanceof Y)){t.next=50;break}if(!r[oo]){t.next=3;break}return t.abrupt("return",r);case 3:a=r.car.valueOf();u=i.get(r.car,{throwError:false});o=b(r.car);s=o||w(u,r)||D(u);if(!(s&&r.cdr.car instanceof $)){t.next=28;break}if(!o){t.next=15;break}g=x(r.cdr.car);t.next=12;return F(r.cdr.car,n);case 12:c=t.sent;t.next=17;break;case 15:g=E(r.cdr.car);c=r.cdr.car;case 17:t.t0=$;t.t1=r.car;t.t2=$;t.t3=c;t.next=23;return k(r.cdr.cdr,n,i);case 23:t.t4=t.sent;t.t5=new t.t2(t.t3,t.t4);return t.abrupt("return",new t.t0(t.t1,t.t5));case 28:if(!A(a,u)){t.next=50;break}f=u instanceof Cu?r:r.cdr;t.next=32;return u.invoke(f,q(q({},m),{},{env:i}),true);case 32:l=t.sent;if(!(u instanceof Cu)){t.next=41;break}h=l,p=h.expr,_=h.scope;if(!(p instanceof $)){t.next=40;break}if(!(n!==-1&&n<=1||n")}return"#"};var Ou=ce(function e(t){ae(this,e);f(this,"_syntax",t,{hidden:true});f(this._syntax,"_param",true,{hidden:true})});Cu.Parameter=Ou;function Su(e,t,P,N){var r=arguments.length>4&&arguments[4]!==undefined?arguments[4]:{};var R={"...":{symbols:{},lists:[]},symbols:{}};var T=r.expansion,L=r.define;z(P);function M(t,e){var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:[];var n=arguments.length>3&&arguments[3]!==undefined?arguments[3]:false;z({code:e,pattern:t});if(Eu(t)&&!(t instanceof Y)){return Du(t,e)}if(t instanceof Y&&P.includes(t.literal())){if(!Y.is(e,t)){return false}var i=T.ref(t);return!i||i===L||i===K}if(Array.isArray(t)&&Array.isArray(e)){z("<<< a 1");if(t.length===0&&e.length===0){return true}if(Y.is(t[1],N)){if(t[0]instanceof Y){var a=t[0].valueOf();z("<<< a 2 "+n);if(n){var u=e.length-2;var o=u>0?e.slice(0,u):e;var s=$.fromArray(o,false);if(!R["..."].symbols[a]){R["..."].symbols[a]=new $(s,V)}else{R["..."].symbols[a].append(new $(s,V))}}else{R["..."].symbols[a]=$.fromArray(e,false)}}else if(Array.isArray(t[0])){z("<<< a 3");var c=U(r);if(!e.every(function(e){return M(t[0],e,c,true)})){return false}}if(t.length>2){var f=t.slice(2);return M(f,e.slice(-f.length),r,n)}return true}var l=M(t[0],e[0],r,n);z({first:l,pattern:t[0],code:e[0]});var h=M(t.slice(1),e.slice(1),r,n);z({first:l,rest:h});return l&&h}if(t instanceof $&&t.car instanceof $&&t.car.cdr instanceof $&&Y.is(t.car.cdr.car,N)){z(">> 0");if(e===V){z({pattern:t});if(t.car.car instanceof Y){var p=t.car.car.valueOf();if(R["..."].symbols[p]){throw new Error("syntax: named ellipsis can only "+"appear onces")}R["..."].symbols[p]=e}}}if(t instanceof $&&t.cdr instanceof $&&Y.is(t.cdr.car,N)){if(t.cdr.cdr!==V){if(t.cdr.cdr instanceof $){var _=t.cdr.cdr.length();if(!Tu(e)){return false}var d=e.length();var v=e;while(d-1>_){v=v.cdr;d--}var y=v.cdr;v.cdr=V;if(!M(t.cdr.cdr,y,r,n)){return false}}}if(t.car instanceof Y){var m=t.car.__name__;if(R["..."].symbols[m]&&!r.includes(m)&&!n){throw new Error("syntax: named ellipsis can only appear onces")}z(">> 1");if(e===V){z(">> 2");if(n){z("NIL");R["..."].symbols[m]=V}else{z("NULL");R["..."].symbols[m]=null}}else if(e instanceof $&&(e.car instanceof $||e.car===V)){z(">> 3 "+n);if(n){if(R["..."].symbols[m]){var g=R["..."].symbols[m];if(g===V){g=new $(V,new $(e,V))}else{g=g.append(new $(e,V))}R["..."].symbols[m]=g}else{R["..."].symbols[m]=new $(e,V)}}else{z(">> 4");R["..."].symbols[m]=new $(e,V)}}else{z(">> 6");if(e instanceof $){if(!(e.cdr instanceof $)&&e.cdr!==V){z(">> 7 (b)");if(t.cdr.cdr===V){return false}else if(!R["..."].symbols[m]){R["..."].symbols[m]=new $(e.car,V);return M(t.cdr.cdr,e.cdr)}}var b=e.last_pair();if(b.cdr!==V){if(t.cdr.cdr===V){return false}else{var w=e.clone();w.last_pair().cdr=V;R["..."].symbols[m]=w;return M(t.cdr.cdr,b.cdr)}}z(">> 7 "+n);r.push(m);if(!R["..."].symbols[m]){R["..."].symbols[m]=new $(e,V)}else{var D=R["..."].symbols[m];R["..."].symbols[m]=D.append(new $(e,V))}z({IIIIII:R["..."].symbols[m]})}else if(t.car instanceof Y&&t.cdr instanceof $&&Y.is(t.cdr.car,N)){z(">> 8");R["..."].symbols[m]=null;return M(t.cdr.cdr,e)}else{z(">> 9");return false}}return true}else if(t.car instanceof $){var E=U(r);if(e===V){z(">> 10");R["..."].lists.push(V);return true}z(">> 11");var x=e;while(x instanceof $){if(!M(t.car,x.car,E,true)){return false}x=x.cdr}return true}if(Array.isArray(t.car)){var E=U(r);var A=e;while(A instanceof $){if(!M(t.car,A.car,E,true)){return false}A=A.cdr}return true}return false}if(t instanceof Y){if(Y.is(t,N)){throw new Error("syntax: invalid usage of ellipsis")}z(">> 12");var F=t.__name__;if(P.includes(F)){return true}if(n){var k,C;z(R["..."].symbols[F]);(C=(k=R["..."].symbols)[F])!==null&&C!==void 0?C:k[F]=[];R["..."].symbols[F].push(e)}else{R.symbols[F]=e}return true}if(t instanceof $&&e instanceof $){z(">> 13");z({a:13,code:e,pattern:t});if(e.cdr===V){var O=t.car instanceof Y&&t.cdr instanceof Y;if(O){if(!M(t.car,e.car,r,n)){return false}z(">> 14");var S=t.cdr.valueOf();if(!(S in R.symbols)){R.symbols[S]=V}S=t.car.valueOf();if(!(S in R.symbols)){R.symbols[S]=e.car}return true}}z({pattern:t,code:e});if(t.cdr instanceof $&&t.cdr.cdr instanceof $&&t.cdr.car instanceof Y&&Y.is(t.cdr.cdr.car,N)&&t.cdr.cdr.cdr instanceof $&&!Y.is(t.cdr.cdr.cdr.car,N)&&M(t.car,e.car,r,n)&&M(t.cdr.cdr.cdr,e.cdr,r,n)){var B=t.cdr.car.__name__;z({pattern:t,code:e,name:B});if(P.includes(B)){return true}R["..."].symbols[B]=null;return true}z("recur");z({pattern:t,code:e});var j=M(t.car,e.car,r,n);z({car:j,pattern:t.car,code:e.car});var I=M(t.cdr,e.cdr,r,n);z({car:j,cdr:I});if(j&&I){return true}}else if(t===V&&(e===V||e===undefined)){return true}else if(t.car instanceof $&&Y.is(t.car.car,N)){throw new Error("syntax: invalid usage of ellipsis")}else{return false}}if(M(e,t)){return R}}function Bu(e,i){function a(t){if(t instanceof $){if(!i.length){return t}var e=a(t.car);var r=a(t.cdr);return new $(e,r)}else if(t instanceof Y){var n=i.find(function(e){return e.gensym===t});if(n){return Y(n.name)}return t}else{return t}}return a(e)}function ju(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};var j=e.bindings,t=e.expr,I=e.scope,u=e.symbols,f=e.names,P=e.ellipsis;var l={};function o(e){if(e instanceof Y){return true}return["string","symbol"].includes(p(e))}function N(e){if(!o(e)){var t=zs(e);throw new Error("syntax: internal error, need symbol got ".concat(t))}var r=e.valueOf();if(r===P){throw new Error("syntax: internal error, ellipis not transformed")}var n=p(r);if(["string","symbol"].includes(n)){if(r in j.symbols){return j.symbols[r]}else if(n==="string"&&r.match(/\./)){var i=r.split(".");var a=i[0];if(a in j.symbols){return $.fromArray([Y("."),j.symbols[a]].concat(i.slice(1).map(function(e){return D(e)})))}}}if(u.includes(r)){return e}return s(r,e)}function s(e,t){if(!l[e]){var r=I.ref(e);if(p(e)==="symbol"&&!r){e=t.literal()}if(l[e]){return l[e]}var n=sa(e);if(r){var i=I.get(e);I.set(n,i)}else{var a=I.get(e,{throwError:false});if(typeof a!=="undefined"){I.set(n,a)}}f.push({name:e,gensym:n});l[e]=n;if(typeof e==="string"&&e.match(/\./)){var u=e.split(".").filter(Boolean),o=re(u),s=o[0],c=o.slice(1);if(l[s]){yo(n,"__object__",[l[s]].concat(U(c)))}}}return l[e]}function R(e,t,r){var n=arguments.length>3&&arguments[3]!==undefined?arguments[3]:function(){};var i=r.nested;z({bindings:t,expr:e});if(Array.isArray(e)&&!e.length){return e}if(e instanceof Y){var a=e.valueOf();if(oa(e)&&!t[a]);z("[t 1");if(t[a]){if(t[a]instanceof $){var u=t[a],o=u.car,s=u.cdr;if(i){var c=o.car,f=o.cdr;if(f!==V){n(a,new $(f,V))}return c}if(s!==V){n(a,s)}return o}else if(t[a]instanceof Array){n(a,t[a].slice(1));return t[a][0]}}return N(e)}var l=Array.isArray(e);if(e instanceof $||l){var h=l?e[0]:e.car;var p=l?e[1]:Tu(e.cdr)&&e.cdr.car;if(h instanceof Y&&Y.is(p,P)){l?e.slice(2):e.cdr.cdr;z("[t 2");var _=h.valueOf();var d=t[_];if(d===null){return}else if(d){z({name:_,binding:t[_]});if(d instanceof $){z("[t 2 Pair "+i);var v=d.car,y=d.cdr;var m=l?e.slice(2):e.cdr.cdr;if(i){if(y!==V){z("|| next 1");n(_,y)}if(l&&m.length||m!==V&&!l){var g=R(m,t,r,n);if(l){return v.concat(g)}else if(Tu(v)){return v.append(g)}else{z("UNKNOWN")}}return v}else if(v instanceof $){if(v.cdr!==V){z("|| next 2");n(_,new $(v.cdr,y))}return v.car}else if(y===V){return v}else{var b=e.last_pair();if(b.cdr instanceof Y){z("|| next 3");n(_,d.last_pair());return v}}}else if(d instanceof Array){z("[t 2 Array "+i);if(i){n(_,d.slice(1));return $.fromArray(d)}else{var w=d.slice(1);if(w.length){n(_,w)}return d[0]}}else{return d}}}z("[t 3 recur ",e);var D=l?e.slice(1):e.cdr;var E=R(h,t,r,n);var x=R(D,t,r,n);z({head:E,rest:x});if(l){return[E].concat(x)}return new $(E,x)}return e}function T(t,r){var e=Object.values(t);var n=Object.getOwnPropertySymbols(t);if(n.length){e.push.apply(e,U(n.map(function(e){return t[e]})))}return e.length&&e.every(function(e){if(e===null){return!r}return e instanceof $||e===V||e instanceof Array&&e.length})}function L(e){return Object.keys(e).concat(Object.getOwnPropertySymbols(e))}function M(i){var e=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},t=e.disabled;z("traverse>> ",i);var a=Array.isArray(i);if(a&&i.length===0){return i}if(i instanceof $||a){var r=a?i[0]:i.car;var n,u;if(a){n=i[1];u=i.slice(2)}else if(Tu(i.cdr)){n=i.cdr.car;u=i.cdr.cdr}z({first:r,second:n,rest_second:u});if(!t&&Tu(r)&&Y.is(r.car,P)){return M(r.cdr,{disabled:true})}if(n&&Y.is(n,P)&&!t){z(">> 1");var o=j["..."].symbols;var s=Object.values(o);if(s.length&&s.every(function(e){return e===null})){z(">>> 1 (a)");return M(u,{disabled:t})}var c=L(o);var f=r instanceof Y&&Y.is(u.car,P);if(Tu(r)||f){z(">>> 1 (b)");if(j["..."].lists[0]===V){if(!f){return M(u,{disabled:t})}z(u);return V}var l=r;if(f){z(">>> 1 (c)");l=new $(r,new $(n,V))}z(">> 2");var h;if(c.length){z(">> 2 (a)");var p=q({},o);h=a?[]:V;var _=function e(){z({bind:p});if(!T(p)){return 1}var n={};var t=function e(t,r){n[t]=r};var r=R(l,p,{nested:true},t);if(r!==undefined){if(f){if(a){if(Array.isArray(r)){var i;(i=h).push.apply(i,U(r))}else{z("ZONK {1}")}}else{if(h===V){h=r}else{h=h.append(r)}}}else if(a){h.push(r)}else{h=new $(r,h)}}p=n};while(true){if(_())break}if(h!==V&&!f&&!a){h=h.reverse()}if(a){if(u){z({rest_second:u,expr:i});var d=M(u,{disabled:t});return h.concat(d)}return h}if(i.cdr.cdr!==V&&!Y.is(i.cdr.cdr.car,P)){var v=M(i.cdr.cdr,{disabled:t});return h.append(v)}return h}else{z(">> 3");var y=R(r,o,{nested:true});if(y){return new $(y,V)}return V}}else if(r instanceof Y){z(">> 4");if(Y.is(u.car,P)){z(">> 4 (a)")}else{z(">> 4 (b)")}var m=r.__name__;var g=fe({},m,o[m]);z({bind:g});var b=o[m]===null;var w=a?[]:V;var D=function e(){if(!T(g,true)){z({bind:g});return 1}var n={};var t=function e(t,r){n[t]=r};var r=R(i,g,{nested:false},t);z({value:r});if(typeof r!=="undefined"){if(a){w.push(r)}else{w=new $(r,w)}}g=n};while(true){if(D())break}if(w!==V&&!a){w=w.reverse()}if(i.cdr instanceof $){if(i.cdr.cdr instanceof $||i.cdr.cdr instanceof Y){var E=M(i.cdr.cdr,{disabled:t});z({node:E});if(b){return E}if(w===V){w=E}else{w.append(E)}z({result:w,node:E})}}z("<<<< 2");return w}}var x=M(r,{disabled:t});var A;var F;if(r instanceof Y){var k=I.get(r,{throwError:false});F=k instanceof J&&k.__name__==="syntax-rules"}if(F){if(i.cdr.car instanceof Y){A=new $(M(i.cdr.car,{disabled:t}),new $(i.cdr.cdr.car,M(i.cdr.cdr.cdr,{disabled:t})))}else{A=new $(i.cdr.car,M(i.cdr.cdr,{disabled:t}))}z("REST >>>> ",A)}else{A=M(i.cdr,{disabled:t})}z({a:true,car:vu(i.car),cdr:vu(i.cdr),head:vu(x),rest:vu(A)});return new $(x,A)}if(i instanceof Y){if(t&&Y.is(i,P)){return i}var C=Object.keys(j["..."].symbols);var O=i.literal();if(C.includes(O)){var S="missing ellipsis symbol next to name `".concat(O,"'");throw new Error("syntax-rules: ".concat(S))}var B=N(i);if(typeof B!=="undefined"){return B}}return i}return M(t,{})}function Iu(e){return zu(e)||e===V||e===null}function d(e){return typeof e==="function"&&typeof e.bind==="function"}function Pu(e){return e instanceof ec}function Nu(e){return e instanceof Zs}function Ru(e){return e instanceof Qs}function Tu(e){return e instanceof $}function Lu(e){return e instanceof A}function Mu(e){return d(e)||Pu(e)||Ru(e)||Uu(e)}function Uu(e){return e instanceof J||e instanceof Ou}function qu(e){if(e instanceof ca){return false}if(e instanceof Promise){return true}return!!e&&d(e.then)}function zu(e){return typeof e==="undefined"}function Yu(e,t){if(Ku(e,t)||Ku(e.__proto__,t)){return d(e[t])}}function Vu(e){if(!e){return false}if(p(e)!=="object"){return false}if(e.__instance__){e.__instance__=false;return e.__instance__}return false}function $u(e){var t=p(e);return["string","function"].includes(t)||p(e)==="symbol"||e instanceof ca||e instanceof Y||e instanceof j||e instanceof D||e instanceof RegExp}function Ju(e){return e instanceof j||e instanceof D||e instanceof h}function Ku(e,t){if(e===null){return false}return p(e)==="object"&&t in Object.getOwnPropertySymbols(e)}function Hu(e){switch(p(e)){case"string":return D(e);case"bigint":return j(e);case"number":if(Number.isNaN(e)){return Es}else{return j(e)}}return e}function Wu(r,n){var e=Object.getOwnPropertyNames(r);var t=Object.getOwnPropertySymbols(r);var i={};e.concat(t).forEach(function(e){var t=n(r[e]);i[e]=t});return i}function Gu(t){var e=[D,j].some(function(e){return t instanceof e});if(e){return t.valueOf()}if(t instanceof Array){return t.map(Gu)}if(t instanceof ca){delete t.then}if(nu(t)){return Wu(t,Gu)}return t}function Qu(e,t){if(e instanceof $){e.markCycles();return ys(e)}if(d(e)){if(t){return Xu(e,t)}}return Hu(e)}function Zu(e){if(to(e)){return e[uo]}return e}function Xu(e,t){if(e[Symbol["for"]("__bound__")]){return e}var r=e.bind(t);var n=Object.getOwnPropertyNames(e);var i=Wn(n),a;try{for(i.s();!(a=i.n()).done;){var u=a.value;if(vo(u)){try{r[u]=e[u]}catch(e){}}}}catch(e){i.e(e)}finally{i.f()}yo(r,"__fn__",e);yo(r,"__context__",t);yo(r,"__bound__",true);if(Do(e)){yo(r,"__native__",true)}if(nu(t)&&go(e)){yo(r,"__method__",true)}r.valueOf=function(){return e};return r}function eo(e){return to(e)&&e[Symbol["for"]("__context__")]===Object}function to(e){return!!(d(e)&&e[uo])}function ro(e){if(d(e)){var t=e[ao];if(t&&(t===Lc||t.constructor&&t.constructor.__class__)){return true}}return false}function no(e){return e instanceof Qo||e instanceof Zo}function io(e){if(d(e)){if(no(e[ao])){return true}}return false}var ao=Symbol["for"]("__context__");var uo=Symbol["for"]("__fn__");var oo=Symbol["for"]("__data__");var so=Symbol["for"]("__ref__");var co=Symbol["for"]("__cycles__");var fo=Symbol["for"]("__class__");var lo=Symbol["for"]("__method__");var ho=Symbol["for"]("__prototype__");var po=Symbol["for"]("__lambda__");var _o=["name","length","caller","callee","arguments","prototype"];function vo(e){return!_o.includes(e)}function yo(e,t,r){Object.defineProperty(e,Symbol["for"](t),{get:function e(){return r},set:function e(){},configurable:false,enumerable:false})}function mo(t,r){try{Object.defineProperty(t,"length",{get:function e(){return r}});return t}catch(e){var n=new Array(r).fill(0).map(function(e,t){return"a"+t}).join(",");var i=new Function("f","return function(".concat(n,") {\n return f.apply(this, arguments);\n };"));return i(t)}}function go(e){return e&&e[po]}function bo(e){return e&&e[lo]}function wo(e){return go(e)&&!e[ho]&&!bo(e)&&!io(e)}function Do(e){var t=Symbol["for"]("__native__");return d(e)&&e.toString().match(/\{\s*\[native code\]\s*\}/)&&(e.name.match(/^bound /)&&e[t]===true||!e.name.match(/^bound /)&&!e[t])}function Eo(e){var b;switch(e){case Symbol["for"]("letrec"):b="letrec";break;case Symbol["for"]("let"):b="let";break;case Symbol["for"]("let*"):b="let*";break;default:throw new Error("Invalid let_macro value")}return J.defmacro(b,function(t,e){var f=e.dynamic_env;var l=e.error,r=e.macro_expand,h=e.use_dynamic;var p;if(t.car instanceof Y){if(!(t.cdr.car instanceof $||t.cdr.car===V)){throw new Error("let require list of pairs")}var n;if(t.cdr.car===V){p=V;n=V}else{n=t.cdr.car.map(function(e){return e.car});p=t.cdr.car.map(function(e){return e.cdr.car})}return $.fromArray([Y("letrec"),[[t.car,$(Y("lambda"),$(n,t.cdr.cdr))]],$(t.car,p)])}else if(r){return}var _=this;p=K.get("list->array")(t.car);var d=_.inherit(b);var v,y;if(b==="let*"){y=d}else if(b==="let"){v=[]}var m=0;function g(){var e=new $(new Y("begin"),t.cdr);return k(e,{env:d,dynamic_env:d,use_dynamic:h,error:l})}return function t(){var r=p[m++];f=b==="let*"?d:_;if(!r){if(v&&v.length){var e=v.map(function(e){return e.value});var n=e.filter(qu);if(n.length){return fa(e).then(function(e){for(var t=0,r=e.length;t1&&arguments[1]!==undefined?arguments[1]:{},r=t.use_dynamic,n=t.error;var i=this;var a=this;var u=[];var o=e;while(o instanceof $){u.push(k(o.car,{env:i,dynamic_env:a,use_dynamic:r,error:n}));o=o.cdr}var s=u.filter(qu).length;if(s){return fa(u).then(c.bind(this))}else{return c.call(this,u)}})}function Ao(e){for(var t=arguments.length,r=new Array(t>1?t-1:0),n=1;n2?n-2:0),a=2;a1&&arguments[1]!==undefined?arguments[1]:null;return function(){for(var e=arguments.length,t=new Array(e),r=0;r1?e-1:0),r=1;r=u){return a.apply(this,n)}else{return i}}return i.apply(this,arguments)}}function Po(n,i){F("limit",i,"function",2);return function(){for(var e=arguments.length,t=new Array(e),r=0;r1){e=e.toLowerCase();if(h.__names__[e]){t=e;e=h.__names__[e]}else{throw new Error("Internal: Unknown named character")}}else{t=h.__rev_names__[e]}Object.defineProperty(this,"__char__",{value:e,enumerable:true});if(t){Object.defineProperty(this,"__name__",{value:t,enumerable:true})}}h.__names__=bi;h.__rev_names__={};Object.keys(h.__names__).forEach(function(e){var t=h.__names__[e];h.__rev_names__[t]=e});h.prototype.toUpperCase=function(){return h(this.__char__.toUpperCase())};h.prototype.toLowerCase=function(){return h(this.__char__.toLowerCase())};h.prototype.toString=function(){return"#\\"+(this.__name__||this.__char__)};h.prototype.valueOf=h.prototype.serialize=function(){return this.__char__};function D(e){if(typeof this!=="undefined"&&!(this instanceof D)||typeof this==="undefined"){return new D(e)}if(e instanceof Array){this.__string__=e.map(function(e,t){F("LString",e,"character",t+1);return e.toString()}).join("")}else{this.__string__=e.valueOf()}}{var No=["length","constructor"];var Ro=Object.getOwnPropertyNames(String.prototype).filter(function(e){return!No.includes(e)});var To=function e(n){return function(){for(var e=arguments.length,t=new Array(e),r=0;r0){r.push(this.__string__.substring(0,e))}r.push(t);if(e1&&arguments[1]!==undefined?arguments[1]:false;if(e instanceof j){return e}if(typeof this!=="undefined"&&!(this instanceof j)||typeof this==="undefined"){return new j(e,t)}if(typeof e==="undefined"){throw new Error("Invalid LNumber constructor call")}var r=j.getType(e);if(j.types[r]){return j.types[r](e,t)}var n=e instanceof Array&&D.isString(e[0])&&j.isNumber(e[1]);if(e instanceof j){return j(e.value)}if(!j.isNumber(e)&&!n){throw new Error("You can't create LNumber from ".concat(zs(e)))}if(e===null){e=0}var i;if(n){var a=e,u=b(a,2),o=u[0],s=u[1];if(o instanceof D){o=o.valueOf()}if(s instanceof j){s=s.valueOf()}var c=o.match(/^([+-])/);var f=false;if(c){o=o.replace(/^[+-]/,"");if(c[1]==="-"){f=true}}}if(Number.isNaN(e)){return g(e)}else if(typeof BigInt!=="undefined"){if(typeof e!=="bigint"){if(n){var l;switch(s){case 8:l="0o";break;case 16:l="0x";break;case 2:l="0b";break;case 10:l="";break}if(typeof l==="undefined"){var h=BigInt(s);i=U(o).map(function(e,t){return BigInt(parseInt(e,s))*$o(h,BigInt(t))}).reduce(function(e,t){return e+t})}else{i=BigInt(l+o)}}else{i=BigInt(e)}if(f){i*=BigInt(-1)}}else{i=e}return x(i,true)}else if(typeof oi!=="undefined"&&!(e instanceof oi)){if(e instanceof Array){return x(L(oi,U(e)))}return x(new oi(e))}else if(n){this.constant(parseInt(o,s),"integer")}else{this.constant(e,"integer")}}j.prototype.constant=function(e,t){Object.defineProperty(this,"__value__",{value:e,enumerable:true});Object.defineProperty(this,"__type__",{value:t,enumerable:true})};j.types={float:function e(t){return new g(t)},complex:function e(t){var r=arguments.length>1&&arguments[1]!==undefined?arguments[1]:false;if(!j.isComplex(t)){t={im:0,re:t}}return new m(t,r)},rational:function e(t){var r=arguments.length>1&&arguments[1]!==undefined?arguments[1]:false;if(!j.isRational(t)){t={num:t,denom:1}}return new E(t,r)}};j.prototype.serialize=function(){return this.__value__};j.prototype.isNaN=function(){return Number.isNaN(this.__value__)};j.prototype.gcd=function(e){var t=this.abs();e=e.abs();if(e.cmp(t)===1){var r=t;t=e;e=r}while(true){t=t.rem(e);if(t.cmp(0)===0){return e}e=e.rem(t);if(e.cmp(0)===0){return t}}};j.isFloat=function e(t){return t instanceof g||Number(t)===t&&t%1!==0};j.isNumber=function(e){return e instanceof j||j.isNative(e)||j.isBN(e)};j.isComplex=function(e){if(!e){return false}var t=e instanceof m||(j.isNumber(e.im)||j.isRational(e.im)||Number.isNaN(e.im))&&(j.isNumber(e.re)||j.isRational(e.re)||Number.isNaN(e.re));return t};j.isRational=function(e){if(!e){return false}return e instanceof E||j.isNumber(e.num)&&j.isNumber(e.denom)};j.isInteger=function(e){if(!(j.isNative(e)||e instanceof j)){return false}if(j.isFloat(e)){return false}if(j.isRational(e)){return false}if(j.isComplex(e)){return false}return true};j.isNative=function(e){return typeof e==="bigint"||typeof e==="number"};j.isBigInteger=function(e){return e instanceof x||typeof e==="bigint"||j.isBN(e)};j.isBN=function(e){return typeof oi!=="undefined"&&e instanceof oi};j.getArgsType=function(e,t){if(e instanceof g||t instanceof g){return g}if(e instanceof x||t instanceof x){return x}return j};j.prototype.toString=function(e){if(Number.isNaN(this.__value__)){return"+nan.0"}if(e>=2&&e<36){return this.__value__.toString(e)}return this.__value__.toString()};j.prototype.asType=function(e){var t=j.getType(this);return j.types[t]?j.types[t](e):j(e)};j.prototype.isBigNumber=function(){return typeof this.__value__==="bigint"||typeof oi!=="undefined"&&!(this.value instanceof oi)};["floor","ceil","round"].forEach(function(e){j.prototype[e]=function(){if(this["float"]||j.isFloat(this.__value__)){return j(Math[e](this.__value__))}else{return j(Math[e](this.valueOf()))}}});j.prototype.valueOf=function(){if(j.isNative(this.__value__)){return Number(this.__value__)}else if(j.isBN(this.__value__)){return this.__value__.toNumber()}};var qo=function(){var e=function e(t,r){return[t,r]};return{bigint:{bigint:e,float:function e(t,r){return[g(t.valueOf()),r]},rational:function e(t,r){return[{num:t,denom:1},r]},complex:function e(t,r){return[{im:0,re:t},r]}},integer:{integer:e,float:function e(t,r){return[g(t.valueOf()),r]},rational:function e(t,r){return[{num:t,denom:1},r]},complex:function e(t,r){return[{im:0,re:t},r]}},float:{bigint:function e(t,r){return[t,r&&g(r.valueOf())]},integer:function e(t,r){return[t,r&&g(r.valueOf())]},float:e,rational:function e(t,r){return[t,r&&g(r.valueOf())]},complex:function e(t,r){return[{re:t,im:g(0)},r]}},complex:{bigint:t("bigint"),integer:t("integer"),float:t("float"),rational:t("rational"),complex:function e(t,r){var n=j.coerce(t.__re__,r.__re__),i=b(n,2),a=i[0],u=i[1];var o=j.coerce(t.__im__,r.__im__),s=b(o,2),c=s[0],f=s[1];return[{im:c,re:a},{im:f,re:u}]}},rational:{bigint:function e(t,r){return[t,r&&{num:r,denom:1}]},integer:function e(t,r){return[t,r&&{num:r,denom:1}]},float:function e(t,r){return[g(t.valueOf()),r]},rational:e,complex:function e(t,r){return[{im:zo(t.__type__,r.__im__.__type__,0)[0],re:zo(t.__type__,r.__re__.__type__,t)[0]},{im:zo(t.__type__,r.__im__.__type__,r.__im__)[0],re:zo(t.__type__,r.__re__.__type__,r.__re__)[0]}]}}};function t(r){return function(e,t){return[{im:zo(r,e.__im__.__type__,0,e.__im__)[1],re:zo(r,e.__re__.__type__,0,e.__re__)[1]},{im:zo(r,e.__im__.__type__,0,0)[1],re:zo(r,t.__type__,0,t)[1]}]}}}();function zo(e,t,r,n){return qo[e][t](r,n)}j.coerce=function(e,t){var r=j.getType(e);var n=j.getType(t);if(!qo[r]){throw new Error("LNumber::coerce unknown lhs type ".concat(r))}else if(!qo[r][n]){throw new Error("LNumber::coerce unknown rhs type ".concat(n))}var i=qo[r][n](e,t);return i.map(function(e){return j(e,true)})};j.prototype.coerce=function(e){if(!(typeof e==="number"||e instanceof j)){throw new Error("LNumber: you can't coerce ".concat(zs(e)))}if(typeof e==="number"){e=j(e)}return j.coerce(this,e)};j.getType=function(e){if(e instanceof j){return e.__type__}if(j.isFloat(e)){return"float"}if(j.isComplex(e)){return"complex"}if(j.isRational(e)){return"rational"}if(typeof e==="number"){return"integer"}if(typeof BigInt!=="undefined"&&typeof e!=="bigint"||typeof oi!=="undefined"&&!(e instanceof oi)){return"bigint"}};j.prototype.isFloat=function(){return!!(j.isFloat(this.__value__)||this["float"])};var Yo={add:"+",sub:"-",mul:"*",div:"/",rem:"%",or:"|",and:"&",neg:"~",shl:">>",shr:"<<"};var Vo={};Object.keys(Yo).forEach(function(t){Vo[Yo[t]]=t;j.prototype[t]=function(e){return this.op(Yo[t],e)}});j._ops={"*":function e(t,r){return t*r},"+":function e(t,r){return t+r},"-":function e(t,r){if(typeof r==="undefined"){return-t}return t-r},"/":function e(t,r){return t/r},"%":function e(t,r){return t%r},"|":function e(t,r){return t|r},"&":function e(t,r){return t&r},"~":function e(t){return~t},">>":function e(t,r){return t>>r},"<<":function e(t,r){return t<1&&arguments[1]!==undefined?arguments[1]:false;if(typeof this!=="undefined"&&!(this instanceof m)||typeof this==="undefined"){return new m(e,t)}if(e instanceof m){return m({im:e.__im__,re:e.__re__})}if(j.isNumber(e)&&t){if(!t){return Number(e)}}else if(!j.isComplex(e)){var r="Invalid constructor call for LComplex expect &(:im :re ) object but got ".concat(vu(e));throw new Error(r)}var n=e.im instanceof j?e.im:j(e.im);var i=e.re instanceof j?e.re:j(e.re);this.constant(n,i)}m.prototype=Object.create(j.prototype);m.prototype.constructor=m;m.prototype.constant=function(e,t){Object.defineProperty(this,"__im__",{value:e,enumerable:true});Object.defineProperty(this,"__re__",{value:t,enumerable:true});Object.defineProperty(this,"__type__",{value:"complex",enumerable:true})};m.prototype.serialize=function(){return{re:this.__re__,im:this.__im__}};m.prototype.toRational=function(e){if(j.isFloat(this.__im__)&&j.isFloat(this.__re__)){var t=g(this.__im__).toRational(e);var r=g(this.__re__).toRational(e);return m({im:t,re:r})}return this};m.prototype.pow=function(e){e.cmp(0);if(e===0){return j(1)}var t=j(Math.atan2(this.__im__.valueOf(),this.__re__.valueOf()));var r=j(this.modulus());if(j.isComplex(e)&&e.__im__.cmp(0)!==0){var n=e.mul(Math.log(r.valueOf())).add(m.i.mul(t).mul(e));var i=g(Math.E).pow(n.__re__.valueOf());return m({re:i.mul(Math.cos(n.__im__.valueOf())),im:i.mul(Math.sin(n.__im__.valueOf()))})}var a=e.__re__.cmp(0)>0;e=e.__re__.valueOf();if(j.isInteger(e)&&a){var u=this;while(--e){u=u.mul(this)}return u}var o=r.pow(e);var s=t.mul(e);return m({re:o.mul(Math.cos(s)),im:o.mul(Math.sin(s))})};m.prototype.add=function(e){return this.complex_op("add",e,function(e,t,r,n){return{re:e.add(t),im:r.add(n)}})};m.prototype.factor=function(){if(this.__im__ instanceof g||this.__im__ instanceof g){var e=this.__re__,t=this.__im__;var r,n;if(e instanceof g){r=e.toRational().mul(e.toRational())}else{r=e.mul(e)}if(t instanceof g){n=t.toRational().mul(t.toRational())}else{n=t.mul(t)}return r.add(n)}else{return this.__re__.mul(this.__re__).add(this.__im__.mul(this.__im__))}};m.prototype.modulus=function(){return this.factor().sqrt()};m.prototype.conjugate=function(){return m({re:this.__re__,im:this.__im__.sub()})};m.prototype.sqrt=function(){var e=this.modulus();var t,r;if(e.cmp(0)===0){t=r=e}else if(this.__re__.cmp(0)===1){t=g(.5).mul(e.add(this.__re__)).sqrt();r=this.__im__.div(t).div(2)}else{r=g(.5).mul(e.sub(this.__re__)).sqrt();if(this.__im__.cmp(0)===-1){r=r.sub()}t=this.__im__.div(r).div(2)}return m({im:r,re:t})};m.prototype.div=function(e){if(j.isNumber(e)&&!j.isComplex(e)){if(!(e instanceof j)){e=j(e)}var t=this.__re__.div(e);var r=this.__im__.div(e);return m({re:t,im:r})}else if(!j.isComplex(e)){throw new Error("[LComplex::div] Invalid value")}if(this.cmp(e)===0){var n=this.coerce(e),i=b(n,2),a=i[0],u=i[1];var o=a.__im__.div(u.__im__);return o.coerce(u.__re__)[0]}var s=this.coerce(e),c=b(s,2),f=c[0],l=c[1];var h=l.factor();var p=l.conjugate();var _=f.mul(p);if(!j.isComplex(_)){return _.div(h)}var d=_.__re__.op("/",h);var v=_.__im__.op("/",h);return m({re:d,im:v})};m.prototype.sub=function(e){return this.complex_op("sub",e,function(e,t,r,n){return{re:e.sub(t),im:r.sub(n)}})};m.prototype.mul=function(e){return this.complex_op("mul",e,function(e,t,r,n){var i={re:e.mul(t).sub(r.mul(n)),im:e.mul(n).add(t.mul(r))};return i})};m.prototype.complex_op=function(e,t,i){var a=this;var r=function e(t,r){var n=i(a.__re__,t,a.__im__,r);if("im"in n&&"re"in n){if(n.im.cmp(0)===0){return n.re}return m(n,true)}return n};if(typeof t==="undefined"){return r()}if(j.isNumber(t)&&!j.isComplex(t)){if(!(t instanceof j)){t=j(t)}var n=t.asType(0);t={__im__:n,__re__:t}}else if(!j.isComplex(t)){throw new Error("[LComplex::".concat(e,"] Invalid value"))}var u=t.__re__ instanceof j?t.__re__:this.__re__.asType(t.__re__);var o=t.__im__ instanceof j?t.__im__:this.__im__.asType(t.__im__);return r(u,o)};m._op={"+":"add","-":"sub","*":"mul","/":"div"};m.prototype._op=function(e,t){var r=m._op[e];return this[r](t)};m.prototype.cmp=function(e){var t=this.coerce(e),r=b(t,2),n=r[0],i=r[1];var a=n.__re__.coerce(i.__re__),u=b(a,2),o=u[0],s=u[1];var c=o.cmp(s);if(c!==0){return c}else{var f=n.__im__.coerce(i.__im__),l=b(f,2),h=l[0],p=l[1];return h.cmp(p)}};m.prototype.valueOf=function(){return[this.__re__,this.__im__].map(function(e){return e.valueOf()})};m.prototype.toString=function(){var e;if(this.__re__.cmp(0)!==0){e=[vu(this.__re__)]}else{e=[]}var t=this.__im__.valueOf();var r=[Number.NEGATIVE_INFINITY,Number.POSITIVE_INFINITY].includes(t);var n=vu(this.__im__);if(!r&&!Number.isNaN(t)){var i=this.__im__.cmp(0);if(i<0||i===0&&this.__im__._minus){e.push("-")}else{e.push("+")}n=n.replace(/^-/,"")}e.push(n);e.push("i");return e.join("")};function g(e){if(typeof this!=="undefined"&&!(this instanceof g)||typeof this==="undefined"){return new g(e)}if(!j.isNumber(e)){throw new Error("Invalid constructor call for LFloat")}if(e instanceof j){return g(e.valueOf())}if(typeof e==="number"){if(Object.is(e,-0)){Object.defineProperty(this,"_minus",{value:true})}this.constant(e,"float")}}g.prototype=Object.create(j.prototype);g.prototype.constructor=g;g.prototype.toString=function(){if(this.__value__===Number.NEGATIVE_INFINITY){return"-inf.0"}if(this.__value__===Number.POSITIVE_INFINITY){return"+inf.0"}if(Number.isNaN(this.__value__)){return"+nan.0"}var e=this.__value__.toString();if(!e.match(/e/i)){var t=this.__value__.toString().replace(/^-/,"");var r=this.__value__<0?"-":"";if(e.match(/^-?0\.0{3}/)){var n=t.match(/^[.0]+/g)[0].length-1;var i=t.replace(/^[.0]+/,"").replace(/^([0-9])/,"$1.");return"".concat(r).concat(i,"e-").concat(n)}if(e.match(/^-?[0-9]{7,}\.?/)){var a=t.match(/^[0-9]+/g)[0].length-1;var u=t.replace(/\./,"").replace(/^([0-9])/,"$1.").replace(/0+$/,"").replace(/\.$/,".0");return"".concat(r).concat(u,"e").concat(a)}if(!j.isFloat(this.__value__)){var o=e+".0";return this._minus?"-"+o:o}}return e.replace(/^([0-9]+)e/,"$1.0e")};g.prototype._op=function(e,t){if(t instanceof j){t=t.__value__}var r=j._ops[e];if(e==="/"&&this.__value__===0&&t===0){return NaN}return g(r(this.__value__,t))};g.prototype.toRational=function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:null;if(e===null){return Ko(this.__value__.valueOf())}return Ho(e.valueOf())(this.__value__.valueOf())};g.prototype.sqrt=function(){var e=this.valueOf();if(this.cmp(0)<0){var t=g(Math.sqrt(-e));return m({re:0,im:t})}return g(Math.sqrt(e))};g.prototype.abs=function(){var e=this.valueOf();if(e<0){e=-e}return g(e)};var Ko=Ho(1e-10);function Ho(n){return function(e){var t=function e(n,t,r){var i=function e(t,r){return r0){i=Go(n,r)}else if(n.cmp(r)<=0){i=r}else if(r.cmp(0)>0){i=Go(r,n)}else if(t.cmp(0)<0){i=j(Go(n.sub(),r.sub())).sub()}else{i=j(0)}if(j.isFloat(t)||j.isFloat(e)){return g(i)}return i}function Go(e,t){var r=j(e).floor();var n=j(t).floor();if(e.cmp(r)<1){return r}else if(r.cmp(n)===0){var i=j(1).div(t.sub(n));var a=j(1).div(e.sub(r));return r.add(j(1).div(Go(i,a)))}else{return r.add(j(1))}}function E(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:false;if(typeof this!=="undefined"&&!(this instanceof E)||typeof this==="undefined"){return new E(e,t)}if(!j.isRational(e)){throw new Error("Invalid constructor call for LRational")}var r,n;if(e instanceof E){r=j(e.__num__);n=j(e.__denom__)}else{r=j(e.num);n=j(e.denom)}if(!t&&n.cmp(0)!==0){var i=r.op("%",n).cmp(0)===0;if(i){return j(r.div(n))}}this.constant(r,n)}E.prototype=Object.create(j.prototype);E.prototype.constructor=E;E.prototype.constant=function(e,t){Object.defineProperty(this,"__num__",{value:e,enumerable:true});Object.defineProperty(this,"__denom__",{value:t,enumerable:true});Object.defineProperty(this,"__type__",{value:"rational",enumerable:true})};E.prototype.serialize=function(){return{num:this.__num__,denom:this.__denom__}};E.prototype.pow=function(e){if(j.isRational(e)){return $o(this.valueOf(),e.valueOf())}var t=e.cmp(0);if(t===0){return j(1)}if(t===-1){e=e.sub();var r=this.__denom__.pow(e);var n=this.__num__.pow(e);return E({num:r,denom:n})}var i=this;e=e.valueOf();while(e>1){i=i.mul(this);e--}return i};E.prototype.sqrt=function(){var e=this.__num__.sqrt();var t=this.__denom__.sqrt();if(e instanceof g||t instanceof g){return e.div(t)}return E({num:e,denom:t})};E.prototype.abs=function(){var e=this.__num__;var t=this.__denom__;if(e.cmp(0)===-1){e=e.sub()}if(t.cmp(0)!==1){t=t.sub()}return E({num:e,denom:t})};E.prototype.cmp=function(e){return j(this.valueOf(),true).cmp(e)};E.prototype.toString=function(){var e=this.__num__.gcd(this.__denom__);var t,r;if(e.cmp(1)!==0){t=this.__num__.div(e);if(t instanceof E){t=j(t.valueOf(true))}r=this.__denom__.div(e);if(r instanceof E){r=j(r.valueOf(true))}}else{t=this.__num__;r=this.__denom__}var n=this.cmp(0)<0;if(n){if(t.abs().cmp(r.abs())===0){return t.toString()}}else if(t.cmp(r)===0){return t.toString()}return t.toString()+"/"+r.toString()};E.prototype.valueOf=function(e){if(this.__denom__.cmp(0)===0){if(this.__num__.cmp(0)<0){return Number.NEGATIVE_INFINITY}return Number.POSITIVE_INFINITY}if(e){return j._ops["/"](this.__num__.value,this.__denom__.value)}return g(this.__num__.valueOf()).div(this.__denom__.valueOf())};E.prototype.mul=function(e){if(!(e instanceof j)){e=j(e)}if(j.isRational(e)){var t=this.__num__.mul(e.__num__);var r=this.__denom__.mul(e.__denom__);return E({num:t,denom:r})}var n=j.coerce(this,e),i=b(n,2),a=i[0],u=i[1];return a.mul(u)};E.prototype.div=function(e){if(!(e instanceof j)){e=j(e)}if(j.isRational(e)){var t=this.__num__.mul(e.__denom__);var r=this.__denom__.mul(e.__num__);return E({num:t,denom:r})}var n=j.coerce(this,e),i=b(n,2),a=i[0],u=i[1];var o=a.div(u);return o};E.prototype._op=function(e,t){return this[Vo[e]](t)};E.prototype.sub=function(e){if(typeof e==="undefined"){return this.mul(-1)}if(!(e instanceof j)){e=j(e)}if(j.isRational(e)){var t=e.__num__.sub();var r=e.__denom__;return this.add(E({num:t,denom:r}))}if(!(e instanceof j)){e=j(e).sub()}else{e=e.sub()}var n=j.coerce(this,e),i=b(n,2),a=i[0],u=i[1];return a.add(u)};E.prototype.add=function(e){if(!(e instanceof j)){e=j(e)}if(j.isRational(e)){var t=this.__denom__;var r=e.__denom__;var n=this.__num__;var i=e.__num__;var a,u;if(t!==r){u=r.mul(n).add(i.mul(t));a=t.mul(r)}else{u=n.add(i);a=t}return E({num:u,denom:a})}if(j.isFloat(e)){return g(this.valueOf()).add(e)}var o=j.coerce(this,e),s=b(o,2),c=s[0],f=s[1];return c.add(f)};function x(e,t){if(typeof this!=="undefined"&&!(this instanceof x)||typeof this==="undefined"){return new x(e,t)}if(e instanceof x){return x(e.__value__,e._native)}if(!j.isBigInteger(e)){throw new Error("Invalid constructor call for LBigInteger")}this.constant(e,"bigint");Object.defineProperty(this,"_native",{value:t})}x.prototype=Object.create(j.prototype);x.prototype.constructor=x;x.bn_op={"+":"iadd","-":"isub","*":"imul","/":"idiv","%":"imod","|":"ior","&":"iand","~":"inot","<<":"ishrn",">>":"ishln"};x.prototype.serialize=function(){return this.__value__.toString()};x.prototype._op=function(e,t){if(typeof t==="undefined"){if(j.isBN(this.__value__)){e=x.bn_op[e];return x(this.__value__.clone()[e](),false)}return x(j._ops[e](this.__value__),true)}if(j.isBN(this.__value__)&&j.isBN(t.__value__)){e=x.bn_op[e];return x(this.__value__.clone()[e](t),false)}var r=j._ops[e](this.__value__,t.__value__);if(e==="/"){var n=this.op("%",t).cmp(0)===0;if(n){return j(r)}return E({num:this,denom:t})}return x(r,true)};x.prototype.sqrt=function(){var e;var t=this.cmp(0)<0;if(j.isNative(this.__value__)){e=j(Math.sqrt(t?-this.valueOf():this.valueOf()))}else if(j.isBN(this.__value__)){e=t?this.__value__.neg().sqrt():this.__value__.sqrt()}if(t){return m({re:0,im:e})}return e};j.NaN=j(NaN);m.i=m({im:1,re:0});function Qo(e){var n=this;if(typeof this!=="undefined"&&!(this instanceof Qo)||typeof this==="undefined"){return new Qo(e)}F("InputPort",e,"function");f(this,"__type__",cs);var i;Object.defineProperty(this,"__parser__",{enumerable:true,get:function e(){return i},set:function e(t){F("InputPort::__parser__",t,"parser");i=t}});this._read=e;this._with_parser=this._with_init_parser.bind(this,ie(C.mark(function e(){var r;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(n.char_ready()){t.next=5;break}t.next=3;return n._read();case 3:r=t.sent;i=new wa(r,{env:n});case 5:return t.abrupt("return",n.__parser__);case 6:case"end":return t.stop()}},e)})));this.char_ready=function(){return!!this.__parser__&&this.__parser__.__lexer__.peek()!==fs};this._make_defaults()}Qo.prototype._make_defaults=function(){this.read=this._with_parser(function(e){return e.read_object()});this.read_line=this._with_parser(function(e){return e.__lexer__.read_line()});this.read_char=this._with_parser(function(e){return e.__lexer__.read_char()});this.read_string=this._with_parser(function(e,t){if(!j.isInteger(t)){var r=j.getType(t);Rs("read-string",r,"integer")}return e.__lexer__.read_string(t.valueOf())});this.peek_char=this._with_parser(function(e){return e.__lexer__.peek_char()})};Qo.prototype._with_init_parser=function(o,s){var c=this;return ie(C.mark(function e(){var r,n,i,a,u=arguments;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:t.next=2;return o.call(c);case 2:r=t.sent;for(n=u.length,i=new Array(n),a=0;a"};function Zo(e){if(typeof this!=="undefined"&&!(this instanceof Zo)||typeof this==="undefined"){return new Zo(e)}F("OutputPort",e,"function");f(this,"__type__",cs);this.write=e}Zo.prototype.is_open=function(){return this._closed!==true};Zo.prototype.close=function(){Object.defineProperty(this,"_closed",{get:function e(){return true},set:function e(){},configurable:false,enumerable:false});this.write=function(){throw new Error("output-port: port is closed")}};Zo.prototype.flush=function(){};Zo.prototype.toString=function(){return"#"};var Xo=function(e){G(r,e);function r(e){var t;ae(this,r);t=Kn(this,r,[function(){var e;return(e=t)._write.apply(e,arguments)}]);F("BufferedOutputPort",e,"function");f(H(t),"_fn",e,{hidden:true});f(H(t),"_buffer",[],{hidden:true});return t}ce(r,[{key:"flush",value:function e(){if(this._buffer.length){this._fn(this._buffer.join(""));this._buffer.length=0}}},{key:"_write",value:function e(){var t=this;for(var r=arguments.length,n=new Array(r),i=0;i"};es.prototype.valueOf=function(){return this.__buffer__.map(function(e){return e.valueOf()}).join("")};function ts(e,t){var r=this;if(typeof this!=="undefined"&&!(this instanceof ts)||typeof this==="undefined"){return new ts(e,t)}F("OutputFilePort",e,"string");f(this,"__filename__",e);f(this,"_fd",t.valueOf(),{hidden:true});f(this,"__type__",cs);this.write=function(e){if(!D.isString(e)){e=vu(e)}else{e=e.valueOf()}r.fs().write(r._fd,e,function(e){if(e){throw e}})}}ts.prototype=Object.create(Zo.prototype);ts.prototype.constructor=ts;ts.prototype.fs=function(){if(!this._fs){this._fs=this.internal("fs")}return this._fs};ts.prototype.internal=function(e){return As.get("**internal-env**").get(e)};ts.prototype.close=function(){var n=this;return new Promise(function(t,r){n.fs().close(n._fd,function(e){if(e){r(e)}else{f(n,"_fd",null,{hidden:true});Zo.prototype.close.call(n);t()}})})};ts.prototype.toString=function(){return"#")};function rs(e,t){var r=this;if(typeof this!=="undefined"&&!(this instanceof rs)||typeof this==="undefined"){return new rs(e)}F("InputStringPort",e,"string");t=t||K;e=e.valueOf();this._with_parser=this._with_init_parser.bind(this,function(){if(!r.__parser__){r.__parser__=new wa(e,{env:t})}return r.__parser__});f(this,"__type__",cs);this._make_defaults()}rs.prototype.char_ready=function(){return true};rs.prototype=Object.create(Qo.prototype);rs.prototype.constructor=rs;rs.prototype.toString=function(){return"#"};function ns(e){if(typeof this!=="undefined"&&!(this instanceof ns)||typeof this==="undefined"){return new ns(e)}F("InputByteVectorPort",e,"uint8array");f(this,"__vector__",e);f(this,"__type__",ss);var r=0;Object.defineProperty(this,"__index__",{enumerable:true,get:function e(){return r},set:function e(t){F("InputByteVectorPort::__index__",t,"number");if(t instanceof j){t=t.valueOf()}if(typeof t==="bigint"){t=Number(t)}if(Math.floor(t)!==t){throw new Error("InputByteVectorPort::__index__ value is "+"not integer")}r=t}})}ns.prototype=Object.create(Qo.prototype);ns.prototype.constructor=ns;ns.prototype.toString=function(){return"#"};ns.prototype.close=function(){var t=this;f(this,"__vector__",V);var r=function e(){throw new Error("Input-binary-port: port is closed")};["read_u8","close","peek_u8","read_u8_vector"].forEach(function(e){t[e]=r});this.u8_ready=this.char_ready=function(){return false}};ns.prototype.u8_ready=function(){return true};ns.prototype.peek_u8=function(){if(this.__index__>=this.__vector__.length){return fs}return this.__vector__[this.__index__]};ns.prototype.skip=function(){if(this.__index__<=this.__vector__.length){++this.__index__}};ns.prototype.read_u8=function(){var e=this.peek_u8();this.skip();return e};ns.prototype.read_u8_vector=function(e){if(typeof e==="undefined"){e=this.__vector__.length}else if(e>this.__index__+this.__vector__.length){e=this.__index__+this.__vector__.length}if(this.peek_u8()===fs){return fs}return this.__vector__.slice(this.__index__,e)};function is(){if(typeof this!=="undefined"&&!(this instanceof is)||typeof this==="undefined"){return new is}f(this,"__type__",ss);f(this,"_buffer",[],{hidden:true});this.write=function(e){F("write",e,["number","uint8array"]);if(j.isNumber(e)){this._buffer.push(e.valueOf())}else{var t;(t=this._buffer).push.apply(t,U(Array.from(e)))}};Object.defineProperty(this,"__buffer__",{enumerable:true,get:function e(){return Uint8Array.from(this._buffer)}})}is.prototype=Object.create(Zo.prototype);is.prototype.constructor=is;is.prototype.close=function(){Zo.prototype.close.call(this);f(this,"_buffer",null,{hidden:true})};is.prototype._close_guard=function(){if(this._closed){throw new Error("output-port: binary port is closed")}};is.prototype.write_u8=function(e){F("OutputByteVectorPort::write_u8",e,"number");this.write(e)};is.prototype.write_u8_vector=function(e){F("OutputByteVectorPort::write_u8_vector",e,"uint8array");this.write(e)};is.prototype.toString=function(){return"#"};is.prototype.valueOf=function(){return this.__buffer__};function as(e,t){if(typeof this!=="undefined"&&!(this instanceof as)||typeof this==="undefined"){return new as(e,t)}rs.call(this,e);F("InputFilePort",t,"string");f(this,"__filename__",t)}as.prototype=Object.create(rs.prototype);as.prototype.constructor=as;as.prototype.toString=function(){return"#")};function us(e,t){if(typeof this!=="undefined"&&!(this instanceof us)||typeof this==="undefined"){return new us(e,t)}ns.call(this,e);F("InputBinaryFilePort",t,"string");f(this,"__filename__",t)}us.prototype=Object.create(ns.prototype);us.prototype.constructor=us;us.prototype.toString=function(){return"#")};function os(e,t){var i=this;if(typeof this!=="undefined"&&!(this instanceof os)||typeof this==="undefined"){return new os(e,t)}F("OutputBinaryFilePort",e,"string");f(this,"__filename__",e);f(this,"_fd",t.valueOf(),{hidden:true});f(this,"__type__",ss);var a;this.write=function(e){F("write",e,["number","uint8array"]);var n;if(!a){a=i.internal("fs")}if(j.isNumber(e)){n=new Uint8Array([e.valueOf()])}else{n=new Uint8Array(Array.from(e))}return new Promise(function(t,r){a.write(i._fd,n,function(e){if(e){r(e)}else{t()}})})}}os.prototype=Object.create(ts.prototype);os.prototype.constructor=os;os.prototype.write_u8=function(e){F("OutputByteVectorPort::write_u8",e,"number");this.write(e)};os.prototype.write_u8_vector=function(e){F("OutputByteVectorPort::write_u8_vector",e,"uint8array");this.write(e)};var ss=Symbol["for"]("binary");var cs=Symbol["for"]("text");var fs=new ls;function ls(){}ls.prototype.toString=function(){return"#"};function hs(e){var t=this;var r=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},n=r.stderr,i=r.stdin,a=r.stdout,u=r.command_line,o=u===void 0?null:u,s=he(r,qn);if(typeof this!=="undefined"&&!(this instanceof hs)||typeof this==="undefined"){return new hs(e,q({stdin:i,stdout:a,stderr:n,command_line:o},s))}if(typeof e==="undefined"){e="anonymous"}this.__env__=As.inherit(e,s);this.__env__.set("parent.frame",l("parent.frame",function(){return t.__env__},K.__env__["parent.frame"].__doc__));var c="**interaction-environment-defaults**";this.set(c,lu(s).concat(c));var f=Ds.inherit("internal-".concat(e));if(no(i)){f.set("stdin",i)}if(no(n)){f.set("stderr",n)}if(no(a)){f.set("stdout",a)}f.set("command-line",o);Fs(this.__env__,f)}hs.prototype.exec=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};var r=t.use_dynamic,n=r===void 0?false:r,i=t.dynamic_env,a=t.env;F("Interpreter::exec",e,["string","array"],1);F("Interpreter::exec",n,"boolean",2);if(!a){a=this.__env__}if(!i){i=a}K.set("**interaction-environment**",this.__env__);return rc(e,{env:a,dynamic_env:i,use_dynamic:n})};hs.prototype.get=function(e){var t=this.__env__.get(e);if(d(t)){var r=new Zs({env:this.__env__});return t.bind(r)}return t};hs.prototype.set=function(e,t){return this.__env__.set(e,t)};hs.prototype.constant=function(e,t){return this.__env__.constant(e,t)};function ps(e,t){this.name="LipsError";this.message=e;this.args=t;this.stack=(new Error).stack}ps.prototype=new Error;ps.prototype.constructor=ps;var _s=function(e){G(t,e);function t(){ae(this,t);return Kn(this,t,arguments)}return ce(t)}(M(Error));function A(e,t,r){if(arguments.length===1){if(p(arguments[0])==="object"){e=arguments[0];t=null}else if(typeof arguments[0]==="string"){e={};t=null;r=arguments[0]}}this.__docs__=new Map;this.__env__=e;this.__parent__=t;this.__name__=r||"anonymous"}A.prototype.list=function(){return lu(this.__env__)};A.prototype.fs=function(){return this.get("**fs**")};A.prototype.unset=function(e){if(e instanceof Y){e=e.valueOf()}if(e instanceof D){e=e.valueOf()}delete this.__env__[e]};A.prototype.inherit=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};if(p(e)==="object"){t=e}if(!e||p(e)==="object"){e="child of "+(this.__name__||"unknown")}return new A(t||{},this,e)};A.prototype.doc=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:null;var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:false;if(e instanceof Y){e=e.__name__}if(e instanceof D){e=e.valueOf()}if(t){if(!r){t=Sa(t)}this.__docs__.set(e,t);return this}if(this.__docs__.has(e)){return this.__docs__.get(e)}if(this.__parent__){return this.__parent__.doc(e)}};A.prototype.new_frame=function(e,t){var n=this.inherit("__frame__");n.set("parent.frame",l("parent.frame",function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:1;e=e.valueOf();var t=n.__parent__;if(!Lu(t)){return V}if(e<=0){return t}var r=t.get("parent.frame");return r(e-1)},K.__env__["parent.frame"].__doc__));t.callee=e;n.set("arguments",t);return n};A.prototype._lookup=function(e){if(e instanceof Y){e=e.__name__}if(e instanceof D){e=e.valueOf()}if(this.__env__.hasOwnProperty(e)){return ds(this.__env__[e])}if(this.__parent__){return this.__parent__._lookup(e)}};A.prototype.toString=function(){return"#"};A.prototype.clone=function(){var t=this;var r={};Object.keys(this.__env__).forEach(function(e){r[e]=t.__env__[e]});return new A(r,this.__parent__,this.__name__)};A.prototype.merge=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:"merge";F("Environment::merge",e,"environment");return this.inherit(t,e.__env__)};function ds(e){if(typeof this!=="undefined"&&!(this instanceof ds)||typeof this==="undefined"){return new ds(e)}this.value=e}ds.isUndefined=function(e){return e instanceof ds&&typeof e.value==="undefined"};ds.prototype.valueOf=function(){return this.value};function vs(e){if(e.length){if(e.length===1){return e[0]}}if(typeof this!=="undefined"&&!(this instanceof vs)||typeof this==="undefined"){return new vs(e)}this.__values__=e}vs.prototype.toString=function(){return this.__values__.map(function(e){return vu(e)}).join("\n")};vs.prototype.valueOf=function(){return this.__values__};A.prototype.get=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};F("Environment::get",e,["symbol","string"]);var r=t.throwError,n=r===void 0?true:r;var i=e;if(i instanceof Y||i instanceof D){i=i.valueOf()}var a=this._lookup(i);if(a instanceof ds){if(ds.isUndefined(a)){return undefined}return Qu(a.valueOf())}var u;if(e instanceof Y&&e[Y.object]){u=e[Y.object]}else if(typeof i==="string"){u=i.split(".").filter(Boolean)}if(u&&u.length>0){var o=u,s=re(o),c=s[0],f=s.slice(1);a=this._lookup(c);if(f.length){try{if(a instanceof ds){a=a.valueOf()}else{a=gs(ti,c);if(d(a)){a=Zu(a)}}if(typeof a!=="undefined"){return gs.apply(void 0,[a].concat(U(f)))}}catch(e){throw e}}else if(a instanceof ds){return Qu(a.valueOf())}a=gs(ti,i)}if(typeof a!=="undefined"){return a}if(n){throw new Error("Unbound variable `"+i.toString()+"'")}};A.prototype.set=function(e,t){var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:null;F("Environment::set",e,["string","symbol"]);if(j.isNumber(t)){t=j(t)}if(e instanceof Y){e=e.__name__}if(e instanceof D){e=e.valueOf()}this.__env__[e]=t;if(r){this.doc(e,r,true)}return this};A.prototype.constant=function(t,e){var r=this;if(this.__env__.hasOwnProperty(t)){throw new Error("Environment::constant: ".concat(t," already exists"))}if(arguments.length===1&&nu(arguments[0])){var n=arguments[0];Object.keys(n).forEach(function(e){r.constant(t,n[e])})}else{Object.defineProperty(this.__env__,t,{value:e,enumerable:true})}return this};A.prototype.has=function(e){return this.__env__.hasOwnProperty(e)};A.prototype.ref=function(e){var t=this;while(true){if(!t){break}if(t.has(e)){return t}t=t.__parent__}};A.prototype.parents=function(){var e=this;var t=[];while(e){t.unshift(e);e=e.__parent__}return t};function ys(e){if(qu(e)){return e.then(ys)}if(e instanceof $||e instanceof Y){e[oo]=true}return e}var ms=Ea(na('(lambda ()\n "[native code]"\n (throw "Invalid Invocation"))'))[0];var gs=l("get",function e(t){var r;for(var n=arguments.length,i=new Array(n>1?n-1:0),a=1;a0&&arguments[0]!==undefined?arguments[0]:null;if(e===null){e=bs(this,"stdin")}Us("peek-char",e,"input-port");return e.peek_char()},"(peek-char port)\n\n This function reads and returns a character from the string\n port, or, if there is no more data in the string port, it\n returns an EOF."),"read-line":l("read-line",function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:null;if(e===null){e=bs(this,"stdin")}Us("read-line",e,"input-port");return e.read_line()},"(read-line port)\n\n This function reads and returns the next line from the input\n port."),"read-char":l("read-char",function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:null;if(e===null){e=bs(this,"stdin")}Us("read-char",e,"input-port");return e.read_char()},"(read-char port)\n\n This function reads and returns the next character from the\n input port."),read:l("read",function(){var e=ie(function(){var f=this;var l=arguments.length>0&&arguments[0]!==undefined?arguments[0]:null;return C.mark(function e(){var r,n,i,a,u,o,s,c;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:r=f.env;if(!D.isString(l)){t.next=30;break}n=false;i=false;t.prev=4;u=Xn(Ea(l,r));case 6:t.next=8;return u.next();case 8:if(!(n=!(o=t.sent).done)){t.next=14;break}s=o.value;return t.abrupt("return",s);case 11:n=false;t.next=6;break;case 14:t.next=20;break;case 16:t.prev=16;t.t0=t["catch"](4);i=true;a=t.t0;case 20:t.prev=20;t.prev=21;if(!(n&&u["return"]!=null)){t.next=25;break}t.next=25;return u["return"]();case 25:t.prev=25;if(!i){t.next=28;break}throw a;case 28:return t.finish(25);case 29:return t.finish(20);case 30:if(l===null){c=bs(r,"stdin")}else{c=l}Us("read",c,"input-port");return t.abrupt("return",c.read.call(r));case 33:case"end":return t.stop()}},e,null,[[4,16,20,30],[21,,25,29]])})()});function t(){return e.apply(this,arguments)}return t}(),"(read [string])\n\n This function, if used with a string, will parse it and\n return the LIPS code, if there is any. If called with a\n port, it will parse the next item from the port. If called\n without an input, it will read a string from standard input\n (using the browser's prompt or a user defined input method)\n and calls itself with that string. This function can be used\n together with `eval` to evaluate code from a string."),pprint:l("pprint",function e(t){if(t instanceof $){t=new Lc.Formatter(t.toString(true))["break"]().format();K.get("display").call(K,t)}else{K.get("write").call(K,t)}K.get("newline").call(K)},"(pprint expression)\n\n This function will pretty print its input to stdout. If it is called\n with a non-list, it will just call the print function on its\n input."),print:l("print",function e(){var t=K.get("display");var r=K.get("newline");var n=this.use_dynamic;var i=K;var a=K;for(var u=arguments.length,o=new Array(u),s=0;s1?r-1:0),i=1;in.length){throw new Error("Not enough arguments")}var o=0;var s=K.get("repr");t=t.replace(a,function(e){var t=e[1];if(t==="~"){return"~"}else if(t==="%"){return"\n"}else{var r=n[o++];if(t==="a"){return s(r)}else{return s(r,true)}}});u=t.match(/~([\S])/);if(u){throw new Error("format: Unrecognized escape sequence ".concat(u[1]))}return t},"(format string n1 n2 ...)\n\n This function accepts a string template and replaces any\n escape sequences in its inputs:\n\n * ~a value as if printed with `display`\n * ~s value as if printed with `write`\n * ~% newline character\n * ~~ literal tilde '~'\n\n If there are missing inputs or other escape characters it\n will error."),display:l("display",function e(t){var r=arguments.length>1&&arguments[1]!==undefined?arguments[1]:null;if(r===null){r=bs(this,"stdout")}else{F("display",r,"output-port")}var n=t;if(!(r instanceof os)){n=K.get("repr")(t)}r.write.call(K,n)},"(display string [port])\n\n This function outputs the string to the standard output or\n the port if given. No newline."),"display-error":l("display-error",function e(){var t=bs(this,"stderr");var r=K.get("repr");for(var n=arguments.length,i=new Array(n),a=0;a1&&arguments[1]!==undefined?arguments[1]:{},r=t.use_dynamic,n=he(t,zn);var i=this;var u=this;var o;var s=q(q({},n),{},{env:this,dynamic_env:i,use_dynamic:r});var c=k(e.cdr.car,s);c=Ys(c);function f(t,r,n){if(qu(t)){return t.then(function(e){return f(t,e,n)})}if(qu(r)){return r.then(function(e){return f(t,e,n)})}if(qu(n)){return n.then(function(e){return f(t,r,e)})}u.get("set-obj!").call(u,t,r,n);return n}if(e.car instanceof $&&Y.is(e.car.car,".")){var l=e.car.cdr.car;var h=e.car.cdr.cdr.car;var p=k(l,s);var _=k(h,s);return f(p,_,c)}if(!(e.car instanceof Y)){throw new Error("set! first argument need to be a symbol or "+"dot accessor that evaluate to object.")}var d=e.car.valueOf();o=this.ref(e.car.__name__);return w(c,function(e){if(!o){var t=d.split(".");if(t.length>1){var r=t.pop();var n=t.join(".");var i=a.get(n,{throwError:false});if(i){f(i,r,e);return}}throw new Error("Unbound variable `"+d+"'")}o.set(d,e)})}),"(set! name value)\n\n Macro that can be used to set the value of the variable or slot (mutate it).\n set! searches the scope chain until it finds first non empty slot and sets it."),"unset!":l(new J("set!",function(e){if(!(e.car instanceof Y)){throw new Error("unset! first argument need to be a symbol or "+"dot accessor that evaluate to object.")}var t=e.car;var r=this.ref(t);if(r){delete r.__env__[t.__name__]}}),"(unset! name)\n\n Function to delete the specified name from environment.\n Trying to access the name afterwards will error."),"set-car!":l("set-car!",function(e,t){F("set-car!",e,"pair");e.car=t},"(set-car! obj value)\n\n Function that sets the car (first item) of the list/pair to specified value.\n The old value is lost."),"set-cdr!":l("set-cdr!",function(e,t){F("set-cdr!",e,"pair");e.cdr=t},"(set-cdr! obj value)\n\n Function that sets the cdr (tail) of the list/pair to specified value.\n It will destroy the list. The old tail is lost."),"empty?":l("empty?",function(e){return typeof e==="undefined"||e===V},"(empty? object)\n\n Function that returns #t if value is nil (an empty list) or undefined."),gensym:l("gensym",sa,"(gensym)\n\n Generates a unique symbol that is not bound anywhere,\n to use with macros as meta name."),load:l("load",function e(o,t){F("load",o,"string");var s=this;if(s.__name__==="__frame__"){s=s.__parent__}if(!(t instanceof A)){if(s===K){t=s}else{t=this.get("**interaction-environment**")}}var c="**module-path**";var f=K.get(c,{throwError:false});o=o.valueOf();if(!o.match(/.[^.]+$/)){o+=".scm"}var r=o.match(/\.xcb$/);function l(e){if(r){e=Sc(e)}else{if(zs(e)==="buffer"){e=e.toString()}e=e.replace(/^#!.*/,"");if(e.match(/^\{/)){e=Ec(e)}}return rc(e,{env:t})}function n(e){return ti.fetch(e).then(function(e){return r?e.arrayBuffer():e.text()}).then(function(e){if(r){e=new Uint8Array(e)}return e})}if(js()){return new Promise(function(){var r=ie(C.mark(function e(r,n){var i,a,u;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:i=ui("path");if(!f){t.next=6;break}f=f.valueOf();o=i.join(f,o);t.next=12;break;case 6:a=s.get("command-line",{throwError:false});if(!a){t.next=11;break}t.next=10;return a();case 10:u=t.sent;case 11:if(u&&u!==V){process.cwd();o=i.join(i.dirname(u.car.valueOf()),o)}case 12:K.set(c,i.dirname(o));ui("fs").readFile(o,function(e,t){if(e){n(e);K.set(c,f)}else{try{l(t).then(function(){r();K.set(c,f)})["catch"](n)}catch(e){n(e)}}});case 14:case"end":return t.stop()}},e)}));return function(e,t){return r.apply(this,arguments)}}())}if(f){f=f.valueOf();o=f+"/"+o.replace(/^\.?\/?/,"")}return n(o).then(function(e){K.set(c,o.replace(/\/[^/]*$/,""));return l(e)}).then(function(){})["finally"](function(){K.set(c,f)})},"(load filename)\n (load filename environment)\n\n Fetches the file (from disk or network) and evaluates its content as LIPS code.\n If the second argument is provided and it's an environment the evaluation\n will happen in that environment."),while:l(new J("while",function(e,t){var r=e.car;var n=q(q({},t),{},{env:this});var i=new $(new Y("begin"),e.cdr);return function t(){return w(k(r,n),function(e){if(e){return w(k(i,n),t)}})}()}),"(while cond body)\n\n Creates a loop, it executes cond and body until cond expression is false."),do:l(new J("do",function(){var r=ie(function(h,e){var p=this;var _=e.use_dynamic,d=e.error;return C.mark(function e(){var r,n,o,s,i,c,f,a,u,l;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:r=p;n=r;o=r.inherit("do");s=h.car;i=h.cdr.car;c=h.cdr.cdr;if(c!==V){c=new $(Y("begin"),c)}f={env:r,dynamic_env:n,use_dynamic:_,error:d};a=s;case 9:if(!(a!==V)){t.next=20;break}u=a.car;t.t0=o;t.t1=u.car;t.next=15;return k(u.cdr.car,f);case 15:t.t2=t.sent;t.t0.set.call(t.t0,t.t1,t.t2);a=a.cdr;t.next=9;break;case 20:f={env:o,dynamic_env:n,error:d};l=C.mark(function e(){var r,n,i,a,u;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(!(c!==V)){t.next=3;break}t.next=3;return Lc.evaluate(c,f);case 3:r=s;n={};case 5:if(!(r!==V)){t.next=15;break}i=r.car;if(!(i.cdr.cdr!==V)){t.next=12;break}t.next=10;return k(i.cdr.cdr.car,f);case 10:a=t.sent;n[i.car.valueOf()]=a;case 12:r=r.cdr;t.next=5;break;case 15:u=Object.getOwnPropertySymbols(n);Object.keys(n).concat(u).forEach(function(e){o.set(e,n[e])});case 17:case"end":return t.stop()}},e)});case 22:t.next=24;return k(i.car,f);case 24:t.t3=t.sent;if(!(t.t3===false)){t.next=29;break}return t.delegateYield(l(),"t4",27);case 27:t.next=22;break;case 29:if(!(i.cdr!==V)){t.next=33;break}t.next=32;return k(i.cdr.car,f);case 32:return t.abrupt("return",t.sent);case 33:case"end":return t.stop()}},e)})()});return function(e,t){return r.apply(this,arguments)}}()),"(do (( )) (test return) . body)\n\n Iteration macro that evaluates the expression body in scope of the variables.\n On each loop it changes the variables according to the expression and runs\n test to check if the loop should continue. If test is a single value, the macro\n will return undefined. If the test is a pair of expressions the macro will\n evaluate and return the second expression after the loop exits."),if:l(new J("if",function(r,e){var t=e.error,n=e.use_dynamic;var i=this;var a=this;var u={env:a,dynamic_env:i,use_dynamic:n,error:t};var o=function e(t){if(t===false){return k(r.cdr.cdr.car,u)}else{return k(r.cdr.car,u)}};if(r===V){throw new Error("too few expressions for `if`")}var s=k(r.car,u);return w(s,o)}),"(if cond true-expr false-expr)\n\n Macro that evaluates cond expression and if the value is true, it\n evaluates and returns true-expression, if not it evaluates and returns\n false-expression."),"let-env":new J("let-env",function(t){var e=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};var r=e.dynamic_env,n=e.use_dynamic,i=e.error;F("let-env",t,"pair");var a=k(t.car,{env:this,dynamic_env:r,error:i,use_dynamic:n});return w(a,function(e){F("let-env",e,"environment");return k($(Y("begin"),t.cdr),{env:e,dynamic_env:r,error:i})})},"(let-env env . body)\n\n Special macro that evaluates body in context of given environment\n object."),letrec:l(Eo(Symbol["for"]("letrec")),"(letrec ((a value-a) (b value-b) ...) . body)\n\n Macro that creates a new environment, then evaluates and assigns values to\n names and then evaluates the body in context of that environment.\n Values are evaluated sequentially and the next value can access the\n previous values/names."),"letrec*":l(Eo(Symbol["for"]("letrec")),"(letrec* ((a value-a) (b value-b) ...) . body)\n\n Same as letrec but the order of execution of the binding is guaranteed,\n so you can use recursive code as well as referencing the previous binding.\n\n In LIPS both letrec and letrec* behave the same."),"let*":l(Eo(Symbol["for"]("let*")),"(let* ((a value-a) (b value-b) ...) . body)\n\n Macro similar to `let`, but the subsequent bindings after the first\n are evaluated in the environment including the previous let variables,\n so you can define one variable, and use it in the next's definition."),let:l(Eo(Symbol["for"]("let")),"(let ((a value-a) (b value-b) ...) . body)\n\n Macro that creates a new environment, then evaluates and assigns values to names,\n and then evaluates the body in context of that environment. Values are evaluated\n sequentially but you can't access previous values/names when the next are\n evaluated. You can only get them in the body of the let expression. (If you want\n to define multiple variables and use them in each other's definitions, use\n `let*`.)"),"begin*":l(xo("begin*",function(e){return e.pop()}),"(begin* . body)\n\n This macro is a parallel version of begin. It evaluates each expression\n in the body and if it's a promise it will await it in parallel and return\n the value of the last expression (i.e. it uses Promise.all())."),shuffle:l("shuffle",function(e){F("shuffle",e,["pair","nil","array"]);var t=K.get("random");if(e===V){return V}if(Array.isArray(e)){return Xa(e.slice(),t)}var r=K.get("list->array")(e);r=Xa(r,t);return K.get("array->list")(r)},"(shuffle obj)\n\n Order items in vector or list in random order."),begin:l(new J("begin",function(e,t){var n=q(q({},t),{},{env:this});var i=K.get("list->array")(e);var a;return function t(){if(i.length){var e=i.shift();var r=k(e,n);return w(r,function(e){a=e;return t()})}else{return a}}()}),"(begin . args)\n\n Macro that runs a list of expressions in order and returns the value\n of the last one. It can be used in places where you can only have a\n single expression, like (if)."),ignore:new J("ignore",function(e,t){var r=q(q({},t),{},{env:this,dynamic_env:this});k(new $(new Y("begin"),e),r)},"(ignore . body)\n\n Macro that will evaluate the expression and swallow any promises that may\n be created. It will discard any value that may be returned by the last body\n expression. The code should have side effects and/or when it's promise\n it should resolve to undefined."),"call/cc":l(J.defmacro("call/cc",function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};var r=q({env:this},t);return w(k(e.car,r),function(e){if(d(e)){return e(new ec(null))}})}),"(call/cc proc)\n\n Call-with-current-continuation.\n\n NOT SUPPORTED BY LIPS RIGHT NOW"),parameterize:l(new J("parameterize",function(t,e){var i=e.dynamic_env;var a=i.inherit("parameterize").new_frame(null,{});var u=q(q({},e),{},{env:this});var o=t.car;if(!Tu(o)){var r=zs(o);throw new Error("Invalid syntax for parameterize expecting pair got ".concat(r))}function s(){var e=new $(new Y("begin"),t.cdr);return k(e,q(q({},u),{},{dynamic_env:a}))}return function r(){var e=o.car;var n=e.car.valueOf();return w(k(e.cdr.car,u),function(e){var t=i.get(n,{throwError:false});if(!Ru(t)){throw new Error("Unknown parameter ".concat(n))}a.set(n,t.inherit(e));if(!Iu(o.cdr)){o=o.cdr;return r()}else{return s()}})}()}),"(parameterize ((name value) ...)\n\n Macro that change the dynamic variable created by make-parameter."),"make-parameter":l(new J("make-parameter",function(e,t){t.dynamic_env;var r=k(e.car,t);var n;if(e.cdr.car instanceof $){n=k(e.cdr.car,t)}return new Qs(r,n)}),"(make-parameter init converter)\n\n Function creates new dynamic variable that can be custimized with parameterize\n macro. The value should be assigned to a variable e.g.:\n\n (define radix (make-parameter 10))\n\n The result value is a procedure that return the value of dynamic variable."),"define-syntax-parameter":l(new J("define-syntax-parameter",function(e,t){var r=e.car;var n=this;if(!(r instanceof Y)){throw new Error("define-syntax-parameter: invalid syntax expecting symbol got ".concat(zs(r)))}var i=k(e.cdr.car,q({env:n},t));F("define-syntax-parameter",i,"syntax",2);i.__name__=r.valueOf();if(i.__name__ instanceof D){i.__name__=i.__name__.valueOf()}var a;if(e.cdr.cdr instanceof $&&D.isString(e.cdr.cdr.car)){a=e.cdr.cdr.car.valueOf()}n.set(e.car,new Ou(i),a,true)}),"(define-syntax-parameter name syntax [__doc__])\n\n Binds to the transformer obtained by evaluating .\n The transformer provides the default expansion for the syntax parameter,\n and in the absence of syntax-parameterize, is functionally equivalent to\n define-syntax."),"syntax-parameterize":l(new J("syntax-parameterize",function(e,t){var r=K.get("list->array")(e.car);var n=this.inherit("syntax-parameterize");while(r.length){var i=r.shift();if(!(Tu(i)||i.car instanceof Y)){var a="invalid syntax for syntax-parameterize: ".concat(ru(e,true));throw new Error("syntax-parameterize: ".concat(a))}var u=k(i.cdr.car,q(q({},t),{},{env:this}));var o=i.car;F("syntax-parameterize",u,["syntax"]);F("syntax-parameterize",o,"symbol");u.__name__=o.valueOf();if(u.__name__ instanceof D){u.__name__=u.__name__.valueOf()}var s=new Ou(u);if(o.is_gensym()){var c=o.literal();var f=this.get(c,{throwError:false});if(f instanceof Ou){n.set(c,s)}}n.set(o,s)}var l=new $(new Y("begin"),e.cdr);return k(l,q(q({},t),{},{env:n}))}),"(syntax-parameterize (bindings) body)\n\n Macro work similar to let-syntax but the the bindnds will be exposed to the user.\n With syntax-parameterize you can define anaphoric macros."),define:l(J.defmacro("define",function(r,e){var n=this;if(r.car instanceof $&&r.car.car instanceof Y){var t=new $(new Y("define"),new $(r.car.car,new $(new $(new Y("lambda"),new $(r.car.cdr,r.cdr)))));return t}else if(e.macro_expand){return}e.dynamic_env=this;e.env=n;var i=r.cdr.car;var a;if(i instanceof $){i=k(i,e);a=true}else if(i instanceof Y){i=n.get(i)}F("define",r.car,"symbol");return w(i,function(e){if(n.__name__===Cu.__merge_env__){n=n.__parent__}if(a&&(d(e)&&go(e)||e instanceof Cu||Ru(e))){e.__name__=r.car.valueOf();if(e.__name__ instanceof D){e.__name__=e.__name__.valueOf()}}var t;if(r.cdr.cdr instanceof $&&D.isString(r.cdr.cdr.car)){t=r.cdr.cdr.car.valueOf()}n.set(r.car,e,t,true)})}),'(define name expression)\n (define name expression "doc string")\n (define (function-name . args) . body)\n\n Macro for defining values. It can be used to define variables,\n or functions. If the first argument is list it will create a function\n with name being first element of the list. This form expands to\n `(define function-name (lambda args body))`'),"set-obj!":l("set-obj!",function(e,t,r){var n=arguments.length>3&&arguments[3]!==undefined?arguments[3]:null;var i=p(e);if(Iu(e)||i!=="object"&&i!=="function"){var a=Rs("set-obj!",zs(e),["object","function"]);throw new Error(a)}F("set-obj!",t,["string","symbol","number"]);e=Zu(e);t=t.valueOf();if(arguments.length===2){delete e[t]}else if(yu(e)&&d(r)){e[t]=Zu(r);e[t][ho]=true}else if(d(r)||Ju(r)||r===V){e[t]=r}else{e[t]=r&&!yu(r)?r.valueOf():r}if(iu){var u=e[t];Object.defineProperty(e,t,q(q({},n),{},{value:u}))}},"(set-obj! obj key value)\n (set-obj! obj key value props)\n\n Function set a property of a JavaScript object. props should be a vector of pairs,\n passed to Object.defineProperty."),"null-environment":l("null-environment",function(){return K.inherit("null")},"(null-environment)\n\n Returns a clean environment with only the standard library."),values:l("values",function e(){for(var t=arguments.length,r=new Array(t),n=0;n1&&arguments[1]!==undefined?arguments[1]:{},y=e.use_dynamic,m=e.error;var g=this;var b;if(v.cdr instanceof $&&D.isString(v.cdr.car)&&v.cdr.cdr!==V){b=v.cdr.car.valueOf()}function w(){var e=Nu(this)?this:{dynamic_env:g},r=e.dynamic_env;var n=g.inherit("lambda");r=r.inherit("lambda");if(this&&!Nu(this)){if(this&&!this.__instance__){Object.defineProperty(this,"__instance__",{enumerable:false,get:function e(){return true},set:function e(){},configurable:false})}n.set("this",this)}for(var t=arguments.length,i=new Array(t),a=0;a> SYNTAX");z(e);z(m);var n=w.inherit("syntax");var i=n;var a=this;if(a.__name__===Cu.__merge_env__){var u=Object.getOwnPropertySymbols(a.__env__);u.forEach(function(e){a.__parent__.set(e,a.__env__[e])});a=a.__parent__}var o={env:n,dynamic_env:i,use_dynamic:g,error:b};var s,c,f;if(m.car instanceof Y){s=m.car;f=D(m.cdr.car);c=m.cdr.cdr}else{s="...";f=D(m.car);c=m.cdr}try{while(c!==V){var l=c.car.car;var h=c.car.cdr.car;z("[[[ RULE");z(l);var p=Su(l,e,f,s,{expansion:this,define:w});if(p){if(ci()){console.log(JSON.stringify(fu(p),true,2));console.log("PATTERN: "+l.toString(true));console.log("MACRO: "+e.toString(true))}var _=[];var d=ju({bindings:p,expr:h,symbols:f,scope:n,lex_scope:a,names:_,ellipsis:s});z("OUPUT>>> ",d);if(d){h=d}var v=a.merge(n,Cu.__merge_env__);if(r){return{expr:h,scope:v}}var y=k(h,q(q({},o),{},{env:v}));return Bu(y,_)}c=c.cdr}}catch(e){e.message+="\nin macro:\n ".concat(m.toString(true));throw e}throw new Error("syntax-rules: no matching syntax in macro ".concat(e.toString(true)))},w);r.__code__=m;return r},"(syntax-rules () (pattern expression) ...)\n\n Base of hygienic macros, it will return a new syntax expander\n that works like Lisp macros."),quote:l(new J("quote",function(e){return ys(e.car)}),"(quote expression) or 'expression\n\n Macro that returns a single LIPS expression as data (it won't evaluate the\n argument). It will return a list if put in front of LIPS code.\n And if put in front of a symbol it will return the symbol itself, not the value\n bound to that name."),"unquote-splicing":l("unquote-splicing",function(){throw new Error("You can't call `unquote-splicing` outside of quasiquote")},"(unquote-splicing code) or ,@code\n\n Special form used in the quasiquote macro. It evaluates the expression inside and\n splices the list into quasiquote's result. If it is not the last element of the\n expression, the computed value must be a pair."),unquote:l("unquote",function(){throw new Error("You can't call `unquote` outside of quasiquote")},"(unquote code) or ,code\n\n Special form used in the quasiquote macro. It evaluates the expression inside and\n substitutes the value into quasiquote's result."),quasiquote:J.defmacro("quasiquote",function(e,t){var o=t.use_dynamic,s=t.error;var c=this;var f=c;function a(e){return e instanceof $||nu(e)||Array.isArray(e)}function l(e,t){var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:a;if(e instanceof $){var n=e.car;var i=e.cdr;if(r(n)){n=t(n)}if(r(i)){i=t(i)}if(qu(n)||qu(i)){return fa([n,i]).then(function(e){var t=b(e,2),r=t[0],n=t[1];return new $(r,n)})}else{return new $(n,i)}}return e}function u(e,t){if(e instanceof $){if(t!==V){e.append(t)}}else{e=new $(e,t)}return e}function r(e){return!!e.filter(function(e){return e instanceof $&&Y.is(e.car,/^(unquote|unquote-splicing)$/)}).length}function h(e,n,i){return e.reduce(function(e,t){if(!(t instanceof $)){e.push(t);return e}if(Y.is(t.car,"unquote-splicing")){var r;if(n+11){var t="You can't splice multiple atoms inside list";throw new Error(t)}if(!(i.cdr instanceof $&&r[0]===V)){return r[0]}}r=r.map(function(e){if(d.has(e)){return e.clone()}else{d.add(e);return e}});var n=v(i.cdr,0,1);if(n===V&&r[0]===V){return undefined}return w(n,function(e){if(r[0]===V){return e}if(r.length===1){return u(r[0],e)}var t=r.reduce(function(e,t){return u(e,t)});return u(t,e)})})}(i.car.cdr)}var d=new Set;function v(e,t,r){if(e instanceof $){if(e.car instanceof $){if(Y.is(e.car.car,"unquote-splicing")){return _(e,t+1,r)}if(Y.is(e.car.car,"unquote")){if(t+2===r&&e.car.cdr instanceof $&&e.car.cdr.car instanceof $&&Y.is(e.car.cdr.car.car,"unquote-splicing")){var n=e.car.cdr;return new $(new $(new Y("unquote"),_(n,t+2,r)),V)}else if(e.car.cdr instanceof $&&e.car.cdr.cdr!==V){if(e.car.cdr.car instanceof $){var i=[];return function t(r){if(r===V){return $.fromArray(i)}return w(k(r.car,{env:c,dynamic_env:f,use_dynamic:o,error:s}),function(e){i.push(e);return t(r.cdr)})}(e.car.cdr)}else{return e.car.cdr}}}}if(Y.is(e.car,"quasiquote")){var a=v(e.cdr,t,r+1);return new $(e.car,a)}if(Y.is(e.car,"quote")){return new $(e.car,v(e.cdr,t,r))}if(Y.is(e.car,"unquote")){t++;if(tr){throw new Error("You can't call `unquote` outside "+"of quasiquote")}if(e.cdr instanceof $){if(e.cdr.cdr!==V){if(e.cdr.car instanceof $){var u=[];return function t(r){if(r===V){return $.fromArray(u)}return w(k(r.car,{env:c,dynamic_env:f,use_dynamic:o,error:s}),function(e){u.push(e);return t(r.cdr)})}(e.cdr)}else{return e.cdr}}else{return k(e.cdr.car,{env:c,dynamic_env:f,error:s})}}else{return e.cdr}}return l(e,function(e){return v(e,t,r)})}else if(nu(e)){return p(e,t,r)}else if(e instanceof Array){return h(e,t,r)}return e}function n(e){if(e instanceof $){delete e[oo];if(!e.haveCycles("car")){n(e.car)}if(!e.haveCycles("cdr")){n(e.cdr)}}}if(nu(e.car)&&!r(Object.values(e.car))){return ys(e.car)}if(Array.isArray(e.car)&&!r(e.car)){return ys(e.car)}if(e.car instanceof $&&!e.car.find("unquote")&&!e.car.find("unquote-splicing")&&!e.car.find("quasiquote")){return ys(e.car)}var i=v(e.car,0,1);return w(i,function(e){n(e);return ys(e)})},"(quasiquote list)\n\n Similar macro to `quote` but inside it you can use special expressions (unquote\n x) abbreviated to ,x that will evaluate x and insert its value verbatim or\n (unquote-splicing x) abbreviated to ,@x that will evaluate x and splice the value\n into the result. Best used with macros but it can be used outside."),clone:l("clone",function e(t){F("clone",t,"pair");return t.clone()},"(clone list)\n\n Function that returns a clone of the list, that does not share any pairs with the\n original, so the clone can be safely mutated without affecting the original."),append:l("append",function e(){var t;for(var r=arguments.length,n=new Array(r),i=0;iarray")(t).reverse();return K.get("array->list")(r)}else if(Array.isArray(t)){return t.reverse()}else{throw new Error(Rs("reverse",zs(t),"array or pair"))}},"(reverse list)\n\n Function that reverses the list or array. If value is not a list\n or array it will error."),nth:l("nth",function e(t,r){F("nth",t,"number");F("nth",r,["array","pair"]);if(r instanceof $){var n=r;var i=0;while(iarray")(r).join(t)},"(join separator list)\n\n Function that returns a string by joining elements of the list using separator."),split:l("split",function e(t,r){F("split",t,["regex","string"]);F("split",r,"string");return K.get("array->list")(r.split(t))},"(split separator string)\n\n Function that creates a list by splitting string by separator which can\n be a string or regular expression."),replace:l("replace",function e(t,r,n){F("replace",t,["regex","string"]);F("replace",r,["string","function"]);F("replace",n,"string");return n.replace(t,r)},"(replace pattern replacement string)\n\n Function that changes pattern to replacement inside string. Pattern can be a\n string or regex and replacement can be function or string. See Javascript\n String.replace()."),match:l("match",function e(t,r){F("match",t,["regex","string"]);F("match",r,"string");var n=r.match(t);return n?K.get("array->list")(n):false},"(match pattern string)\n\n Function that returns a match object from JavaScript as a list or #f if\n no match."),search:l("search",function e(t,r){F("search",t,["regex","string"]);F("search",r,"string");return r.search(t)},"(search pattern string)\n\n Function that returns the first found index of the pattern inside a string."),repr:l("repr",function e(t,r){return vu(t,r)},"(repr obj)\n\n Function that returns a LIPS code representation of the object as a string."),"escape-regex":l("escape-regex",function(e){F("escape-regex",e,"string");return Gi(e.valueOf())},"(escape-regex string)\n\n Function that returns a new string where all special operators used in regex,\n are escaped with backslashes so they can be used in the RegExp constructor\n to match a literal string."),env:l("env",function e(e){e=e||this.env;var t=Object.keys(e.__env__).map(Y);var r;if(t.length){r=$.fromArray(t)}else{r=V}if(e.__parent__ instanceof A){return K.get("env").call(this,e.__parent__).append(r)}return r},"(env)\n (env obj)\n\n Function that returns a list of names (functions, macros and variables)\n that are bound in the current environment or one of its parents."),new:l("new",function(e){for(var t=arguments.length,r=new Array(t>1?t-1:0),n=1;n2&&arguments[2]!==undefined?arguments[2]:pa.LITERAL;F("set-special!",e,"string",1);F("set-special!",t,"symbol",2);pa.append(e.valueOf(),t,r)},'(set-special! symbol name [type])\n\n Add a special symbol to the list of transforming operators by the parser.\n e.g.: `(add-special! "#" \'x)` will allow to use `#(1 2 3)` and it will be\n transformed into (x (1 2 3)) so you can write x macro that will process\n the list. 3rd argument is optional, and it can be one of two values:\n lips.specials.LITERAL, which is the default behavior, or\n lips.specials.SPLICE which causes the value to be unpacked into the expression.\n This can be used for e.g. to make `#(1 2 3)` into (x 1 2 3) that is needed\n by # that defines vectors.'),get:gs,".":gs,unbind:l(Zu,"(unbind fn)\n\n Function that removes the weak 'this' binding from a function so you\n can get properties from the actual function object."),type:l(zs,"(type object)\n\n Function that returns the type of an object as string."),debugger:l("debugger",function(){debugger},'(debugger)\n\n Function that triggers the JavaScript debugger (e.g. the browser devtools)\n using the "debugger;" statement. If a debugger is not running this\n function does nothing.'),in:l("in",function(e,t){if(e instanceof Y||e instanceof D||e instanceof j){e=e.valueOf()}return e in Gu(t)},'(in key value)\n\n Function that uses the Javascript "in" operator to check if key is\n a valid property in the value.'),"instance?":l("instance?",function(e){return Vu(e)},"(instance? obj)\n\n Checks if object is an instance, created with a new operator"),instanceof:l("instanceof",function(e,t){return t instanceof Zu(e)},"(instanceof type obj)\n\n Predicate that tests if the obj is an instance of type."),"prototype?":l("prototype?",yu,"(prototype? obj)\n\n Predicate that tests if value is a valid JavaScript prototype,\n i.e. calling (new) with it will not throw ' is not a constructor'."),"macro?":l("macro?",function(e){return e instanceof J},"(macro? expression)\n\n Predicate that tests if value is a macro."),"continuation?":l("continuation?",Pu,"(continuation? expression)\n\n Predicate that tests if value is a callable continuation."),"function?":l("function?",d,"(function? expression)\n\n Predicate that tests if value is a callable function."),"real?":l("real?",function(e){if(zs(e)!=="number"){return false}if(e instanceof j){return e.isFloat()}return j.isFloat(e)},"(real? number)\n\n Predicate that tests if value is a real number (not complex)."),"number?":l("number?",function(e){return Number.isNaN(e)||j.isNumber(e)},"(number? expression)\n\n Predicate that tests if value is a number or NaN value."),"string?":l("string?",function(e){return D.isString(e)},"(string? expression)\n\n Predicate that tests if value is a string."),"pair?":l("pair?",function(e){return e instanceof $},"(pair? expression)\n\n Predicate that tests if value is a pair or list structure."),"regex?":l("regex?",function(e){return e instanceof RegExp},"(regex? expression)\n\n Predicate that tests if value is a regular expression."),"null?":l("null?",function(e){return Iu(e)},"(null? expression)\n\n Predicate that tests if value is null-ish (i.e. undefined, nil, or\n Javascript null)."),"boolean?":l("boolean?",function(e){return typeof e==="boolean"},"(boolean? expression)\n\n Predicate that tests if value is a boolean (#t or #f)."),"symbol?":l("symbol?",function(e){return e instanceof Y},"(symbol? expression)\n\n Predicate that tests if value is a LIPS symbol."),"array?":l("array?",function(e){return e instanceof Array},"(array? expression)\n\n Predicate that tests if value is an array."),"object?":l("object?",function(e){return e!==V&&e!==null&&!(e instanceof h)&&!(e instanceof RegExp)&&!(e instanceof D)&&!(e instanceof $)&&!(e instanceof j)&&p(e)==="object"&&!(e instanceof Array)},"(object? expression)\n\n Predicate that tests if value is an plain object (not another LIPS type)."),flatten:l("flatten",function e(t){F("flatten",t,"pair");return t.flatten()},"(flatten list)\n\n Returns a shallow list from tree structure (pairs)."),"array->list":l("array->list",function(e){F("array->list",e,"array");return $.fromArray(e)},"(array->list array)\n\n Function that converts a JavaScript array to a LIPS cons list."),"tree->array":l("tree->array",tu("tree->array",true),"(tree->array list)\n\n Function that converts a LIPS cons tree structure into a JavaScript array."),"list->array":l("list->array",tu("list->array"),"(list->array list)\n\n Function that converts a LIPS list into a JavaScript array."),apply:l("apply",function e(t){for(var r=arguments.length,n=new Array(r>1?r-1:0),i=1;iarray").call(this,a));return t.apply(this,Ks(t,n))},"(apply fn list)\n\n Function that calls fn with the list of arguments."),length:l("length",function e(t){if(!t||t===V){return 0}if(t instanceof $){return t.length()}if("length"in t){return t.length}},'(length expression)\n\n Function that returns the length of the object. The object can be a LIPS\n list or any object that has a "length" property. Returns undefined if the\n length could not be found.'),"string->number":l("string->number",function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:10;F("string->number",e,"string",1);F("string->number",t,"number",2);e=e.valueOf();t=t.valueOf();if(e.match(Bi)||e.match(Ci)){return Ri(e,t)}else if(e.match(ji)||e.match(ki)){return Mi(e,t)}else{var r=t===10&&!e.match(/e/i)||t===16;if(e.match(Si)&&r||e.match(Oi)){return Ti(e,t)}if(e.match(yi)){return Yi(e)}}return false},"(string->number number [radix])\n\n Function that parses a string into a number."),try:l(new J("try",function(r,e){var l=this;var h=e.use_dynamic;e.error;return new Promise(function(t,o){var s,n;if(Y.is(r.cdr.car.car,"catch")){s=r.cdr.car;if(r.cdr.cdr instanceof $&&Y.is(r.cdr.cdr.car.car,"finally")){n=r.cdr.cdr.car}}else if(Y.is(r.cdr.car.car,"finally")){n=r.cdr.car}if(!(n||s)){throw new Error("try: invalid syntax")}function c(e){t(e);throw new _s("[CATCH]")}var f=function e(t,r){r(t)};if(n){f=function e(t,r){f=o;i.error=function(e){throw e};w(k(new $(new Y("begin"),n.cdr),i),function(){r(t)})}}var i={env:l,use_dynamic:h,dynamic_env:l,error:function e(t){if(t instanceof _s){throw t}var r=l.inherit("try");if(s){var n=s.cdr.car.car;if(!(n instanceof Y)){throw new Error("try: invalid syntax: catch require variable name")}r.set(n,t);var i;var a={env:r,use_dynamic:h,dynamic_env:l,error:function e(t){i=true;o(t);throw new _s("[CATCH]")}};var u=k(new $(new Y("begin"),s.cdr.cdr),a);w(u,function e(t){if(!i){f(t,c)}})}else{f(undefined,function(){throw t})}}};var e=k(r.car,i);w(e,function(e){f(e,t)},i.error)})}),"(try expr (catch (e) code))\n (try expr (catch (e) code) (finally code))\n (try expr (finally code))\n\n Macro that executes expr and catches any exceptions thrown. If catch is provided\n it's executed when an error is thrown. If finally is provided it's always\n executed at the end."),raise:l("raise",function(e){throw e},"(raise obj)\n\n Throws the object verbatim (no wrapping an a new Error)."),throw:l("throw",function(e){throw new Error(e)},"(throw string)\n\n Throws a new exception."),find:l("find",function t(r,n){F("find",r,["regex","function"]);F("find",n,["pair","nil"]);if(Iu(n)){return V}var e=Oa("find",r);return w(e(n.car),function(e){if(e&&e!==V){return n.car}return t(r,n.cdr)})},"(find fn list)\n (find regex list)\n\n Higher-order function that finds the first value for which fn return true.\n If called with a regex it will create a matcher function."),"for-each":l("for-each",function(e){var t;F("for-each",e,"function");for(var r=arguments.length,n=new Array(r>1?r-1:0),i=1;i1?t-1:0),a=1;a3?n-3:0),a=3;a3?i-3:0),u=3;uarray")(r);var a=[];var u=Oa("filter",t);return function t(r){function e(e){if(e&&e!==V){a.push(n)}return t(++r)}if(r===i.length){return $.fromArray(a)}var n=i[r];return w(u(n),e)}(0)},"(filter fn list)\n (filter regex list)\n\n Higher-order function that calls `fn` for each element of the list\n and return a new list for only those elements for which fn returns\n a truthy value. If called with a regex it will create a matcher function."),compose:l(ko,"(compose . fns)\n\n Higher-order function that creates a new function that applies all functions\n from right to left and returns the last value. Reverse of pipe.\n e.g.:\n ((compose (curry + 2) (curry * 3)) 10) --\x3e (+ 2 (* 3 10)) --\x3e 32"),pipe:l(Fo,"(pipe . fns)\n\n Higher-order function that creates a new function that applies all functions\n from left to right and returns the last value. Reverse of compose.\n e.g.:\n ((pipe (curry + 2) (curry * 3)) 10) --\x3e (* 3 (+ 2 10)) --\x3e 36"),curry:l(Io,"(curry fn . args)\n\n Higher-order function that creates a curried version of the function.\n The result function will have partially applied arguments and it\n will keep returning one-argument functions until all arguments are provided,\n then it calls the original function with the accumulated arguments.\n\n e.g.:\n (define (add a b c d) (+ a b c d))\n (define add1 (curry add 1))\n (define add12 (add 2))\n (display (add12 3 4))"),gcd:l("gcd",function e(){for(var t=arguments.length,r=new Array(t),n=0;no?a%=o:o%=a}a=gu(s*r[u])/(a+o)}return j(a)},"(lcm n1 n2 ...)\n\n Function that returns the least common multiple of the arguments."),"odd?":l("odd?",So(function(e){return j(e).isOdd()}),"(odd? number)\n\n Checks if number is odd."),"even?":l("even?",So(function(e){return j(e).isEven()}),"(even? number)\n\n Checks if number is even."),"*":l("*",jo(function(e,t){return j(e).mul(t)},j(1)),"(* . numbers)\n\n Multiplies all numbers passed as arguments. If single value is passed\n it will return that value."),"+":l("+",jo(function(e,t){return j(e).add(t)},j(0)),"(+ . numbers)\n\n Sums all numbers passed as arguments. If single value is passed it will\n return that value."),"-":l("-",function(){for(var e=arguments.length,t=new Array(e),r=0;r":l(">",function(){for(var e=arguments.length,t=new Array(e),r=0;r",t,["bigint","float","rational"]);return bu(function(e,t){return j(e).cmp(t)===1},t)},"(> x1 x2 x3 ...)\n\n Function that compares its numerical arguments and checks if they are\n monotonically decreasing, i.e. x1 > x2 and x2 > x3 and so on."),"<":l("<",function(){for(var e=arguments.length,t=new Array(e),r=0;r=":l(">=",function(){for(var e=arguments.length,t=new Array(e),r=0;r=",t,["bigint","float","rational"]);return bu(function(e,t){return[0,1].includes(j(e).cmp(t))},t)},"(>= x1 x2 ...)\n\n Function that compares its numerical arguments and checks if they are\n monotonically nonincreasing, i.e. x1 >= x2 and x2 >= x3 and so on."),"eq?":l("eq?",wu,"(eq? a b)\n\n Function that compares two values if they are identical."),or:l(new J("or",function(e,t){var i=t.use_dynamic,a=t.error;var u=K.get("list->array")(e);var o=this;var s=o;if(!u.length){return false}var c;return function t(){function e(e){c=e;if(c!==false){return c}else{return t()}}if(!u.length){if(c!==false){return c}else{return false}}else{var r=u.shift();var n=k(r,{env:o,dynamic_env:s,use_dynamic:i,error:a});return w(n,e)}}()}),"(or . expressions)\n\n Macro that executes the values one by one and returns the first that is\n a truthy value. If there are no expressions that evaluate to true it\n returns false."),and:l(new J("and",function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},r=t.use_dynamic,n=t.error;var i=K.get("list->array")(e);var a=this;var u=a;if(!i.length){return true}var o;var s={env:a,dynamic_env:u,use_dynamic:r,error:n};return function t(){function e(e){o=e;if(o===false){return false}else{return t()}}if(!i.length){if(o!==false){return o}else{return false}}else{var r=i.shift();return w(k(r,s),e)}}()}),"(and . expressions)\n\n Macro that evaluates each expression in sequence and if any value returns false\n it will stop and return false. If each value returns true it will return the\n last value. If it's called without arguments it will return true."),"|":l("|",function(e,t){return j(e).or(t)},"(| a b)\n\n Function that calculates the bitwise or operation."),"&":l("&",function(e,t){return j(e).and(t)},"(& a b)\n\n Function that calculates the bitwise and operation."),"~":l("~",function(e){return j(e).neg()},"(~ number)\n\n Function that calculates the bitwise inverse (flip all the bits)."),">>":l(">>",function(e,t){return j(e).shr(t)},"(>> a b)\n\n Function that right shifts the value a by value b bits."),"<<":l("<<",function(e,t){return j(e).shl(t)},"(<< a b)\n\n Function that left shifts the value a by value b bits."),not:l("not",function e(t){if(Iu(t)){return true}return!t},"(not object)\n\n Function that returns the Boolean negation of its argument.")},undefined,"global");var As=K.inherit("user-env");function Fs(e,t){e.constant("**internal-env**",t);e.doc("**internal-env**","**internal-env**\n\n Constant used to hide stdin, stdout and stderr so they don't interfere\n with variables with the same name. Constants are an internal type\n of variable that can't be redefined, defining a variable with the same name\n will throw an error.");K.set("**interaction-environment**",e)}Fs(As,Ds);K.doc("**interaction-environment**","**interaction-environment**\n\n Internal dynamic, global variable used to find interpreter environment.\n It's used so the read and write functions can locate **internal-env**\n that contains the references to stdin, stdout and stderr.");function ks(e){As.get("**internal-env**").set("fs",e)}(function(){var e={ceil:"ceiling"};["floor","round","ceil"].forEach(function(t){var r=e[t]?e[t]:t;K.set(r,l(r,function(e){F(r,e,"number");if(e instanceof j){return e[t]()}},"(".concat(r," number)\n\n Function that calculates the ").concat(r," of a number.")))})})();function Cs(e){if(e.length===1){return e[0]}else{var t=[];var r=Cs(e.slice(1));for(var n=0;n3&&arguments[3]!==undefined?arguments[3]:null;var i=e?" in expression `".concat(e,"`"):"";if(n!==null){i+=" (argument ".concat(n,")")}if(d(r)){return"Invalid type: got ".concat(t).concat(i)}if(r instanceof Array){if(r.length===1){var a=r[0].toLowerCase();r="a"+("aeiou".includes(a)?"n ":" ")+r[0]}else{r=new Intl.ListFormat("en",{style:"long",type:"disjunction"}).format(r)}}return"Expecting ".concat(r," got ").concat(t).concat(i)}function Ts(e,t,r){var n=arguments.length>3&&arguments[3]!==undefined?arguments[3]:null;F(e,t,"number",n);var i=t.__type__;var a;if(r instanceof $){r=r.to_array()}if(r instanceof Array){r=r.map(function(e){return e.valueOf()})}if(r instanceof Array){r=r.map(function(e){return e.valueOf().toLowerCase()});if(r.includes(i)){a=true}}else{r=r.valueOf().toLowerCase()}if(!a&&i!==r){throw new Error(Rs(e,i,r,n))}}function Ls(r,e,n){e.forEach(function(e,t){Ts(r,e,n,t+1)})}function Ms(r,e,n){e.forEach(function(e,t){F(r,e,n,t+1)})}function Us(e,t,r){F(e,t,r);if(t.__type__===ss){throw new Error(Rs(e,"binary-port","textual-port"))}}function F(e,t,r){var n=arguments.length>3&&arguments[3]!==undefined?arguments[3]:null;e=e.valueOf();var i=zs(t).toLowerCase();if(d(r)){if(!r(t)){throw new Error(Rs(e,i,r,n))}return}var a=false;if(r instanceof $){r=r.to_array()}if(r instanceof Array){r=r.map(function(e){return e.valueOf()})}if(r instanceof Array){r=r.map(function(e){return e.valueOf().toLowerCase()});if(r.includes(i)){a=true}}else{r=r.valueOf().toLowerCase()}if(!a&&i!==r){throw new Error(Rs(e,i,r,n))}}function qs(r){var n=new WeakMap;return function(e){var t=n.get(e);if(!t){t=r(e)}return t}}zs=qs(zs);function zs(e){var t=ni.get(e);if(t){return t}if(p(e)==="object"){for(var r=0,n=Object.entries(ri);r2&&arguments[2]!==undefined?arguments[2]:{},n=r.env,i=r.dynamic_env,a=r.use_dynamic;var u=n===null||n===void 0?void 0:n.new_frame(e,t);var o=i===null||i===void 0?void 0:i.new_frame(e,t);var s=new Zs({env:u,use_dynamic:a,dynamic_env:o});return Ys(e.apply(s,t))}function Ws(n,e){var t=arguments.length>2&&arguments[2]!==undefined?arguments[2]:{},i=t.env,a=t.dynamic_env,u=t.use_dynamic,r=t.error,o=r===void 0?function(){}:r;e=Vs(e,{env:i,dynamic_env:a,error:o,use_dynamic:u});return w(e,function(e){if(wo(n)){n=Zu(n)}e=Ks(n,e);var t=e.slice();var r=Hs(n,t,{env:i,dynamic_env:a,use_dynamic:u});return w(r,function(e){if(e instanceof $){e.markCycles();return ys(e)}return Hu(e)},o)})}var Gs=new WeakMap;var Qs=function(){function n(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:null;var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:null;ae(this,n);fe(this,"__value__",void 0);fe(this,"__fn__",void 0);$n(this,Gs,{writable:true,value:void 0});this.__value__=e;if(t){if(!d(t)){throw new Error("Section argument to Parameter need to be function "+"".concat(zs(t)," given"))}this.__fn__=t}if(r){I(this,Gs,r)}}ce(n,[{key:"__name__",get:function e(){return r(this,Gs)},set:function e(t){I(this,Gs,t);if(this.__fn__){this.__fn__.__name__="fn-".concat(t)}}},{key:"invoke",value:function e(){if(d(this.__fn__)){return this.__fn__(this.__value__)}return this.__value__}},{key:"inherit",value:function e(t){return new n(t,this.__fn__,this.__name__)}}]);return n}();var Zs=function(){function t(e){ae(this,t);fe(this,"env",void 0);fe(this,"dynamic_env",void 0);fe(this,"use_dynamic",void 0);Object.assign(this,e)}ce(t,[{key:"__name__",get:function e(){return this.env.__name__}},{key:"__parent__",get:function e(){return this.env.__parent__}},{key:"get",value:function e(){var t;return(t=this.env).get.apply(t,arguments)}}]);return t}();function Xs(e,t){var r=e.get(t.__name__,{throwError:false});if(Ru(r)&&r!==t){return r}var n=As.get("**interaction-environment**");while(true){var i=e.get("parent.frame",{throwError:false});e=i(0);if(e===n){break}r=e.get(t.__name__,{throwError:false});if(Ru(r)&&r!==t){return r}}return t}var ec=function(){function t(e){ae(this,t);fe(this,"__value__",void 0);this.__value__=e}ce(t,[{key:"invoke",value:function e(){if(this.__value__===null){throw new Error("Continuations are not implemented yet")}}}]);return t}();function k(o){var e=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},s=e.env,c=e.dynamic_env,f=e.use_dynamic,t=e.error,l=t===void 0?Is:t,r=he(e,Vn);return function(e){try{if(!Lu(c)){c=s===true?As:s||As}if(f){s=c}else if(s===true){s=As}else{s=s||K}var t={env:s,dynamic_env:c,use_dynamic:f,error:l};var r;if(Iu(o)){return o}if(o instanceof Y){return s.get(o)}if(!(o instanceof $)){return o}var n=o.car;var e=o.cdr;if(n instanceof $){r=Ys(k(n,t));if(qu(r)){return r.then(function(e){if(!Mu(e)){throw new Error(zs(e)+" "+s.get("repr")(e)+" is not callable while evaluating "+o.toString())}return k(new $(e,o.cdr),t)})}else if(!Mu(r)){throw new Error(zs(r)+" "+s.get("repr")(r)+" is not callable while evaluating "+o.toString())}}if(n instanceof Y){r=s.get(n)}else if(d(n)){r=n}var i;if(r instanceof Cu){i=$s(r,o,t)}else if(r instanceof J){i=Js(r,e,t)}else if(d(r)){i=Ws(r,e,t)}else if(r instanceof Ou){i=$s(r._syntax,o,t)}else if(Ru(r)){var a=Xs(c,r);if(Iu(o.cdr)){i=a.invoke()}else{return w(k(o.cdr.car,t),function(e){a.__value__=e})}}else if(Pu(r)){i=r.invoke()}else if(o instanceof $){r=n&&n.toString();throw new Error("".concat(zs(n)," ").concat(r," is not a function"))}else{return o}var u=s.get(Symbol["for"]("__promise__"),{throwError:false});if(u===true&&qu(i)){i=i.then(function(e){if(e instanceof $&&!r[oo]){return k(e,t)}return e});return new ca(i)}return i}catch(e){l&&l.call(s,e,o)}}(r)}var tc=ic(function(e){return e});var rc=ic(function(e,t){return t});function nc(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},r=t.env,n=t.dynamic_env,i=t.use_dynamic;return k(e,{env:r,dynamic_env:n,use_dynamic:i,error:function e(t,r){if(t&&t.message){if(t.message.match(/^Error:/)){var n=/^(Error:)\s*([^:]+:\s*)/;t.message=t.message.replace(n,"$1 $2")}if(r){if(!(t.__code__ instanceof Array)){t.__code__=[]}t.__code__.push(r.toString(true))}}if(!(t instanceof _s)){throw t}}})}function ic(d){return function(){var t=ie(function(l){var e=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},h=e.env,p=e.dynamic_env,_=e.use_dynamic;return C.mark(function e(){var r,n,i,a,u,o,s,c,f;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(!Lu(p)){p=h===true?As:h||As}if(h===true){h=As}else{h=h||As}r=[];if(!Tu(l)){t.next=8;break}t.next=6;return nc(code,{env:h,dynamic_env:p,use_dynamic:_});case 6:t.t0=t.sent;return t.abrupt("return",[t.t0]);case 8:n=Array.isArray(l)?l:Ea(l);i=false;a=false;t.prev=11;o=Xn(n);case 13:t.next=15;return o.next();case 15:if(!(i=!(s=t.sent).done)){t.next=31;break}c=s.value;t.next=19;return nc(c,{env:h,dynamic_env:p,use_dynamic:_});case 19:f=t.sent;t.t1=r;t.t2=d;t.t3=c;t.next=25;return f;case 25:t.t4=t.sent;t.t5=(0,t.t2)(t.t3,t.t4);t.t1.push.call(t.t1,t.t5);case 28:i=false;t.next=13;break;case 31:t.next=37;break;case 33:t.prev=33;t.t6=t["catch"](11);a=true;u=t.t6;case 37:t.prev=37;t.prev=38;if(!(i&&o["return"]!=null)){t.next=42;break}t.next=42;return o["return"]();case 42:t.prev=42;if(!a){t.next=45;break}throw u;case 45:return t.finish(42);case 46:return t.finish(37);case 47:return t.abrupt("return",r);case 48:case"end":return t.stop()}},e,null,[[11,33,37,47],[38,,42,46]])})()});function e(e){return t.apply(this,arguments)}return e}()}function ac(e){var t={"[":"]","(":")"};var r;if(typeof e==="string"){r=na(e)}else{r=e.map(function(e){return e&&e.token?e.token:e})}var n=Object.keys(t);var i=Object.values(t).concat(n);r=r.filter(function(e){return i.includes(e)});var a=new Qi;var u=Wn(r),o;try{for(u.s();!(o=u.n()).done;){var s=o.value;if(n.includes(s)){a.push(s)}else if(!a.is_empty()){var c=a.top();var f=t[c];if(s===f){a.pop()}else{throw new Error("Syntax error: missing closing ".concat(f))}}else{throw new Error("Syntax error: not matched closing ".concat(s))}}}catch(e){u.e(e)}finally{u.f()}return a.is_empty()}function uc(e){var t="("+e.toString()+")()";var r=window.URL||window.webkitURL;var n;try{n=new Blob([t],{type:"application/javascript"})}catch(e){var i=window.BlobBuilder||window.WebKitBlobBuilder||window.MozBlobBuilder;n=new i;n.append(t);n=n.getBlob()}return new ti.Worker(r.createObjectURL(n))}function oc(){return Lc.version.match(/^(\{\{VER\}\}|DEV)$/)}function sc(){if(js()){return}var e;if(document.currentScript){e=document.currentScript}else{var t=document.querySelectorAll("script");if(!t.length){return}e=t[t.length-1]}var r=e.getAttribute("src");return r}var cc=sc();function fc(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:"";var t="dist/std.xcb";if(e===""){if(cc){e=cc.replace(/[^/]*$/,"std.xcb")}else if(oc()){e="https://cdn.jsdelivr.net/gh/jcubic/lips@devel/".concat(t)}else{e="https://cdn.jsdelivr.net/npm/@jcubic/lips@".concat(Lc.version,"/").concat(t)}}var r=K.get("load");return r.call(As,e,K)}function lc(e){this.url=e;var u=this.worker=uc(function(){var u;var o;self.addEventListener("message",function(e){var r=e.data;var t=r.id;if(r.type!=="RPC"||t===null){return}function n(e){self.postMessage({id:t,type:"RPC",result:e})}function i(e){self.postMessage({id:t,type:"RPC",error:e})}if(r.method==="eval"){if(!o){i("Worker RPC: LIPS not initialized, call init first");return}o.then(function(){var e=r.params[0];var t=r.params[1];u.exec(e,{use_dynamic:t}).then(function(e){e=e.map(function(e){return e&&e.valueOf()});n(e)})["catch"](function(e){i(e)})})}else if(r.method==="init"){var a=r.params[0];if(typeof a!=="string"){i("Worker RPC: url is not a string")}else{importScripts("".concat(a,"/dist/lips.min.js"));u=new Lc.Interpreter("worker");o=fc(a);o.then(function(){n(true)})}}})});this.rpc=function(){var n=0;return function e(t,r){var a=++n;return new Promise(function(n,i){u.addEventListener("message",function e(t){var r=t.data;if(r&&r.type==="RPC"&&r.id===a){if(r.error){i(r.error)}else{n(r.result)}u.removeEventListener("message",e)}});u.postMessage({type:"RPC",method:t,id:a,params:r})})}}();this.rpc("init",[e])["catch"](function(e){console.error(e)});this.exec=function(e,t){var r=t.use_dynamic,n=r===void 0?false:r;return this.rpc("eval",[e,n])}}var hc={pair:function e(t){var r=b(t,2),n=r[0],i=r[1];return $(n,i)},number:function e(t){if(D.isString(t)){return j([t,10])}return j(t)},regex:function e(t){var r=b(t,2),n=r[0],i=r[1];return new RegExp(n,i)},nil:function e(){return V},symbol:function e(t){if(D.isString(t)){return Y(t)}else if(Array.isArray(t)){return Y(Symbol["for"](t[0]))}},string:D,character:h};var pc=Object.keys(hc);var _c={};for(var dc=0,vc=Object.entries(pc);dc1){var n=t.reduce(function(e,t){return e+t.length},0);var i=new Uint8Array(n);var a=0;t.forEach(function(e){i.set(e,a);a+=e.length});return i}else if(t.length){return t[0]}}function Fc(){var e=1;var t=new TextEncoder("utf-8");return t.encode("LIPS".concat(e.toString().padStart(3," ")))}var kc=7;function Cc(e){var t=new TextDecoder("utf-8");var r=t.decode(e.slice(0,kc));var n=r.substring(0,4);if(n==="LIPS"){var i=r.match(/^(....).*([0-9]+)$/);if(i){return{type:i[1],version:Number(i[2])}}}return{type:"unknown"}}function Oc(e){var t=Fc();var r=xc.encode(e);return Ac(t,Rn(r,{magic:false}))}function Sc(e){var t=Cc(e),r=t.type,n=t.version;if(r==="LIPS"&&n===1){var i=Tn(e.slice(kc),{magic:false});return xc.decode(i)}else{throw new Error("Invalid file format ".concat(r))}}function Bc(e){console.error(e.message||e);if(Array.isArray(e.code)){console.error(e.code.map(function(e,t){return"[".concat(t+1,"]: ").concat(e)}))}}function jc(){var o=["text/x-lips","text/x-scheme"];var s;function c(r){return new Promise(function(t){var e=r.getAttribute("src");if(e){return fetch(e).then(function(e){return e.text()}).then(rc).then(t)["catch"](function(e){Bc(e);t()})}else{return rc(r.innerHTML).then(t)["catch"](function(e){Bc(e);t()})}})}function e(){return new Promise(function(a){var u=Array.from(document.querySelectorAll("script"));return function e(){var t=u.shift();if(!t){a()}else{var r=t.getAttribute("type");if(o.includes(r)){var n;var i=(n=t.getAttribute("bootstrap"))!==null&&n!==void 0?n:t.getAttribute("data-bootstrap");if(!s&&typeof i==="string"){return fc(i).then(function(){return c(t)}).then(e)}else{return c(t).then(e)}}else if(r&&r.match(/lips|lisp/)){console.warn("Expecting "+o.join(" or ")+" found "+r)}return e()}}()})}if(!window.document){return Promise.resolve()}else if(Ic){var t=Ic;var r=t.getAttribute("bootstrap");if(typeof r==="string"){return fc(r).then(function(){s=true;return e()})}}return e()}var Ic=typeof window!=="undefined"&&window.document&&document.currentScript;if(typeof window!=="undefined"){si(window,jc)}var Pc=function(){var e=D("Mon, 12 Feb 2024 12:58:05 +0000").valueOf();var t=e==="{{"+"DATE}}"?new Date:new Date(e);var r=function e(t){return t.toString().padStart(2,"0")};var n=t.getFullYear();var i=[n,r(t.getMonth()+1),r(t.getDate())].join("-");var a="\n __ __ __\n / / \\ \\ _ _ ___ ___ \\ \\\n| | \\ \\ | | | || . \\/ __> | |\n| | > \\ | |_ | || _/\\__ \\ | |\n| | / ^ \\ |___||_||_| <___/ | |\n \\_\\ /_/ \\_\\ /_/\n\nLIPS Interpreter DEV (".concat(i,") \nCopyright (c) 2018-").concat(n," Jakub T. Jankiewicz\n\nType (env) to see environment with functions macros and variables. You can also\nuse (help name) to display help for specific function or macro, (apropos name)\nto display list of matched names in environment and (dir object) to list\nproperties of an object.\n").replace(/^.*\n/,"");return a}();f(Na,"__class__","ahead");f($,"__class__","pair");f(eu,"__class__","nil");f(Ra,"__class__","pattern");f(Pa,"__class__","formatter");f(J,"__class__","macro");f(Cu,"__class__","syntax");f(Cu.Parameter,"__class__","syntax-parameter");f(A,"__class__","environment");f(Qo,"__class__","input-port");f(Zo,"__class__","output-port");f(Xo,"__class__","output-port");f(es,"__class__","output-string-port");f(rs,"__class__","input-string-port");f(as,"__class__","input-file-port");f(ts,"__class__","output-file-port");f(ps,"__class__","lips-error");[j,m,E,g,x].forEach(function(e){f(e,"__class__","number")});f(h,"__class__","character");f(Y,"__class__","symbol");f(D,"__class__","string");f(ca,"__class__","promise");f(Qs,"__class__","parameter");var Nc="DEV";var Rc="Mon, 12 Feb 2024 12:58:05 +0000";var Tc=ko(ka,Ea);var Lc={version:Nc,banner:Pc,date:Rc,exec:rc,parse:Tc,tokenize:na,evaluate:k,compile:tc,serialize:Dc,unserialize:Ec,serialize_bin:Oc,unserialize_bin:Sc,bootstrap:fc,Environment:A,env:As,Worker:lc,Interpreter:hs,balanced_parenthesis:ac,balancedParenthesis:ac,balanced:ac,Macro:J,Syntax:Cu,Pair:$,Values:vs,QuotedPromise:ca,Error:ps,quote:ys,InputPort:Qo,OutputPort:Zo,BufferedOutputPort:Xo,InputFilePort:as,OutputFilePort:ts,InputStringPort:rs,OutputStringPort:es,InputByteVectorPort:ns,OutputByteVectorPort:is,InputBinaryFilePort:us,OutputBinaryFilePort:os,set_fs:ks,Formatter:Pa,Parser:wa,Lexer:s,specials:pa,repr:ru,nil:V,eof:fs,LSymbol:Y,LNumber:j,LFloat:g,LComplex:m,LRational:E,LBigInteger:x,LCharacter:h,LString:D,Parameter:Qs,rationalize:Wo};K.set("lips",Lc);var Mc={};var Uc=Object.freeze({__proto__:null,default:Mc});function qc(e,t){var r=0;for(var n=e.length-1;n>=0;n--){var i=e[n];if(i==="."){e.splice(n,1)}else if(i===".."){e.splice(n,1);r++}else if(r){e.splice(n,1);r--}}if(t){for(;r--;r){e.unshift("..")}}return e}var zc=/^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/;var Yc=function(e){return zc.exec(e).slice(1)};function Vc(){var e="",t=false;for(var r=arguments.length-1;r>=-1&&!t;r--){var n=r>=0?arguments[r]:"/";if(typeof n!=="string"){throw new TypeError("Arguments to path.resolve must be strings")}else if(!n){continue}e=n+"/"+e;t=n.charAt(0)==="/"}e=qc(tf(e.split("/"),function(e){return!!e}),!t).join("/");return(t?"/":"")+e||"."}function $c(e){var t=Jc(e),r=rf(e,-1)==="/";e=qc(tf(e.split("/"),function(e){return!!e}),!t).join("/");if(!e&&!t){e="."}if(e&&r){e+="/"}return(t?"/":"")+e}function Jc(e){return e.charAt(0)==="/"}function Kc(){var e=Array.prototype.slice.call(arguments,0);return $c(tf(e,function(e,t){if(typeof e!=="string"){throw new TypeError("Arguments to path.join must be strings")}return e}).join("/"))}function Hc(e,t){e=Vc(e).substr(1);t=Vc(t).substr(1);function r(e){var t=0;for(;t=0;r--){if(e[r]!=="")break}if(t>r)return[];return e.slice(t,r-t+1)}var n=r(e.split("/"));var i=r(t.split("/"));var a=Math.min(n.length,i.length);var u=a;for(var o=0;or-An){t[i++]=e[n++];continue}f=(e[n]+13^e[n+1]-13^e[n+2])&Fn-1;c=n-l[f]&xn;l[f]=n;u=n-c;if(u>=0&&u!=n&&e[n]==e[u]&&e[n+1]==e[u+1]&&e[n+2]==e[u+2]){t[a]|=o;for(s=En;s>wn;t[i++]=c;n+=s}else{t[i++]=e[n++]}}console.assert(e.length>=n);return i}function Cn(e,t,r){t=t|0;var n=0,i=0,u=0,a=0,o=1<<(wn-1|0),s=0,c=0;while(n>(wn-Dn|0))+En|0;c=(e[n]<4){r[i]=r[u];i=i+1|0;u=u+1|0;r[i]=r[u];i=i+1|0;u=u+1|0;r[i]=r[u];i=i+1|0;u=u+1|0;r[i]=r[u];i=i+1|0;u=u+1|0;s=s-4|0}while(s>0){r[i]=r[u];i=i+1|0;u=u+1|0;s=s-1|0}}}else{r[i]=e[n];i=i+1|0;n=n+1|0}}return i}function On(){const e=new TextEncoder("utf-8");return e.encode(Sn)}const Sn="@lzjb";const Bn=On();function jn(...e){if(e.length>1){const r=e.reduce((e,t)=>e+t.length,0);const n=new Uint8Array(r);let t=0;e.forEach(e=>{n.set(e,t);t+=e.length});return n}else if(e.length){return e[0]}}function In(t){const e=Math.ceil(Math.log2(t)/8);const r=new Uint8Array(e);for(let e=0;e=0;e--){r=r*256+t[e]}return r}function Nn(e,{magic:t=true}={}){const r=new Uint8Array(Math.max(e.length*1.5|0,16*1024));const n=kn(e,r);const i=In(e.length);const u=[Uint8Array.of(i.length),i,r.slice(0,n)];if(t){u.unshift(Bn)}return jn(...u)}function Rn(t,{magic:e=true}={}){if(e){const e=new TextDecoder("utf-8");const s=e.decode(t.slice(0,Bn.length));if(s!==Sn){throw new Error("Invalid magic value")}}const r=e?Bn.length:0;const n=t[r];const i=r+1;const u=r+n+1;const a=Pn(t.slice(i,u));t=t.slice(u);const o=new Uint8Array(a);Cn(t,t.length,o);return o}var Tn=bn.pack=Nn;var Ln=bn.unpack=Rn;function Mn(s,c){return c=c||{},new Promise(function(e,t){var r=new XMLHttpRequest,n=[],i=[],u={},a=function(){return{ok:2==(r.status/100|0),statusText:r.statusText,status:r.status,url:r.responseURL,text:function(){return Promise.resolve(r.responseText)},json:function(){return Promise.resolve(r.responseText).then(JSON.parse)},blob:function(){return Promise.resolve(new Blob([r.response]))},clone:a,headers:{keys:function(){return n},entries:function(){return i},get:function(e){return u[e.toLowerCase()]},has:function(e){return e.toLowerCase()in u}}}};for(var o in r.open(c.method||"get",s,!0),r.onload=function(){r.getAllResponseHeaders().replace(/^(.*?):[^\S\n]*([\s\S]*?)$/gm,function(e,t,r){n.push(t=t.toLowerCase()),i.push([t,r]),u[t]=u[t]?u[t]+","+r:r}),e(a())},r.onerror=t,r.withCredentials="include"==c.credentials,c.headers)r.setRequestHeader(o,c.headers[o]);r.send(c.body||null)})}var Un=["token"],qn=["env"],zn=["stderr","stdin","stdout","command_line"],Yn=["use_dynamic"],Vn=["use_dynamic"],$n=["env","dynamic_env","use_dynamic","error"];function Jn(e,t,r){Kn(e,t);t.set(e,r)}function Kn(e,t){if(t.has(e)){throw new TypeError("Cannot initialize the same private elements twice on an object")}}function Hn(e,t,r){return t=I(t),M(e,Wn()?Reflect.construct(t,r||[],I(e).constructor):t.apply(e,r))}function Wn(){try{var t=!Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){}))}catch(t){}return(Wn=function e(){return!!t})()}function Gn(t,e){var r=typeof Symbol!=="undefined"&&t[Symbol.iterator]||t["@@iterator"];if(!r){if(Array.isArray(t)||(r=Qn(t))||e&&t&&typeof t.length==="number"){if(r)t=r;var n=0;var i=function e(){};return{s:i,n:function e(){if(n>=t.length)return{done:true};return{done:false,value:t[n++]}},e:function e(t){throw t},f:i}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var u=true,a=false,o;return{s:function e(){r=r.call(t)},n:function e(){var t=r.next();u=t.done;return t},e:function e(t){a=true;o=t},f:function e(){try{if(!u&&r["return"]!=null)r["return"]()}finally{if(a)throw o}}}}function Qn(e,t){if(!e)return;if(typeof e==="string")return Zn(e,t);var r=Object.prototype.toString.call(e).slice(8,-1);if(r==="Object"&&e.constructor)r=e.constructor.name;if(r==="Map"||r==="Set")return Array.from(e);if(r==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r))return Zn(e,t)}function Zn(e,t){if(t==null||t>e.length)t=e.length;for(var r=0,n=new Array(t);r1?r-1:0),i=1;i0&&arguments[0]!==undefined?arguments[0]:null;var t=Fs&&Fs.get("DEBUG",{throwError:false});if(e===null){return t===true}return(t===null||t===void 0?void 0:t.valueOf())===e.valueOf()}function li(e){return e?"(?:#".concat(e,"(?:#[ie])?|#[ie]#").concat(e,")"):"(?:#[ie])?"}function hi(e,t){return"".concat(li(e),"[+-]?").concat(t,"+/").concat(t,"+")}function pi(e,t){return"".concat(li(e),"(?:[+-]?(?:").concat(t,"+/").concat(t,"+|nan.0|inf.0|").concat(t,"+))?(?:[+-]i|[+-]?(?:").concat(t,"+/").concat(t,"+|").concat(t,"+|nan.0|inf.0)i)(?=[()[\\]\\s]|$)")}function _i(e,t){return"".concat(li(e),"[+-]?").concat(t,"+")}var di=/^#\/((?:\\\/|[^/]|\[[^\]]*\/[^\]]*\])+)\/([gimyus]*)$/;var vi="(?:[-+]?(?:[0-9]+(?:[eE][-+]?[0-9]+)|(?:\\.[0-9]+|[0-9]+\\.[0-9]+)(?:[eE][-+]?[0-9]+)?)|[0-9]+\\.)";var yi="(?:#[ie])?(?:[+-]?(?:[0-9]+/[0-9]+|nan.0|inf.0|".concat(vi,"|[+-]?[0-9]+))?(?:").concat(vi,"|[+-](?:[0-9]+/[0-9]+|[0-9]+|nan.0|inf.0))i");var mi=new RegExp("^(#[ie])?".concat(vi,"$"),"i");function gi(e,t){var r=e==="x"?"(?!\\+|".concat(t,")"):"(?!\\.|".concat(t,")");var n="";if(e===""){n="(?:[-+]?(?:[0-9]+(?:[eE][-+]?[0-9]+)|(?:\\.[0-9]+|[0-9]+\\.[0-9]+(?![0-9]))(?:[eE][-+]?[0-9]+)?))"}return new RegExp("^((?:(?:".concat(n,"|[-+]?inf.0|[-+]?nan.0|[+-]?").concat(t,"+/").concat(t,"+(?!").concat(t,")|[+-]?").concat(t,"+)").concat(r,")?)(").concat(n,"|[-+]?inf.0|[-+]?nan.0|[+-]?").concat(t,"+/").concat(t,"+|[+-]?").concat(t,"+|[+-])i$"),"i")}var bi=function(){var u={};[[10,"","[0-9]"],[16,"x","[0-9a-fA-F]"],[8,"o","[0-7]"],[2,"b","[01]"]].forEach(function(e){var t=b(e,3),r=t[0],n=t[1],i=t[2];u[r]=gi(n,i)});return u}();var wi={alarm:"",backspace:"\b",delete:"",escape:"",newline:"\n",null:"\0",return:"\r",space:" ",tab:"\t",dle:"",soh:"",dc1:"",stx:"",dc2:"",etx:"",dc3:"",eot:"",dc4:"",enq:"",nak:"",ack:"",syn:"",bel:"",etb:"",bs:"\b",can:"",ht:"\t",em:"",lf:"\n",sub:"",vt:"\v",esc:"",ff:"\f",fs:"",cr:"\r",gs:"",so:"",rs:"",si:"",us:"",del:""};function Di(e){var t=[];var r=0;var n=e.length;while(r=55296&&i<=56319&&r1&&arguments[1]!==undefined?arguments[1]:10;var r=Ri(e);var n=r.number.split("/");var i=E({num:B([n[0],r.radix||t]),denom:B([n[1],r.radix||t])});if(r.inexact){return i.valueOf()}else{return i}}function Li(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:10;var r=Ri(e);if(r.inexact){return g(parseInt(r.number,r.radix||t))}return B([r.number,r.radix||t])}function Mi(e){var t=e.match(/#\\x([0-9a-f]+)$/i);var r;if(t){var n=parseInt(t[1],16);r=String.fromCodePoint(n)}else{t=e.match(/#\\([\s\S]+)$/);if(t){r=t[1]}}if(r){return h(r)}throw new Error("Parse: invalid character")}function Ui(e){var i=arguments.length>1&&arguments[1]!==undefined?arguments[1]:10;function t(e){var t;if(e==="+"){t=B(1)}else if(e==="-"){t=B(-1)}else if(e.match(Bi)){t=B([e,i])}else if(e.match(ji)){var r=e.split("/");t=E({num:B([r[0],i]),denom:B([r[1],i])})}else if(e.match(mi)){var n=Vi(e);if(u.exact){return n.toRational()}return n}else if(e.match(/nan.0$/)){return B(NaN)}else if(e.match(/inf.0$/)){if(e[0]==="-"){return B(Number.NEGATIVE_INFINITY)}return B(Number.POSITIVE_INFINITY)}else{throw new Error("Internal Parser Error")}if(u.inexact){return g(t.valueOf())}return t}var u=Ri(e);i=u.radix||i;var r;var n=u.number.match(Pi);if(i!==10&&n){r=n}else{r=u.number.match(bi[i])}var a,o;o=t(r[2]);if(r[1]){a=t(r[1])}else{a=B(0)}if(o.cmp(0)===0&&o.__type__==="bigint"){return a}return m({im:o,re:a})}function qi(e){return parseInt(e.toString(),10)===e}function zi(e){var t=e.match(/^(([-+]?[0-9]*)(?:\.([0-9]+))?)e([-+]?[0-9]+)/i);if(t){var r=parseInt(t[4],10);var n;var i=t[1].replace(/[-+]?([0-9]*)\..+$/,"$1").length;var u=t[3]&&t[3].length;if(i0&&(t.exact||!t.number.match(/\./))){return B(u).mul(o)}}}r=g(r);if(t.exact){return r.toRational()}return r}function $i(e){e=e.replace(/\\x([0-9a-f]+);/gi,function(e,t){return"\\u"+t.padStart(4,"0")}).replace(/\n/g,"\\n");var t=e.match(/(\\*)(\\x[0-9A-F])/i);if(t&&t[1].length%2===0){throw new Error("Invalid string literal, unclosed ".concat(t[2]))}try{var r=D(JSON.parse(e));r.freeze();return r}catch(e){var n=e.message.replace(/in JSON /,"").replace(/.*Error: /,"");throw new Error("Invalid string literal: ".concat(n))}}function Ji(e){if(e.match(/^\|.*\|$/)){e=e.replace(/(^\|)|(\|$)/g,"");var r={t:"\t",r:"\r",n:"\n"};e=e.replace(/\\(x[^;]+);/g,function(e,t){return String.fromCharCode(parseInt("0"+t,16))}).replace(/\\(.)/g,function(e,t){return r[t]||t})}return new Y(e)}function Ki(e){if(xs.hasOwnProperty(e)){return xs[e]}if(e.match(/^"[\s\S]*"$/)){return $i(e)}else if(e[0]==="#"){var t=e.match(di);if(t){return new RegExp(t[1],t[2])}else if(e.match(xi)){return Mi(e)}var r=e.match(/#\\(.+)/);if(r&&Di(r[1]).length===1){return Mi(e)}}if(e.match(/[0-9a-f]|[+-]i/i)){if(e.match(Si)){return Li(e)}else if(e.match(mi)){return Vi(e)}else if(e.match(Oi)){return Ti(e)}else if(e.match(Ci)){return Ui(e)}}if(e.match(/^#[iexobd]/)){throw new Error("Invalid numeric constant: "+e)}return Ji(e)}function Hi(e){return!(["(",")","[","]"].includes(e)||_u.names().includes(e))}function Wi(e){return Hi(e)&&!(e.match(di)||e.match(/^"[\s\S]*"$/)||e.match(Si)||e.match(mi)||e.match(Ci)||e.match(Oi)||e.match(xi)||["#t","#f","nil"].includes(e))}var Gi=/"(?:\\[\S\s]|[^"])*"?/g;function Qi(e){if(typeof e==="string"){var t=/([-\\^$[\]()+{}?*.|])/g;return e.replace(t,"\\$1")}return e}function Zi(){this.data=[]}Zi.prototype.push=function(e){this.data.push(e)};Zi.prototype.top=function(){return this.data[this.data.length-1]};Zi.prototype.pop=function(){return this.data.pop()};Zi.prototype.is_empty=function(){return!this.data.length};function Xi(e){if(e instanceof D){e=e.valueOf()}var t=new s(e,{whitespace:true});var r=[];while(true){var n=t.peek(true);if(n===ls){break}r.push(n);t.skip()}return r}function eu(e){var t=e.token,r=he(e,Un);if(t.match(/^"[\s\S]*"$/)&&t.match(/\n/)){var n=new RegExp("^ {1,"+(e.col+1)+"}","mg");t=t.replace(n,"")}return q({token:t},r)}function tu(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:function(){};this.fn=e;this.cont=t}tu.prototype.toString=function(){return"#"};function ru(n){return function(){for(var e=arguments.length,t=new Array(e),r=0;r1&&arguments[1]!==undefined?arguments[1]:false;if(e instanceof D){e=e.toString()}if(t){return Xi(e)}else{var r=Xi(e).map(function(e){if(e.token==="#\\ "||e.token=="#\\\n"){return e.token}return e.token.trim()}).filter(function(e){return e&&!e.match(/^;/)&&!e.match(/^#\|[\s\S]*\|#$/)});return uu(r)}}function uu(e){var t=0;var r=null;var n=[];for(var i=0;i0&&arguments[0]!==undefined?arguments[0]:null;if(e instanceof Y){if(e.is_gensym()){return e}e=e.valueOf()}if(su(e)){return Y(e)}if(e!==null){return r(e,Symbol("#:".concat(e)))}t++;return r(t,Symbol("#:g".concat(t)))}}();function fu(e){var r=this;var n={pending:true,rejected:false,fulfilled:false,reason:undefined,type:undefined};e=e.then(function(e){n.type=Ys(e);n.fulfilled=true;n.pending=false;return e});f(this,"_promise",e,{hidden:true});if(d(e["catch"])){e=e["catch"](function(e){n.rejected=true;n.pending=false;n.reason=e})}Object.keys(n).forEach(function(t){Object.defineProperty(r,"__".concat(t,"__"),{enumerable:true,get:function e(){return n[t]}})});f(this,"__promise__",e);this.then=false}fu.prototype.then=function(e){return new fu(this.valueOf().then(e))};fu.prototype["catch"]=function(e){return new fu(this.valueOf()["catch"](e))};fu.prototype.valueOf=function(){if(!this._promise){throw new Error("QuotedPromise: invalid promise created")}return this._promise};fu.prototype.toString=function(){if(this.__pending__){return fu.pending_str}if(this.__rejected__){return fu.rejected_str}return"#")};fu.pending_str="#";fu.rejected_str="#";function lu(e){if(Array.isArray(e)){return Promise.all(hu(e)).then(pu)}return e}function hu(e){var t=new Array(e.length),r=e.length;while(r--){var n=e[r];if(n instanceof fu){t[r]=new vs(n)}else{t[r]=n}}return t}function pu(e){var t=new Array(e.length),r=e.length;while(r--){var n=e[r];if(n instanceof vs){t[r]=n.valueOf()}else{t[r]=n}}return t}var _u={LITERAL:Symbol["for"]("literal"),SPLICE:Symbol["for"]("splice"),SYMBOL:Symbol["for"]("symbol"),names:function e(){return Object.keys(this.__list__)},type:function e(t){try{return this.get(t).type}catch(e){console.log({name:t});console.log(e);return null}},get:function e(t){return this.__list__[t]},off:function e(t){var r=this;var n=arguments.length>1&&arguments[1]!==undefined?arguments[1]:null;if(Array.isArray(t)){t.forEach(function(e){return r.off(e,n)})}else if(n===null){delete this.__events__[t]}else{this.__events__=this.__events__.filter(function(e){return e!==n})}},on:function e(t,r){var n=this;if(Array.isArray(t)){t.forEach(function(e){return n.on(e,r)})}else if(!this.__events__[t]){this.__events__[t]=[r]}else{this.__events__[t].push(r)}},trigger:function e(t){for(var r=arguments.length,n=new Array(r>1?r-1:0),i=1;i",new Y("quote-promise"),_u.LITERAL]];var bu=gu.map(function(e){return e[0]});Object.freeze(bu);Object.defineProperty(_u,"__builtins__",{writable:false,value:bu});gu.forEach(function(e){var t=b(e,3),r=t[0],n=t[1],i=t[2];_u.append(r,n,i)});var s=function(){function p(e){var t=this;var r=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},n=r.whitespace,i=n===void 0?false:n;ue(this,p);f(this,"__input__",e.replace(/\r/g,""));var u={};["_i","_whitespace","_col","_newline","_line","_state","_next","_token","_prev_char"].forEach(function(r){Object.defineProperty(t,r,{configurable:false,enumerable:false,get:function e(){return u[r]},set:function e(t){u[r]=t}})});this._whitespace=i;this._i=this._line=this._col=this._newline=0;this._state=this._next=this._token=null;this._prev_char=""}ce(p,[{key:"get",value:function e(t){return this.__internal[t]}},{key:"set",value:function e(t,r){this.__internal[t]=r}},{key:"token",value:function e(){var t=arguments.length>0&&arguments[0]!==undefined?arguments[0]:false;if(t){var r=this._line;if(this._whitespace&&this._token==="\n"){--r}return{token:this._token,col:this._col,offset:this._i,line:r}}return this._token}},{key:"peek",value:function e(){var t=arguments.length>0&&arguments[0]!==undefined?arguments[0]:false;if(this._i>=this.__input__.length){return ls}if(this._token){return this.token(t)}var r=this.next_token();if(r){this._token=this.__input__.substring(this._i,this._next);return this.token(t)}return ls}},{key:"skip",value:function e(){if(this._next!==null){this._token=null;this._i=this._next}}},{key:"read_line",value:function e(){var t=this.__input__.length;if(this._i>=t){return ls}for(var r=this._i;r=r){return ls}if(t+this._i>=r){return this.read_rest()}var n=this._i+t;var i=this.__input__.substring(this._i,n);var u=i.match(/\n/g);if(u){this._line+=u.length}this._i=n;return i}},{key:"peek_char",value:function e(){if(this._i>=this.__input__.length){return ls}return h(this.__input__[this._i])}},{key:"read_char",value:function e(){var t=this.peek_char();this.skip_char();return t}},{key:"skip_char",value:function e(){if(this._i1&&arguments[1]!==undefined?arguments[1]:{},n=r.prev_char,i=r["char"],u=r.next_char;var a=b(t,4),o=a[0],s=a[1],c=a[2],f=a[3];if(t.length!==5){throw new Error("Lexer: Invalid rule of length ".concat(t.length))}if(!i.match(o)){return false}if(!wu(s,n)){return false}if(!wu(c,u)){return false}if(f!==this._state){return false}return true}},{key:"next_token",value:function e(){if(this._i>=this.__input__.length){return false}var t=true;e:for(var r=this._i,n=this.__input__.length;r2&&arguments[2]!==undefined?arguments[2]:null;var i=arguments.length>3&&arguments[3]!==undefined?arguments[3]:null;if(t.length===0){throw new Error("Lexer: invalid literal rule")}if(t.length===1){return[[t,n,i,null,null]]}var u=[];for(var a=0,o=t.length;a1&&arguments[1]!==undefined?arguments[1]:{},r=t.env,n=t.meta,i=n===void 0?false:n,u=t.formatter,a=u===void 0?eu:u;ue(this,o);if(e instanceof D){e=e.toString()}f(this,"_formatter",a,{hidden:true});f(this,"__lexer__",new s(e));f(this,"__env__",r);f(this,"_meta",i,{hidden:true});f(this,"_refs",[],{hidden:true});f(this,"_state",{parentheses:0},{hidden:true})}ce(o,[{key:"resolve",value:function e(t){return this.__env__&&this.__env__.get(t,{throwError:false})}},{key:"peek",value:function(){var e=ie(C.mark(function e(){var r;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:r=this.__lexer__.peek(true);if(!(r===ls)){t.next=4;break}return t.abrupt("return",ls);case 4:if(!this.is_comment(r.token)){t.next=7;break}this.skip();return t.abrupt("continue",0);case 7:if(!(r.token==="#;")){t.next=14;break}this.skip();if(!(this.__lexer__.peek()===ls)){t.next=11;break}throw new Error("Lexer: syntax error eof found after comment");case 11:t.next=13;return this._read_object();case 13:return t.abrupt("continue",0);case 14:return t.abrupt("break",17);case 17:r=this._formatter(r);if(!this._meta){t.next=20;break}return t.abrupt("return",r);case 20:return t.abrupt("return",r.token);case 21:case"end":return t.stop()}},e,this)}));function t(){return e.apply(this,arguments)}return t}()},{key:"reset",value:function e(){this._refs.length=0}},{key:"skip",value:function e(){this.__lexer__.skip()}},{key:"read",value:function(){var e=ie(C.mark(function e(){var r;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:t.next=2;return this.peek();case 2:r=t.sent;this.skip();return t.abrupt("return",r);case 5:case"end":return t.stop()}},e,this)}));function t(){return e.apply(this,arguments)}return t}()},{key:"match_datum_label",value:function e(t){var r=t.match(/^#([0-9]+)=$/);return r&&r[1]}},{key:"match_datum_ref",value:function e(t){var r=t.match(/^#([0-9]+)#$/);return r&&r[1]}},{key:"is_open",value:function e(t){var r=["(","["].includes(t);if(r){this._state.parentheses++}return r}},{key:"is_close",value:function e(t){var r=[")","]"].includes(t);if(r){this._state.parentheses--}return r}},{key:"read_list",value:function(){var e=ie(C.mark(function e(){var r,n,i,u,a;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:r=V,n=r;case 1:t.next=4;return this.peek();case 4:u=t.sent;if(!(u===ls)){t.next=7;break}return t.abrupt("break",32);case 7:if(!this.is_close(u)){t.next=10;break}this.skip();return t.abrupt("break",32);case 10:if(!(u==="."&&!K(r))){t.next=18;break}this.skip();t.next=14;return this._read_object();case 14:n.cdr=t.sent;i=true;t.next=30;break;case 18:if(!i){t.next=22;break}throw new Error("Parser: syntax error more than one element after dot");case 22:t.t0=$;t.next=25;return this._read_object();case 25:t.t1=t.sent;t.t2=V;a=new t.t0(t.t1,t.t2);if(K(r)){r=a}else{n.cdr=a}n=a;case 30:t.next=1;break;case 32:return t.abrupt("return",r);case 33:case"end":return t.stop()}},e,this)}));function t(){return e.apply(this,arguments)}return t}()},{key:"read_value",value:function(){var e=ie(C.mark(function e(){var r;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:t.next=2;return this.read();case 2:r=t.sent;if(!(r===ls)){t.next=5;break}throw new Error("Parser: Expected token eof found");case 5:return t.abrupt("return",Ki(r));case 6:case"end":return t.stop()}},e,this)}));function t(){return e.apply(this,arguments)}return t}()},{key:"is_comment",value:function e(t){return t.match(/^;/)||t.match(/^#\|/)&&t.match(/\|#$/)}},{key:"evaluate",value:function e(t){return k(t,{env:this.__env__,error:function e(t){throw t}})}},{key:"read_object",value:function(){var e=ie(C.mark(function e(){var r;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:this.reset();t.next=3;return this._read_object();case 3:r=t.sent;if(r instanceof Eu){r=r.valueOf()}if(!this._refs.length){t.next=7;break}return t.abrupt("return",this._resolve_object(r));case 7:return t.abrupt("return",r);case 8:case"end":return t.stop()}},e,this)}));function t(){return e.apply(this,arguments)}return t}()},{key:"balanced",value:function e(){return this._state.parentheses===0}},{key:"ballancing_error",value:function e(t,r){var n=this._state.parentheses;var i;if(n<0){i=new Error("Parser: unexpected parenthesis");i.__code__=[r.toString()+")"]}else{i=new Error("Parser: expected parenthesis but eof found");var u=new RegExp("\\){".concat(n,"}$"));i.__code__=[t.toString().replace(u,"")]}throw i}},{key:"_resolve_object",value:function(){var t=ie(C.mark(function e(r){var n=this;var i;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(!Array.isArray(r)){t.next=2;break}return t.abrupt("return",r.map(function(e){return n._resolve_object(e)}));case 2:if(!ua(r)){t.next=6;break}i={};Object.keys(r).forEach(function(e){i[e]=n._resolve_object(r[e])});return t.abrupt("return",i);case 6:if(!H(r)){t.next=8;break}return t.abrupt("return",this._resolve_pair(r));case 8:return t.abrupt("return",r);case 9:case"end":return t.stop()}},e,this)}));function e(e){return t.apply(this,arguments)}return e}()},{key:"_resolve_pair",value:function(){var t=ie(C.mark(function e(r){return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(!H(r)){t.next=15;break}if(!(r.car instanceof Eu)){t.next=7;break}t.next=4;return r.car.valueOf();case 4:r.car=t.sent;t.next=8;break;case 7:this._resolve_pair(r.car);case 8:if(!(r.cdr instanceof Eu)){t.next=14;break}t.next=11;return r.cdr.valueOf();case 11:r.cdr=t.sent;t.next=15;break;case 14:this._resolve_pair(r.cdr);case 15:return t.abrupt("return",r);case 16:case"end":return t.stop()}},e,this)}));function e(e){return t.apply(this,arguments)}return e}()},{key:"_read_object",value:function(){var e=ie(C.mark(function e(){var r,n,i,u,a,o,s,c,f,l,h;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:t.next=2;return this.peek();case 2:r=t.sent;if(!(r===ls)){t.next=5;break}return t.abrupt("return",r);case 5:if(!du(r)){t.next=38;break}n=_u.get(r);i=vu(r);this.skip();a=mu(r);if(!a){t.next=14;break}t.t0=undefined;t.next=17;break;case 14:t.next=16;return this._read_object();case 16:t.t0=t.sent;case 17:o=t.t0;if(i){t.next=25;break}s=this.__env__.get(n.symbol);if(!(typeof s==="function")){t.next=25;break}if(yu(r)){c=[o]}else if(K(o)){c=[]}else if(H(o)){c=o.to_array(false)}if(!(c||a)){t.next=24;break}return t.abrupt("return",Ws(s,a?[]:c,{env:this.__env__,dynamic_env:this.__env__,use_dynamic:false}));case 24:throw new Error("Parse Error: Invalid parser extension "+"invocation ".concat(n.symbol));case 25:if(yu(r)){u=new $(n.symbol,new $(o,V))}else{u=new $(n.symbol,o)}if(!i){t.next=28;break}return t.abrupt("return",u);case 28:if(!(s instanceof J)){t.next=37;break}t.next=31;return this.evaluate(u);case 31:f=t.sent;if(!(H(f)||f instanceof Y)){t.next=34;break}return t.abrupt("return",$.fromArray([Y("quote"),f]));case 34:return t.abrupt("return",f);case 37:throw new Error("Parse Error: invalid parser extension: "+n.symbol);case 38:l=this.match_datum_ref(r);if(!(l!==null)){t.next=44;break}this.skip();if(!this._refs[l]){t.next=43;break}return t.abrupt("return",new Eu(l,this._refs[l]));case 43:throw new Error("Parse Error: invalid datum label #".concat(l,"#"));case 44:h=this.match_datum_label(r);if(!(h!==null)){t.next=51;break}this.skip();this._refs[h]=this._read_object();return t.abrupt("return",this._refs[h]);case 51:if(!this.is_close(r)){t.next=55;break}this.skip();t.next=61;break;case 55:if(!this.is_open(r)){t.next=60;break}this.skip();return t.abrupt("return",this.read_list());case 60:return t.abrupt("return",this.read_value());case 61:case"end":return t.stop()}},e,this)}));function t(){return e.apply(this,arguments)}return t}()}]);return o}();var Eu=function(){function r(e,t){ue(this,r);this.name=e;this.data=t}ce(r,[{key:"valueOf",value:function e(){return this.data}}]);return r}();function Au(e,t){return xu.apply(this,arguments)}function xu(){xu=ge(C.mark(function e(r,n){var i,u,a;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(!n){if(W){n=W.get("**interaction-environment**",{throwError:false})}else{n=Fs}}i=new Du(r,{env:n});case 3:t.next=6;return ye(i.read_object());case 6:a=t.sent;if(!i.balanced()){i.ballancing_error(a,u)}if(!(a===ls)){t.next=10;break}return t.abrupt("break",15);case 10:u=a;t.next=13;return a;case 13:t.next=3;break;case 15:case"end":return t.stop()}},e)}));return xu.apply(this,arguments)}function w(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:function(e){return e};var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:null;if(za(e)){var n=e.then(t);if(r===null){return n}else{return n["catch"](r)}}if(e instanceof Array){return Fu(e,t,r)}if(ua(e)){return ku(e,t,r)}return t(e)}function Fu(t,r,e){if(t.find(za)){return w(lu(t),function(e){if(Object.isFrozen(t)){Object.freeze(e)}return r(e)},e)}return r(t)}function ku(t,e,r){var i=Object.keys(t);var n=[],u=[];var a=i.length;while(a--){var o=i[a];var s=t[o];n[a]=s;if(za(s)){u.push(s)}}if(u.length){return w(lu(n),function(e){var n={};e.forEach(function(e,t){var r=i[t];n[r]=e});if(Object.isFrozen(t)){Object.freeze(n)}return n},r)}return e(t)}function f(e,t,r){var n=arguments.length>3&&arguments[3]!==undefined?arguments[3]:{},i=n.hidden,u=i===void 0?false:i;Object.defineProperty(e,t,{value:r,configurable:true,enumerable:!u})}function Cu(e){return Ou.apply(this,arguments)}function Ou(){Ou=ie(C.mark(function e(r){var n,i,u,a,o,s,c;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:n=[];i=false;u=false;t.prev=3;o=ei(r);case 5:t.next=7;return o.next();case 7:if(!(i=!(s=t.sent).done)){t.next=13;break}c=s.value;n.push(c);case 10:i=false;t.next=5;break;case 13:t.next=19;break;case 15:t.prev=15;t.t0=t["catch"](3);u=true;a=t.t0;case 19:t.prev=19;t.prev=20;if(!(i&&o["return"]!=null)){t.next=24;break}t.next=24;return o["return"]();case 24:t.prev=24;if(!u){t.next=27;break}throw a;case 27:return t.finish(24);case 28:return t.finish(19);case 29:return t.abrupt("return",n);case 30:case"end":return t.stop()}},e,null,[[3,15,19,29],[20,,24,28]])}));return Ou.apply(this,arguments)}function Su(e,t){if(t instanceof RegExp){return function(e){return String(e).match(t)}}else if(d(t)){return t}throw new Error("Invalid matcher")}function l(e,t,r,n){if(typeof e!=="string"){t=arguments[0];r=arguments[1];n=arguments[2];e=null}if(r){if(n){t.__doc__=r}else{t.__doc__=Bu(r)}}if(e){t.__name__=e}else if(t.name&&!bo(t)){t.__name__=t.name}return t}function Bu(e){return e.split("\n").map(function(e){return e.trim()}).join("\n")}function ju(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:1;var r=e.length;if(t<=0){throw Error("previousSexp: Invalid argument sexp = ".concat(t))}e:while(t--&&r>=0){var n=1;while(n>0){var i=e[--r];if(!i){break e}if(i==="("||i.token==="("){n--}else if(i===")"||i.token===")"){n++}}r--}return e.slice(r+1)}function Iu(e){if(!e||!e.length){return 0}var t=e.length;if(e[t-1].token==="\n"){return 0}while(--t){if(e[t].token==="\n"){var r=(e[t+1]||{}).token;if(r){return r.length}}}return 0}function Pu(e,t){return f(e,t)===t.length;function f(r,n){function e(e,t){var r=Gn(e),n;try{for(r.s();!(n=r.n()).done;){var i=n.value;var u=f(i,t);if(u!==-1){return u}}}catch(e){r.e(e)}finally{r.f()}return-1}function t(){return r[u]===Symbol["for"]("symbol")&&!Wi(n[o])}function i(){var e=r[u+1];var t=n[o+1];if(e!==undefined&&t!==undefined){return f([e],[t])}}var u=0;var a={};for(var o=0;o0){continue}}else if(t()){return-1}}else if(r[u]instanceof Array){var c=f(r[u],n.slice(o));if(c===-1||c+o>n.length){return-1}o+=c-1;u++;continue}else{return-1}u++}if(r.length!==u){return-1}return n.length}}function Nu(e){this.__code__=e.replace(/\r/g,"")}Nu.defaults={offset:0,indent:2,exceptions:{specials:[/^(?:#:)?(?:define(?:-values|-syntax|-macro|-class|-record-type)?|(?:call-with-(?:input-file|output-file|port))|lambda|let-env|try|catch|when|unless|while|syntax-rules|(let|letrec)(-syntax|\*?-values|\*)?)$/],shift:{1:["&","#"]}}};Nu.match=Pu;Nu.prototype._options=function e(t){var r=Nu.defaults;if(typeof t==="undefined"){return Object.assign({},r)}var n=t&&t.exceptions||{};var i=n.specials||[];var u=n.shift||{1:[]};return q(q(q({},r),t),{},{exceptions:{specials:[].concat(U(r.exceptions.specials),U(i)),shift:q(q({},u),{},{1:[].concat(U(r.exceptions.shift[1]),U(u[1]))})}})};Nu.prototype.indent=function e(t){var r=iu(this.__code__,true);return this._indent(r,t)};Nu.exception_shift=function(u,e){function t(e){if(!e.length){return false}if(e.indexOf(u)!==-1){return true}else{var t=e.filter(function(e){return e instanceof RegExp});if(!t.length){return false}var r=Gn(t),n;try{for(r.s();!(n=r.n()).done;){var i=n.value;if(u.match(i)){return true}}}catch(e){r.e(e)}finally{r.f()}}return false}if(t(e.exceptions.specials)){return e.indent}var r=e.exceptions.shift;for(var n=0,i=Object.entries(r);n0){n.offset=0}if(u.toString()===t.toString()&&ac(u)){return n.offset+u[0].col}else if(u.length===1){return n.offset+u[0].col+1}else{var s=-1;if(a){var c=Nu.exception_shift(a.token,n);if(c!==-1){s=c}}if(s===-1){s=Nu.exception_shift(u[1].token,n)}if(s!==-1){return n.offset+u[0].col+s}else if(u[0].line3&&u[1].line===u[3].line){if(u[1].token==="("||u[1].token==="["){return n.offset+u[1].col}return n.offset+u[3].col}else if(u[0].line===u[1].line){return n.offset+n.indent+u[0].col}else{var f=u.slice(2);for(var l=0;l")};Ru.prototype.match=function(e){return e.match(this.pattern)};function Tu(){for(var e=arguments.length,t=new Array(e),r=0;r")};Nu.Pattern=Tu;Nu.Ahead=Ru;var Lu=/^[[(]$/;var Mu=/^[\])]$/;var Uu=/[^()[\]]/;var qu=new Ru(/[^)\]]/);var zu=Symbol["for"]("*");var Yu=new Tu([Lu,zu,Mu],[Uu],"+");var Vu=new Tu([Lu,zu,Mu],"+");var $u=new Tu([Symbol["for"]("symbol")],"?");var Ju=new Tu([Symbol["for"]("symbol")],"*");var Ku=[Lu,Ju,Mu];var Hu=new Tu([Lu,Symbol["for"]("symbol"),zu,Mu],"+");var Wu=Xu("syntax-rules");var Gu=Xu("define","lambda","define-macro","syntax-rules");var Qu=/^(?!.*\b(?:[()[\]]|define(?:-macro)?|let(?:\*|rec|-env|-syntax|)?|lambda|syntax-rules)\b).*$/;var Zu=/^(?:#:)?(let(?:\*|rec|-env|-syntax)?)$/;function Xu(){for(var e=arguments.length,t=new Array(e),r=0;r0&&!o[e]){o[e]=ju(a,e)}});var s=Gn(i),c;try{for(s.s();!(c=s.n()).done;){var f=b(c.value,3),l=f[0],h=f[1],p=f[2];h=h.valueOf();var _=h>0?o[h]:a;var d=_.filter(function(e){return e.trim()&&!du(e)});var v=r(_);var y=Pu(l,d);var m=n.slice(u).find(function(e){return e.trim()&&!du(e)});if(y&&(p instanceof Ru&&p.match(m)||!p)){var g=u-v;if(n[g]!=="\n"){if(!n[g].trim()){n[g]="\n"}else{n.splice(g,0,"\n");u++}}u+=v;continue e}}}catch(e){s.e(e)}finally{s.f()}}this.__code__=n.join("");return this};Nu.prototype._spaces=function(e){return" ".repeat(e)};Nu.prototype.format=function e(t){var r=this.__code__.replace(/[ \t]*\n[ \t]*/g,"\n ");var n=iu(r,true);var i=this._options(t);var u=0;var a=0;for(var o=0;o0){n=Math.floor(t()*r);r--;var i=[e[n],e[r]];e[r]=i[0];e[n]=i[1]}return e}function ra(){}ra.prototype.toString=function(){return"()"};ra.prototype.valueOf=function(){return undefined};ra.prototype.serialize=function(){return 0};ra.prototype.to_object=function(){return{}};ra.prototype.append=function(e){return new $(e,V)};ra.prototype.to_array=function(){return[]};var V=new ra;function $(e,t){if(typeof this!=="undefined"&&this.constructor!==$||typeof this==="undefined"){return new $(e,t)}this.car=e;this.cdr=t}function na(u,a){return function e(t){F(u,t,["pair","nil"]);if(K(t)){return[]}var r=[];var n=t;while(true){if(H(n)){if(n.haveCycles("cdr")){break}var i=n.car;if(a&&H(i)){i=this.get(u).call(this,i)}r.push(i);n=n.cdr}else if(K(n)){break}else{throw new Error("".concat(u,": can't convert improper list"))}}return r}}$.prototype.flatten=function(){return $.fromArray(ea(this.to_array()))};$.prototype.length=function(){var e=0;var t=this;while(true){if(!t||K(t)||!H(t)||t.haveCycles("cdr")){break}e++;t=t.cdr}return e};$.match=function(e,t){if(e instanceof Y){return Y.is(e,t)}else if(H(e)){return $.match(e.car,t)||$.match(e.cdr,t)}else if(Array.isArray(e)){return e.some(function(e){return $.match(e,t)})}else if(ua(e)){return Object.values(e).some(function(e){return $.match(e,t)})}return false};$.prototype.find=function(e){return $.match(this,e)};$.prototype.clone=function(){var r=arguments.length>0&&arguments[0]!==undefined?arguments[0]:true;var n=new Map;function i(e){if(H(e)){if(n.has(e)){return n.get(e)}var t=new $;n.set(e,t);if(r){t.car=i(e.car)}else{t.car=e.car}t.cdr=i(e.cdr);t[fo]=e[fo];return t}return e}return i(this)};$.prototype.last_pair=function(){var e=this;while(true){if(!H(e.cdr)){return e}if(e.haveCycles("cdr")){break}e=e.cdr}};$.prototype.to_array=function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:true;var t=[];if(H(this.car)){if(e){t.push(this.car.to_array())}else{t.push(this.car)}}else{t.push(this.car.valueOf())}if(H(this.cdr)){t=t.concat(this.cdr.to_array(e))}return t};$.fromArray=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:true;var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:false;if(H(e)||r&&e instanceof Array&&e[so]){return e}if(t===false){var n=V;for(var i=e.length;i--;){n=new $(e[i],n)}return n}if(e.length&&!(e instanceof Array)){e=U(e)}var u=V;var a=e.length;while(a--){var o=e[a];if(o instanceof Array){o=$.fromArray(o,t,r)}else if(typeof o==="string"){o=D(o)}else if(typeof o==="number"&&!Number.isNaN(o)){o=B(o)}u=new $(o,u)}return u};$.prototype.to_object=function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:false;var t=this;var r={};while(true){if(H(t)&&H(t.car)){var n=t.car;var i=n.car;if(i instanceof Y){i=i.__name__}if(i instanceof D){i=i.valueOf()}var u=n.cdr;if(H(u)){u=u.to_object(e)}if(Ka(u)){if(!e){u=u.valueOf()}}r[i]=u;t=t.cdr}else{break}}return r};$.fromPairs=function(e){return e.reduce(function(e,t){return new $(new $(new Y(t[0]),t[1]),e)},V)};$.fromObject=function(t){var e=Object.keys(t).map(function(e){return[e,t[e]]});return $.fromPairs(e)};$.prototype.reduce=function(e){var t=this;var r=V;while(true){if(!K(t)){r=e(r,t.car);t=t.cdr}else{break}}return r};$.prototype.reverse=function(){if(this.haveCycles()){throw new Error("You can't reverse list that have cycles")}var e=this;var t=V;while(!K(e)){var r=e.cdr;e.cdr=t;t=e;e=r}return t};$.prototype.transform=function(n){function i(e){if(H(e)){if(e.replace){delete e.replace;return e}var t=n(e.car);if(H(t)){t=i(t)}var r=n(e.cdr);if(H(r)){r=i(r)}return new $(t,r)}return e}return i(this)};$.prototype.map=function(e){if(typeof this.car!=="undefined"){return new $(e(this.car),K(this.cdr)?V:this.cdr.map(e))}else{return V}};var ia=new Map;function ua(e){return e&&p(e)==="object"&&e.constructor===Object}var aa=Object.getOwnPropertyNames(Array.prototype);var oa=[];aa.forEach(function(e){oa.push(Array[e],Array.prototype[e])});function sa(e){e=Xa(e);return oa.includes(e)}function ca(e){return d(e)&&(bo(e)||e.__doc__)}function fa(r){var e=r.constructor||Object;var n=ua(r);var i=d(r[Symbol.asyncIterator])||d(r[Symbol.iterator]);var u;if(ia.has(e)){u=ia.get(e)}else{ia.forEach(function(e,t){t=Xa(t);if(r.constructor===t&&(t===Object&&n&&!i||t!==Object)){u=e}})}return u}var la=new Map;[[true,"#t"],[false,"#f"],[null,"null"],[undefined,"#"]].forEach(function(e){var t=b(e,2),r=t[0],n=t[1];la.set(r,n)});function ha(r){if(r&&p(r)==="object"){var n={};var e=Object.getOwnPropertySymbols(r);e.forEach(function(e){var t=e.toString().replace(/Symbol\(([^)]+)\)/,"$1");n[t]=ma(r[e])});var t=Object.getOwnPropertyNames(r);t.forEach(function(e){var t=r[e];if(t&&p(t)==="object"&&t.constructor===Object){n[e]=ha(t)}else{n[e]=ma(t)}});return n}return r}function pa(e){return Object.keys(e).concat(Object.getOwnPropertySymbols(e))}function _a(e,t){return e.hasOwnProperty(t)&&d(e.toString)}function da(e){if(Eo(e)){return"#"}var t=e.prototype&&e.prototype.constructor;if(d(t)&&bo(t)){if(e[lo]&&t.hasOwnProperty("__name__")){var r=t.__name__;if(D.isString(r)){r=r.toString();return"#")}return"#"}}if(e.hasOwnProperty("__name__")){var n=e.__name__;if(p(n)==="symbol"){n=ou(n)}if(typeof n==="string"){return"#")}}if(_a(e,"toString")){return e.toString()}else if(e.name&&!bo(e)){return"#")}else{return"#"}}var va=new Map;[[Error,function(e){return e.message}],[$,function(e,t){var r=t.quote,n=t.skip_cycles,i=t.pair_args;if(!n){e.markCycles()}return e.toString.apply(e,[r].concat(U(i)))}],[h,function(e,t){var r=t.quote;if(r){return e.toString()}return e.valueOf()}],[D,function(e,t){var r=t.quote;e=e.toString();if(r){return JSON.stringify(e).replace(/\\n/g,"\n")}return e}],[RegExp,function(e){return"#"+e.toString()}]].forEach(function(e){var t=b(e,2),r=t[0],n=t[1];va.set(r,n)});var ya=[Y,B,J,ys,Zo,Xo,x,fu];function ma(e,t,r){if(typeof jQuery!=="undefined"&&e instanceof jQuery.fn.init){return"#"}if(la.has(e)){return la.get(e)}if(ga(e)){return"#"}if(e){var n=e.constructor;if(va.has(n)){for(var i=arguments.length,u=new Array(i>3?i-3:0),a=3;a"}if(e===null){return"null"}if(p(e)==="object"){var f=e.constructor;if(!f){f=Object}var l;if(typeof f.__class__==="string"){l=f.__class__}else{var h=fa(e);if(h){if(d(h)){return h(e,t)}else{throw new Error("toString: Invalid repr value")}}l=f.name}if(d(e.toString)&&bo(e.toString)){return e.toString().valueOf()}if(Ys(e)==="instance"){if(bo(f)&&f.__name__){l=f.__name__.valueOf()}else if(!Eo(f)){l="instance"}}if(Va(e,Symbol.iterator)){if(l){return"#")}return"#"}if(Va(e,Symbol.asyncIterator)){if(l){return"#")}return"#"}if(l!==""){return"#<"+l+">"}return"#"}if(typeof e!=="string"){return e.toString()}return e}function ga(e){return e&&p(e)==="object"&&e.hasOwnProperty&&e.hasOwnProperty("constructor")&&typeof e.constructor==="function"&&e.constructor.prototype===e}$.prototype.markCycles=function(){ba(this);return this};$.prototype.haveCycles=function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:null;if(!e){return this.haveCycles("car")||this.haveCycles("cdr")}return!!(this[fo]&&this[fo][e])};function ba(e){var t=[];var i=[];var u=[];function a(e){if(!t.includes(e)){t.push(e)}}function o(e,t,r,n){if(H(r)){if(n.includes(r)){if(!u.includes(r)){u.push(r)}if(!e[fo]){e[fo]={}}e[fo][t]=r;if(!i.includes(e)){i.push(e)}return true}}}var s=ru(function e(t,r){if(H(t)){delete t.ref;delete t[fo];a(t);r.push(t);var n=o(t,"car",t.car,r);var i=o(t,"cdr",t.cdr,r);if(!n){s(t.car,r.slice())}if(!i){return new tu(function(){return e(t.cdr,r.slice())})}}});function r(e,t){if(H(e[fo][t])){var r=n.indexOf(e[fo][t]);e[fo][t]="#".concat(r,"#")}}s(e,[]);var n=t.filter(function(e){return u.includes(e)});n.forEach(function(e,t){e[co]="#".concat(t,"=")});i.forEach(function(e){r(e,"car");r(e,"cdr")})}$.prototype.toString=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},r=t.nested,n=r===void 0?false:r;var i=[];if(this[co]){i.push(this[co]+"(")}else if(!n){i.push("(")}var u;if(this[fo]&&this[fo].car){u=this[fo].car}else{u=ma(this.car,e,true)}if(u!==undefined){i.push(u)}if(H(this.cdr)){if(this[fo]&&this[fo].cdr){i.push(" . ");i.push(this[fo].cdr)}else{if(this.cdr[co]){i.push(" . ")}else{i.push(" ")}var a=this.cdr.toString(e,{nested:true});i.push(a)}}else if(!K(this.cdr)){i=i.concat([" . ",ma(this.cdr,e,true)])}if(!n||this[co]){i.push(")")}return i.join("")};$.prototype.set=function(e,t){this[e]=t;if(H(t)){this.markCycles()}};$.prototype.append=function(e){if(e instanceof Array){return this.append($.fromArray(e))}var t=this;if(t.car===undefined){if(H(e)){this.car=e.car;this.cdr=e.cdr}else{this.car=e}}else if(!K(e)){while(true){if(H(t)&&!K(t.cdr)){t=t.cdr}else{break}}t.cdr=e}return this};$.prototype.serialize=function(){return[this.car,this.cdr]};$.prototype[Symbol.iterator]=function(){var r=this;return{next:function e(){var t=r;r=t.cdr;if(K(t)){return{value:undefined,done:true}}else{return{value:t.car,done:false}}}}};function wa(e){return e<0?-e:e}function Da(e,t){var r=re(t),n=r[0],i=r.slice(1);while(i.length>0){var u=i,a=b(u,1),o=a[0];if(!e(n,o)){return false}var s=i;var c=re(s);n=c[0];i=c.slice(1)}return true}function Ea(e,t){if(d(e)){return d(t)&&Xa(e)===Xa(t)}else if(e instanceof B){if(!(t instanceof B)){return false}var r;if(e.__type__===t.__type__){if(e.__type__==="complex"){r=e.__im__.__type__===t.__im__.__type__&&e.__re__.__type__===t.__re__.__type__}else{r=true}if(r&&e.cmp(t)===0){if(e.valueOf()===0){return Object.is(e.valueOf(),t.valueOf())}return true}}return false}else if(typeof e==="number"){if(typeof t!=="number"){return false}if(Number.isNaN(e)){return Number.isNaN(t)}if(e===Number.NEGATIVE_INFINITY){return t===Number.NEGATIVE_INFINITY}if(e===Number.POSITIVE_INFINITY){return t===Number.POSITIVE_INFINITY}return Ea(B(e),B(t))}else if(e instanceof h){if(!(t instanceof h)){return false}return e.__char__===t.__char__}else{return e===t}}function Aa(e,t){if(Ys(e)!==Ys(t)){return false}if(!xa(e)){return false}if(e instanceof RegExp){return e.source===t.source}if(e instanceof D){return e.valueOf()===t.valueOf()}return Ea(e,t)}function xa(e){return e instanceof Y||D.isString(e)||K(e)||e===null||e instanceof h||e instanceof B||e===true||e===false}var Fa=function(){if(Math.trunc){return Math.trunc}else{return function(e){if(e===0){return 0}else if(e<0){return Math.ceil(e)}else{return Math.floor(e)}}}}();function J(e,t,r,n){if(typeof this!=="undefined"&&this.constructor!==J||typeof this==="undefined"){return new J(e,t)}F("Macro",e,"string",1);F("Macro",t,"function",2);if(r){if(n){this.__doc__=r}else{this.__doc__=Bu(r)}}this.__name__=e;this.__fn__=t}J.defmacro=function(e,t,r,n){var i=new J(e,t,r,n);i.__defmacro__=true;return i};J.prototype.invoke=function(e,t,r){var n=t.env,i=he(t,qn);var u=q(q({},i),{},{macro_expand:r});var a=this.__fn__.call(n,e,u,this.__name__);return a};J.prototype.toString=function(){return"#")};var ka="define-macro";var Ca=-1e4;function Oa(c){return function(){var r=ie(C.mark(function e(r,m){var u,g,n,i,a,b,w,D,E,A,x,F,o,k,s;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:s=function e(){s=ie(C.mark(function e(r,n,i){var u,a,o,s,c,f,l,h,p,_,d,v,y;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(!(H(r)&&r.car instanceof Y)){t.next=50;break}if(!r[so]){t.next=3;break}return t.abrupt("return",r);case 3:u=r.car.valueOf();a=i.get(r.car,{throwError:false});o=b(r.car);s=o||w(a,r)||D(a);if(!(s&&H(r.cdr.car))){t.next=28;break}if(!o){t.next=15;break}g=A(r.cdr.car);t.next=12;return F(r.cdr.car,n);case 12:c=t.sent;t.next=17;break;case 15:g=E(r.cdr.car);c=r.cdr.car;case 17:t.t0=$;t.t1=r.car;t.t2=$;t.t3=c;t.next=23;return k(r.cdr.cdr,n,i);case 23:t.t4=t.sent;t.t5=new t.t2(t.t3,t.t4);return t.abrupt("return",new t.t0(t.t1,t.t5));case 28:if(!x(u,a)){t.next=50;break}f=a instanceof Sa?r:r.cdr;t.next=32;return a.invoke(f,q(q({},m),{},{env:i}),true);case 32:l=t.sent;if(!(a instanceof Sa)){t.next=41;break}h=l,p=h.expr,_=h.scope;if(!H(p)){t.next=40;break}if(!(n!==-1&&n<=1||n")}return"#"};var Ba=ce(function e(t){ue(this,e);f(this,"_syntax",t,{hidden:true});f(this._syntax,"_param",true,{hidden:true})});Sa.Parameter=Ba;function ja(e,t,P,N){var r=arguments.length>4&&arguments[4]!==undefined?arguments[4]:{};var R={"...":{symbols:{},lists:[]},symbols:{}};var T=r.expansion,L=r.define;z(P);function M(t,e){var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:[];var n=arguments.length>3&&arguments[3]!==undefined?arguments[3]:false;z({code:e,pattern:t});if(xa(t)&&!(t instanceof Y)){return Aa(t,e)}if(t instanceof Y&&P.includes(t.literal())){if(!Y.is(e,t)){return false}var i=T.ref(t);return!i||i===L||i===W}if(Array.isArray(t)&&Array.isArray(e)){z("<<< a 1");if(t.length===0&&e.length===0){return true}if(Y.is(t[1],N)){if(t[0]instanceof Y){var u=t[0].valueOf();z("<<< a 2 "+n);if(n){var a=e.length-2;var o=a>0?e.slice(0,a):e;var s=$.fromArray(o,false);if(!R["..."].symbols[u]){R["..."].symbols[u]=new $(s,V)}else{R["..."].symbols[u].append(new $(s,V))}}else{R["..."].symbols[u]=$.fromArray(e,false)}}else if(Array.isArray(t[0])){z("<<< a 3");var c=U(r);if(!e.every(function(e){return M(t[0],e,c,true)})){return false}}if(t.length>2){var f=t.slice(2);return M(f,e.slice(-f.length),r,n)}return true}var l=M(t[0],e[0],r,n);z({first:l,pattern:t[0],code:e[0]});var h=M(t.slice(1),e.slice(1),r,n);z({first:l,rest:h});return l&&h}if(H(t)&&H(t.car)&&H(t.car.cdr)&&Y.is(t.car.cdr.car,N)){z(">> 0");if(K(e)){z({pattern:t});if(t.car.car instanceof Y){var p=t.car.car.valueOf();if(R["..."].symbols[p]){throw new Error("syntax: named ellipsis can only "+"appear onces")}R["..."].symbols[p]=e}}}if(H(t)&&H(t.cdr)&&Y.is(t.cdr.car,N)){if(!K(t.cdr.cdr)){if(H(t.cdr.cdr)){var _=t.cdr.cdr.length();if(!H(e)){return false}var d=e.length();var v=e;while(d-1>_){v=v.cdr;d--}var y=v.cdr;v.cdr=V;if(!M(t.cdr.cdr,y,r,n)){return false}}}if(t.car instanceof Y){var m=t.car.__name__;if(R["..."].symbols[m]&&!r.includes(m)&&!n){throw new Error("syntax: named ellipsis can only appear onces")}z(">> 1");if(K(e)){z(">> 2");if(n){z("NIL");R["..."].symbols[m]=V}else{z("NULL");R["..."].symbols[m]=null}}else if(H(e)&&(H(e.car)||K(e.car))){z(">> 3 "+n);if(n){if(R["..."].symbols[m]){var g=R["..."].symbols[m];if(K(g)){g=new $(V,new $(e,V))}else{g=g.append(new $(e,V))}R["..."].symbols[m]=g}else{R["..."].symbols[m]=new $(e,V)}}else{z(">> 4");R["..."].symbols[m]=new $(e,V)}}else{z(">> 6");if(H(e)){if(!H(e.cdr)&&!K(e.cdr)){z(">> 7 (b)");if(K(t.cdr.cdr)){return false}else if(!R["..."].symbols[m]){R["..."].symbols[m]=new $(e.car,V);return M(t.cdr.cdr,e.cdr)}}var b=e.last_pair();if(!K(b.cdr)){if(K(t.cdr.cdr)){return false}else{var w=e.clone();w.last_pair().cdr=V;R["..."].symbols[m]=w;return M(t.cdr.cdr,b.cdr)}}z(">> 7 "+n);r.push(m);if(!R["..."].symbols[m]){R["..."].symbols[m]=new $(e,V)}else{var D=R["..."].symbols[m];R["..."].symbols[m]=D.append(new $(e,V))}z({IIIIII:R["..."].symbols[m]})}else if(t.car instanceof Y&&H(t.cdr)&&Y.is(t.cdr.car,N)){z(">> 8");R["..."].symbols[m]=null;return M(t.cdr.cdr,e)}else{z(">> 9");return false}}return true}else if(H(t.car)){var E=U(r);if(K(e)){z(">> 10");R["..."].lists.push(V);return true}z(">> 11");var A=e;while(H(A)){if(!M(t.car,A.car,E,true)){return false}A=A.cdr}return true}if(Array.isArray(t.car)){var E=U(r);var x=e;while(H(x)){if(!M(t.car,x.car,E,true)){return false}x=x.cdr}return true}return false}if(t instanceof Y){if(Y.is(t,N)){throw new Error("syntax: invalid usage of ellipsis")}z(">> 12");var F=t.__name__;if(P.includes(F)){return true}if(n){var k,C;z(R["..."].symbols[F]);(C=(k=R["..."].symbols)[F])!==null&&C!==void 0?C:k[F]=[];R["..."].symbols[F].push(e)}else{R.symbols[F]=e}return true}if(H(t)&&H(e)){z(">> 13");z({a:13,code:e,pattern:t});if(K(e.cdr)){var O=t.car instanceof Y&&t.cdr instanceof Y;if(O){if(!M(t.car,e.car,r,n)){return false}z(">> 14");var S=t.cdr.valueOf();if(!(S in R.symbols)){R.symbols[S]=V}S=t.car.valueOf();if(!(S in R.symbols)){R.symbols[S]=e.car}return true}}z({pattern:t,code:e});if(H(t.cdr)&&H(t.cdr.cdr)&&t.cdr.car instanceof Y&&Y.is(t.cdr.cdr.car,N)&&H(t.cdr.cdr.cdr)&&!Y.is(t.cdr.cdr.cdr.car,N)&&M(t.car,e.car,r,n)&&M(t.cdr.cdr.cdr,e.cdr,r,n)){var B=t.cdr.car.__name__;z({pattern:t,code:e,name:B});if(P.includes(B)){return true}R["..."].symbols[B]=null;return true}z("recur");z({pattern:t,code:e});var j=M(t.car,e.car,r,n);z({car:j,pattern:t.car,code:e.car});var I=M(t.cdr,e.cdr,r,n);z({car:j,cdr:I});if(j&&I){return true}}else if(K(t)&&(K(e)||e===undefined)){return true}else if(H(t.car)&&Y.is(t.car.car,N)){throw new Error("syntax: invalid usage of ellipsis")}else{return false}}if(M(e,t)){return R}}function Ia(e,i){function u(t){if(H(t)){if(!i.length){return t}var e=u(t.car);var r=u(t.cdr);return new $(e,r)}else if(t instanceof Y){var n=i.find(function(e){return e.gensym===t});if(n){return Y(n.name)}return t}else{return t}}return u(e)}function Pa(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};var j=e.bindings,t=e.expr,I=e.scope,a=e.symbols,f=e.names,P=e.ellipsis;var l={};function o(e){if(e instanceof Y){return true}return["string","symbol"].includes(p(e))}function N(e){if(!o(e)){var t=Ys(e);throw new Error("syntax: internal error, need symbol got ".concat(t))}var r=e.valueOf();if(r===P){throw new Error("syntax: internal error, ellipis not transformed")}var n=p(r);if(["string","symbol"].includes(n)){if(r in j.symbols){return j.symbols[r]}else if(n==="string"&&r.match(/\./)){var i=r.split(".");var u=i[0];if(u in j.symbols){return $.fromArray([Y("."),j.symbols[u]].concat(i.slice(1).map(function(e){return D(e)})))}}}if(a.includes(r)){return e}return s(r,e)}function s(e,t){if(!l[e]){var r=I.ref(e);if(p(e)==="symbol"&&!r){e=t.literal()}if(l[e]){return l[e]}var n=cu(e);if(r){var i=I.get(e);I.set(n,i)}else{var u=I.get(e,{throwError:false});if(typeof u!=="undefined"){I.set(n,u)}}f.push({name:e,gensym:n});l[e]=n;if(typeof e==="string"&&e.match(/\./)){var a=e.split(".").filter(Boolean),o=re(a),s=o[0],c=o.slice(1);if(l[s]){mo(n,"__object__",[l[s]].concat(U(c)))}}}return l[e]}function R(e,t,r){var n=arguments.length>3&&arguments[3]!==undefined?arguments[3]:function(){};var i=r.nested;z({bindings:t,expr:e});if(Array.isArray(e)&&!e.length){return e}if(e instanceof Y){var u=e.valueOf();if(su(e)&&!t[u]);z("[t 1");if(t[u]){if(H(t[u])){var a=t[u],o=a.car,s=a.cdr;if(i){var c=o.car,f=o.cdr;if(!K(f)){n(u,new $(f,V))}return c}if(!K(s)){n(u,s)}return o}else if(t[u]instanceof Array){n(u,t[u].slice(1));return t[u][0]}}return N(e)}var l=Array.isArray(e);if(H(e)||l){var h=l?e[0]:e.car;var p=l?e[1]:H(e.cdr)&&e.cdr.car;if(h instanceof Y&&Y.is(p,P)){l?e.slice(2):e.cdr.cdr;z("[t 2");var _=h.valueOf();var d=t[_];if(d===null){return}else if(d){z({name:_,binding:t[_]});if(H(d)){z("[t 2 Pair "+i);var v=d.car,y=d.cdr;var m=l?e.slice(2):e.cdr.cdr;if(i){if(!K(y)){z("|| next 1");n(_,y)}if(l&&m.length||!K(m)&&!l){var g=R(m,t,r,n);if(l){return v.concat(g)}else if(H(v)){return v.append(g)}else{z("UNKNOWN")}}return v}else if(H(v)){if(!K(v.cdr)){z("|| next 2");n(_,new $(v.cdr,y))}return v.car}else if(K(y)){return v}else{var b=e.last_pair();if(b.cdr instanceof Y){z("|| next 3");n(_,d.last_pair());return v}}}else if(d instanceof Array){z("[t 2 Array "+i);if(i){n(_,d.slice(1));return $.fromArray(d)}else{var w=d.slice(1);if(w.length){n(_,w)}return d[0]}}else{return d}}}z("[t 3 recur ",e);var D=l?e.slice(1):e.cdr;var E=R(h,t,r,n);var A=R(D,t,r,n);z({head:E,rest:A});if(l){return[E].concat(A)}return new $(E,A)}return e}function T(t,r){var e=Object.values(t);var n=Object.getOwnPropertySymbols(t);if(n.length){e.push.apply(e,U(n.map(function(e){return t[e]})))}return e.length&&e.every(function(e){if(e===null){return!r}return H(e)||K(e)||Array.isArray(e)&&e.length})}function L(e){return Object.keys(e).concat(Object.getOwnPropertySymbols(e))}function M(i){var e=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},t=e.disabled;z("traverse>> ",i);var u=Array.isArray(i);if(u&&i.length===0){return i}if(H(i)||u){var r=u?i[0]:i.car;var n,a;if(u){n=i[1];a=i.slice(2)}else if(H(i.cdr)){n=i.cdr.car;a=i.cdr.cdr}z({first:r,second:n,rest_second:a});if(!t&&H(r)&&Y.is(r.car,P)){return M(r.cdr,{disabled:true})}if(n&&Y.is(n,P)&&!t){z(">> 1");var o=j["..."].symbols;var s=Object.values(o);if(s.length&&s.every(function(e){return e===null})){z(">>> 1 (a)");return M(a,{disabled:t})}var c=L(o);var f=r instanceof Y&&Y.is(a.car,P);if(H(r)||f){z(">>> 1 (b)");if(K(j["..."].lists[0])){if(!f){return M(a,{disabled:t})}z(a);return V}var l=r;if(f){z(">>> 1 (c)");l=new $(r,new $(n,V))}z(">> 2");var h;if(c.length){z(">> 2 (a)");var p=q({},o);h=u?[]:V;var _=function e(){z({bind:p});if(!T(p)){return 1}var n={};var t=function e(t,r){n[t]=r};var r=R(l,p,{nested:true},t);if(r!==undefined){if(f){if(u){if(Array.isArray(r)){var i;(i=h).push.apply(i,U(r))}else{z("ZONK {1}")}}else{if(K(h)){h=r}else{h=h.append(r)}}}else if(u){h.push(r)}else{h=new $(r,h)}}p=n};while(true){if(_())break}if(!K(h)&&!f&&!u){h=h.reverse()}if(u){if(a){z({rest_second:a,expr:i});var d=M(a,{disabled:t});return h.concat(d)}return h}if(!K(i.cdr.cdr)&&!Y.is(i.cdr.cdr.car,P)){var v=M(i.cdr.cdr,{disabled:t});return h.append(v)}return h}else{z(">> 3");var y=R(r,o,{nested:true});if(y){return new $(y,V)}return V}}else if(r instanceof Y){z(">> 4");if(Y.is(a.car,P)){z(">> 4 (a)")}else{z(">> 4 (b)")}var m=r.__name__;var g=fe({},m,o[m]);z({bind:g});var b=o[m]===null;var w=u?[]:V;var D=function e(){if(!T(g,true)){z({bind:g});return 1}var n={};var t=function e(t,r){n[t]=r};var r=R(i,g,{nested:false},t);z({value:r});if(typeof r!=="undefined"){if(u){w.push(r)}else{w=new $(r,w)}}g=n};while(true){if(D())break}if(!K(w)&&!u){w=w.reverse()}if(H(i.cdr)){if(H(i.cdr.cdr)||i.cdr.cdr instanceof Y){var E=M(i.cdr.cdr,{disabled:t});z({node:E});if(b){return E}if(K(w)){w=E}else{w.append(E)}z({result:w,node:E})}}z("<<<< 2");return w}}var A=M(r,{disabled:t});var x;var F;if(r instanceof Y){var k=I.get(r,{throwError:false});F=k instanceof J&&k.__name__==="syntax-rules"}if(F){if(i.cdr.car instanceof Y){x=new $(M(i.cdr.car,{disabled:t}),new $(i.cdr.cdr.car,M(i.cdr.cdr.cdr,{disabled:t})))}else{x=new $(i.cdr.car,M(i.cdr.cdr,{disabled:t}))}z("REST >>>> ",x)}else{x=M(i.cdr,{disabled:t})}z({a:true,car:ma(i.car),cdr:ma(i.cdr),head:ma(A),rest:ma(x)});return new $(A,x)}if(i instanceof Y){if(t&&Y.is(i,P)){return i}var C=Object.keys(j["..."].symbols);var O=i.literal();if(C.includes(O)){var S="missing ellipsis symbol next to name `".concat(O,"'");throw new Error("syntax-rules: ".concat(S))}var B=N(i);if(typeof B!=="undefined"){return B}}return i}return M(t,{})}function Na(e){return Ya(e)||K(e)||e===null}function K(e){return e===V}function d(e){return typeof e==="function"&&typeof e.bind==="function"}function Ra(e){return e instanceof tc}function Ta(e){return e instanceof Xs}function La(e){return e instanceof Zs}function H(e){return e instanceof $}function Ma(e){return e instanceof x}function Ua(e){return d(e)||Ra(e)||La(e)||qa(e)}function qa(e){return e instanceof J||e instanceof Ba}function za(e){if(e instanceof fu){return false}if(e instanceof Promise){return true}return!!e&&d(e.then)}function Ya(e){return typeof e==="undefined"}function Va(e,t){if(Ha(e,t)||Ha(e.__proto__,t)){return d(e[t])}}function $a(e){if(!e){return false}if(p(e)!=="object"){return false}if(e.__instance__){e.__instance__=false;return e.__instance__}return false}function Ja(e){var t=p(e);return["string","function"].includes(t)||p(e)==="symbol"||e instanceof fu||e instanceof Y||e instanceof B||e instanceof D||e instanceof RegExp}function Ka(e){return e instanceof B||e instanceof D||e instanceof h}function Ha(e,t){if(e===null){return false}return p(e)==="object"&&t in Object.getOwnPropertySymbols(e)}function Wa(e){switch(p(e)){case"string":return D(e);case"bigint":return B(e);case"number":if(Number.isNaN(e)){return As}else{return B(e)}}return e}function Ga(r,n){var e=Object.getOwnPropertyNames(r);var t=Object.getOwnPropertySymbols(r);var i={};e.concat(t).forEach(function(e){var t=n(r[e]);i[e]=t});return i}function Qa(t){var e=[D,B].some(function(e){return t instanceof e});if(e){return t.valueOf()}if(t instanceof Array){return t.map(Qa)}if(t instanceof fu){delete t.then}if(ua(t)){return Ga(t,Qa)}return t}function Za(e,t){if(H(e)){e.markCycles();return ms(e)}if(d(e)){if(t){return eo(e,t)}}return Wa(e)}function Xa(e){if(ro(e)){return e[oo]}return e}function eo(e,t){if(e[Symbol["for"]("__bound__")]){return e}var r=e.bind(t);var n=Object.getOwnPropertyNames(e);var i=Gn(n),u;try{for(i.s();!(u=i.n()).done;){var a=u.value;if(yo(a)){try{r[a]=e[a]}catch(e){}}}}catch(e){i.e(e)}finally{i.f()}mo(r,"__fn__",e);mo(r,"__context__",t);mo(r,"__bound__",true);if(Eo(e)){mo(r,"__native__",true)}if(ua(t)&&bo(e)){mo(r,"__method__",true)}r.valueOf=function(){return e};return r}function to(e){return ro(e)&&e[Symbol["for"]("__context__")]===Object}function ro(e){return!!(d(e)&&e[oo])}function no(e){if(d(e)){var t=e[ao];if(t&&(t===Mc||t.constructor&&t.constructor.__class__)){return true}}return false}function io(e){return e instanceof Zo||e instanceof Xo}function uo(e){if(d(e)){if(io(e[ao])){return true}}return false}var ao=Symbol["for"]("__context__");var oo=Symbol["for"]("__fn__");var so=Symbol["for"]("__data__");var co=Symbol["for"]("__ref__");var fo=Symbol["for"]("__cycles__");var lo=Symbol["for"]("__class__");var ho=Symbol["for"]("__method__");var po=Symbol["for"]("__prototype__");var _o=Symbol["for"]("__lambda__");var vo=["name","length","caller","callee","arguments","prototype"];function yo(e){return!vo.includes(e)}function mo(e,t,r){Object.defineProperty(e,Symbol["for"](t),{get:function e(){return r},set:function e(){},configurable:false,enumerable:false})}function go(t,r){try{Object.defineProperty(t,"length",{get:function e(){return r}});return t}catch(e){var n=new Array(r).fill(0).map(function(e,t){return"a"+t}).join(",");var i=new Function("f","return function(".concat(n,") {\n return f.apply(this, arguments);\n };"));return i(t)}}function bo(e){return e&&e[_o]}function wo(e){return e&&e[ho]}function Do(e){return bo(e)&&!e[po]&&!wo(e)&&!uo(e)}function Eo(e){var t=Symbol["for"]("__native__");return d(e)&&e.toString().match(/\{\s*\[native code\]\s*\}/)&&(e.name.match(/^bound /)&&e[t]===true||!e.name.match(/^bound /)&&!e[t])}function Ao(e){var b;switch(e){case Symbol["for"]("letrec"):b="letrec";break;case Symbol["for"]("let"):b="let";break;case Symbol["for"]("let*"):b="let*";break;default:throw new Error("Invalid let_macro value")}return J.defmacro(b,function(t,e){var f=e.dynamic_env;var l=e.error,r=e.macro_expand,h=e.use_dynamic;var p;if(t.car instanceof Y){if(!(H(t.cdr.car)||K(t.cdr.car))){throw new Error("let require list of pairs")}var n;if(K(t.cdr.car)){p=V;n=V}else{n=t.cdr.car.map(function(e){return e.car});p=t.cdr.car.map(function(e){return e.cdr.car})}return $.fromArray([Y("letrec"),[[t.car,$(Y("lambda"),$(n,t.cdr.cdr))]],$(t.car,p)])}else if(r){return}var _=this;p=W.get("list->array")(t.car);var d=_.inherit(b);var v,y;if(b==="let*"){y=d}else if(b==="let"){v=[]}var m=0;function g(){var e=new $(new Y("begin"),t.cdr);return k(e,{env:d,dynamic_env:d,use_dynamic:h,error:l})}return function t(){var r=p[m++];f=b==="let*"?d:_;if(!r){if(v&&v.length){var e=v.map(function(e){return e.value});var n=e.filter(za);if(n.length){return lu(e).then(function(e){for(var t=0,r=e.length;t1&&arguments[1]!==undefined?arguments[1]:{},r=t.use_dynamic,n=t.error;var i=this;var u=this;var a=[];var o=e;while(H(o)){a.push(k(o.car,{env:i,dynamic_env:u,use_dynamic:r,error:n}));o=o.cdr}var s=a.filter(za).length;if(s){return lu(a).then(c.bind(this))}else{return c.call(this,a)}})}function Fo(e){for(var t=arguments.length,r=new Array(t>1?t-1:0),n=1;n2?n-2:0),u=2;u1&&arguments[1]!==undefined?arguments[1]:null;return function(){for(var e=arguments.length,t=new Array(e),r=0;r1?e-1:0),r=1;r=a){return u.apply(this,n)}else{return i}}return i.apply(this,arguments)}}function No(n,i){F("limit",i,"function",2);return function(){for(var e=arguments.length,t=new Array(e),r=0;r1){e=e.toLowerCase();if(h.__names__[e]){t=e;e=h.__names__[e]}else{throw new Error("Internal: Unknown named character")}}else{t=h.__rev_names__[e]}Object.defineProperty(this,"__char__",{value:e,enumerable:true});if(t){Object.defineProperty(this,"__name__",{value:t,enumerable:true})}}h.__names__=wi;h.__rev_names__={};Object.keys(h.__names__).forEach(function(e){var t=h.__names__[e];h.__rev_names__[t]=e});h.prototype.toUpperCase=function(){return h(this.__char__.toUpperCase())};h.prototype.toLowerCase=function(){return h(this.__char__.toLowerCase())};h.prototype.toString=function(){return"#\\"+(this.__name__||this.__char__)};h.prototype.valueOf=h.prototype.serialize=function(){return this.__char__};function D(e){if(typeof this!=="undefined"&&!(this instanceof D)||typeof this==="undefined"){return new D(e)}if(e instanceof Array){this.__string__=e.map(function(e,t){F("LString",e,"character",t+1);return e.toString()}).join("")}else{this.__string__=e.valueOf()}}{var Ro=["length","constructor"];var To=Object.getOwnPropertyNames(String.prototype).filter(function(e){return!Ro.includes(e)});var Lo=function e(n){return function(){for(var e=arguments.length,t=new Array(e),r=0;r0){r.push(this.__string__.substring(0,e))}r.push(t);if(e1&&arguments[1]!==undefined?arguments[1]:false;if(e instanceof B){return e}if(typeof this!=="undefined"&&!(this instanceof B)||typeof this==="undefined"){return new B(e,t)}if(typeof e==="undefined"){throw new Error("Invalid LNumber constructor call")}var r=B.getType(e);if(B.types[r]){return B.types[r](e,t)}var n=e instanceof Array&&D.isString(e[0])&&B.isNumber(e[1]);if(e instanceof B){return B(e.value)}if(!B.isNumber(e)&&!n){throw new Error("You can't create LNumber from ".concat(Ys(e)))}if(e===null){e=0}var i;if(n){var u=e,a=b(u,2),o=a[0],s=a[1];if(o instanceof D){o=o.valueOf()}if(s instanceof B){s=s.valueOf()}var c=o.match(/^([+-])/);var f=false;if(c){o=o.replace(/^[+-]/,"");if(c[1]==="-"){f=true}}}if(Number.isNaN(e)){return g(e)}else if(typeof BigInt!=="undefined"){if(typeof e!=="bigint"){if(n){var l;switch(s){case 8:l="0o";break;case 16:l="0x";break;case 2:l="0b";break;case 10:l="";break}if(typeof l==="undefined"){var h=BigInt(s);i=U(o).map(function(e,t){return BigInt(parseInt(e,s))*Jo(h,BigInt(t))}).reduce(function(e,t){return e+t})}else{i=BigInt(l+o)}}else{i=BigInt(e)}if(f){i*=BigInt(-1)}}else{i=e}return A(i,true)}else if(typeof si!=="undefined"&&!(e instanceof si)){if(e instanceof Array){return A(T(si,U(e)))}return A(new si(e))}else if(n){this.constant(parseInt(o,s),"integer")}else{this.constant(e,"integer")}}B.prototype.constant=function(e,t){Object.defineProperty(this,"__value__",{value:e,enumerable:true});Object.defineProperty(this,"__type__",{value:t,enumerable:true})};B.types={float:function e(t){return new g(t)},complex:function e(t){var r=arguments.length>1&&arguments[1]!==undefined?arguments[1]:false;if(!B.isComplex(t)){t={im:0,re:t}}return new m(t,r)},rational:function e(t){var r=arguments.length>1&&arguments[1]!==undefined?arguments[1]:false;if(!B.isRational(t)){t={num:t,denom:1}}return new E(t,r)}};B.prototype.serialize=function(){return this.__value__};B.prototype.isNaN=function(){return Number.isNaN(this.__value__)};B.prototype.gcd=function(e){var t=this.abs();e=e.abs();if(e.cmp(t)===1){var r=t;t=e;e=r}while(true){t=t.rem(e);if(t.cmp(0)===0){return e}e=e.rem(t);if(e.cmp(0)===0){return t}}};B.isFloat=function e(t){return t instanceof g||Number(t)===t&&t%1!==0};B.isNumber=function(e){return e instanceof B||B.isNative(e)||B.isBN(e)};B.isComplex=function(e){if(!e){return false}var t=e instanceof m||(B.isNumber(e.im)||B.isRational(e.im)||Number.isNaN(e.im))&&(B.isNumber(e.re)||B.isRational(e.re)||Number.isNaN(e.re));return t};B.isRational=function(e){if(!e){return false}return e instanceof E||B.isNumber(e.num)&&B.isNumber(e.denom)};B.isInteger=function(e){if(!(B.isNative(e)||e instanceof B)){return false}if(B.isFloat(e)){return false}if(B.isRational(e)){return false}if(B.isComplex(e)){return false}return true};B.isNative=function(e){return typeof e==="bigint"||typeof e==="number"};B.isBigInteger=function(e){return e instanceof A||typeof e==="bigint"||B.isBN(e)};B.isBN=function(e){return typeof si!=="undefined"&&e instanceof si};B.getArgsType=function(e,t){if(e instanceof g||t instanceof g){return g}if(e instanceof A||t instanceof A){return A}return B};B.prototype.toString=function(e){if(Number.isNaN(this.__value__)){return"+nan.0"}if(e>=2&&e<36){return this.__value__.toString(e)}return this.__value__.toString()};B.prototype.asType=function(e){var t=B.getType(this);return B.types[t]?B.types[t](e):B(e)};B.prototype.isBigNumber=function(){return typeof this.__value__==="bigint"||typeof si!=="undefined"&&!(this.value instanceof si)};["floor","ceil","round"].forEach(function(e){B.prototype[e]=function(){if(this["float"]||B.isFloat(this.__value__)){return B(Math[e](this.__value__))}else{return B(Math[e](this.valueOf()))}}});B.prototype.valueOf=function(){if(B.isNative(this.__value__)){return Number(this.__value__)}else if(B.isBN(this.__value__)){return this.__value__.toNumber()}};var zo=function(){var e=function e(t,r){return[t,r]};return{bigint:{bigint:e,float:function e(t,r){return[g(t.valueOf()),r]},rational:function e(t,r){return[{num:t,denom:1},r]},complex:function e(t,r){return[{im:0,re:t},r]}},integer:{integer:e,float:function e(t,r){return[g(t.valueOf()),r]},rational:function e(t,r){return[{num:t,denom:1},r]},complex:function e(t,r){return[{im:0,re:t},r]}},float:{bigint:function e(t,r){return[t,r&&g(r.valueOf())]},integer:function e(t,r){return[t,r&&g(r.valueOf())]},float:e,rational:function e(t,r){return[t,r&&g(r.valueOf())]},complex:function e(t,r){return[{re:t,im:g(0)},r]}},complex:{bigint:t("bigint"),integer:t("integer"),float:t("float"),rational:t("rational"),complex:function e(t,r){var n=B.coerce(t.__re__,r.__re__),i=b(n,2),u=i[0],a=i[1];var o=B.coerce(t.__im__,r.__im__),s=b(o,2),c=s[0],f=s[1];return[{im:c,re:u},{im:f,re:a}]}},rational:{bigint:function e(t,r){return[t,r&&{num:r,denom:1}]},integer:function e(t,r){return[t,r&&{num:r,denom:1}]},float:function e(t,r){return[g(t.valueOf()),r]},rational:e,complex:function e(t,r){return[{im:Yo(t.__type__,r.__im__.__type__,0)[0],re:Yo(t.__type__,r.__re__.__type__,t)[0]},{im:Yo(t.__type__,r.__im__.__type__,r.__im__)[0],re:Yo(t.__type__,r.__re__.__type__,r.__re__)[0]}]}}};function t(r){return function(e,t){return[{im:Yo(r,e.__im__.__type__,0,e.__im__)[1],re:Yo(r,e.__re__.__type__,0,e.__re__)[1]},{im:Yo(r,e.__im__.__type__,0,0)[1],re:Yo(r,t.__type__,0,t)[1]}]}}}();function Yo(e,t,r,n){return zo[e][t](r,n)}B.coerce=function(e,t){var r=B.getType(e);var n=B.getType(t);if(!zo[r]){throw new Error("LNumber::coerce unknown lhs type ".concat(r))}else if(!zo[r][n]){throw new Error("LNumber::coerce unknown rhs type ".concat(n))}var i=zo[r][n](e,t);return i.map(function(e){return B(e,true)})};B.prototype.coerce=function(e){if(!(typeof e==="number"||e instanceof B)){throw new Error("LNumber: you can't coerce ".concat(Ys(e)))}if(typeof e==="number"){e=B(e)}return B.coerce(this,e)};B.getType=function(e){if(e instanceof B){return e.__type__}if(B.isFloat(e)){return"float"}if(B.isComplex(e)){return"complex"}if(B.isRational(e)){return"rational"}if(typeof e==="number"){return"integer"}if(typeof BigInt!=="undefined"&&typeof e!=="bigint"||typeof si!=="undefined"&&!(e instanceof si)){return"bigint"}};B.prototype.isFloat=function(){return!!(B.isFloat(this.__value__)||this["float"])};var Vo={add:"+",sub:"-",mul:"*",div:"/",rem:"%",or:"|",and:"&",neg:"~",shl:">>",shr:"<<"};var $o={};Object.keys(Vo).forEach(function(t){$o[Vo[t]]=t;B.prototype[t]=function(e){return this.op(Vo[t],e)}});B._ops={"*":function e(t,r){return t*r},"+":function e(t,r){return t+r},"-":function e(t,r){if(typeof r==="undefined"){return-t}return t-r},"/":function e(t,r){return t/r},"%":function e(t,r){return t%r},"|":function e(t,r){return t|r},"&":function e(t,r){return t&r},"~":function e(t){return~t},">>":function e(t,r){return t>>r},"<<":function e(t,r){return t<1&&arguments[1]!==undefined?arguments[1]:false;if(typeof this!=="undefined"&&!(this instanceof m)||typeof this==="undefined"){return new m(e,t)}if(e instanceof m){return m({im:e.__im__,re:e.__re__})}if(B.isNumber(e)&&t){if(!t){return Number(e)}}else if(!B.isComplex(e)){var r="Invalid constructor call for LComplex expect &(:im :re ) object but got ".concat(ma(e));throw new Error(r)}var n=e.im instanceof B?e.im:B(e.im);var i=e.re instanceof B?e.re:B(e.re);this.constant(n,i)}m.prototype=Object.create(B.prototype);m.prototype.constructor=m;m.prototype.constant=function(e,t){Object.defineProperty(this,"__im__",{value:e,enumerable:true});Object.defineProperty(this,"__re__",{value:t,enumerable:true});Object.defineProperty(this,"__type__",{value:"complex",enumerable:true})};m.prototype.serialize=function(){return{re:this.__re__,im:this.__im__}};m.prototype.toRational=function(e){if(B.isFloat(this.__im__)&&B.isFloat(this.__re__)){var t=g(this.__im__).toRational(e);var r=g(this.__re__).toRational(e);return m({im:t,re:r})}return this};m.prototype.pow=function(e){e.cmp(0);if(e===0){return B(1)}var t=B(Math.atan2(this.__im__.valueOf(),this.__re__.valueOf()));var r=B(this.modulus());if(B.isComplex(e)&&e.__im__.cmp(0)!==0){var n=e.mul(Math.log(r.valueOf())).add(m.i.mul(t).mul(e));var i=g(Math.E).pow(n.__re__.valueOf());return m({re:i.mul(Math.cos(n.__im__.valueOf())),im:i.mul(Math.sin(n.__im__.valueOf()))})}var u=e.__re__.cmp(0)>0;e=e.__re__.valueOf();if(B.isInteger(e)&&u){var a=this;while(--e){a=a.mul(this)}return a}var o=r.pow(e);var s=t.mul(e);return m({re:o.mul(Math.cos(s)),im:o.mul(Math.sin(s))})};m.prototype.add=function(e){return this.complex_op("add",e,function(e,t,r,n){return{re:e.add(t),im:r.add(n)}})};m.prototype.factor=function(){if(this.__im__ instanceof g||this.__im__ instanceof g){var e=this.__re__,t=this.__im__;var r,n;if(e instanceof g){r=e.toRational().mul(e.toRational())}else{r=e.mul(e)}if(t instanceof g){n=t.toRational().mul(t.toRational())}else{n=t.mul(t)}return r.add(n)}else{return this.__re__.mul(this.__re__).add(this.__im__.mul(this.__im__))}};m.prototype.modulus=function(){return this.factor().sqrt()};m.prototype.conjugate=function(){return m({re:this.__re__,im:this.__im__.sub()})};m.prototype.sqrt=function(){var e=this.modulus();var t,r;if(e.cmp(0)===0){t=r=e}else if(this.__re__.cmp(0)===1){t=g(.5).mul(e.add(this.__re__)).sqrt();r=this.__im__.div(t).div(2)}else{r=g(.5).mul(e.sub(this.__re__)).sqrt();if(this.__im__.cmp(0)===-1){r=r.sub()}t=this.__im__.div(r).div(2)}return m({im:r,re:t})};m.prototype.div=function(e){if(B.isNumber(e)&&!B.isComplex(e)){if(!(e instanceof B)){e=B(e)}var t=this.__re__.div(e);var r=this.__im__.div(e);return m({re:t,im:r})}else if(!B.isComplex(e)){throw new Error("[LComplex::div] Invalid value")}if(this.cmp(e)===0){var n=this.coerce(e),i=b(n,2),u=i[0],a=i[1];var o=u.__im__.div(a.__im__);return o.coerce(a.__re__)[0]}var s=this.coerce(e),c=b(s,2),f=c[0],l=c[1];var h=l.factor();var p=l.conjugate();var _=f.mul(p);if(!B.isComplex(_)){return _.div(h)}var d=_.__re__.op("/",h);var v=_.__im__.op("/",h);return m({re:d,im:v})};m.prototype.sub=function(e){return this.complex_op("sub",e,function(e,t,r,n){return{re:e.sub(t),im:r.sub(n)}})};m.prototype.mul=function(e){return this.complex_op("mul",e,function(e,t,r,n){var i={re:e.mul(t).sub(r.mul(n)),im:e.mul(n).add(t.mul(r))};return i})};m.prototype.complex_op=function(e,t,i){var u=this;var r=function e(t,r){var n=i(u.__re__,t,u.__im__,r);if("im"in n&&"re"in n){if(n.im.cmp(0)===0){return n.re}return m(n,true)}return n};if(typeof t==="undefined"){return r()}if(B.isNumber(t)&&!B.isComplex(t)){if(!(t instanceof B)){t=B(t)}var n=t.asType(0);t={__im__:n,__re__:t}}else if(!B.isComplex(t)){throw new Error("[LComplex::".concat(e,"] Invalid value"))}var a=t.__re__ instanceof B?t.__re__:this.__re__.asType(t.__re__);var o=t.__im__ instanceof B?t.__im__:this.__im__.asType(t.__im__);return r(a,o)};m._op={"+":"add","-":"sub","*":"mul","/":"div"};m.prototype._op=function(e,t){var r=m._op[e];return this[r](t)};m.prototype.cmp=function(e){var t=this.coerce(e),r=b(t,2),n=r[0],i=r[1];var u=n.__re__.coerce(i.__re__),a=b(u,2),o=a[0],s=a[1];var c=o.cmp(s);if(c!==0){return c}else{var f=n.__im__.coerce(i.__im__),l=b(f,2),h=l[0],p=l[1];return h.cmp(p)}};m.prototype.valueOf=function(){return[this.__re__,this.__im__].map(function(e){return e.valueOf()})};m.prototype.toString=function(){var e;if(this.__re__.cmp(0)!==0){e=[ma(this.__re__)]}else{e=[]}var t=this.__im__.valueOf();var r=[Number.NEGATIVE_INFINITY,Number.POSITIVE_INFINITY].includes(t);var n=ma(this.__im__);if(!r&&!Number.isNaN(t)){var i=this.__im__.cmp(0);if(i<0||i===0&&this.__im__._minus){e.push("-")}else{e.push("+")}n=n.replace(/^-/,"")}e.push(n);e.push("i");return e.join("")};function g(e){if(typeof this!=="undefined"&&!(this instanceof g)||typeof this==="undefined"){return new g(e)}if(!B.isNumber(e)){throw new Error("Invalid constructor call for LFloat")}if(e instanceof B){return g(e.valueOf())}if(typeof e==="number"){if(Object.is(e,-0)){Object.defineProperty(this,"_minus",{value:true})}this.constant(e,"float")}}g.prototype=Object.create(B.prototype);g.prototype.constructor=g;g.prototype.toString=function(){if(this.__value__===Number.NEGATIVE_INFINITY){return"-inf.0"}if(this.__value__===Number.POSITIVE_INFINITY){return"+inf.0"}if(Number.isNaN(this.__value__)){return"+nan.0"}var e=this.__value__.toString();if(!e.match(/e/i)){var t=this.__value__.toString().replace(/^-/,"");var r=this.__value__<0?"-":"";if(e.match(/^-?0\.0{3}/)){var n=t.match(/^[.0]+/g)[0].length-1;var i=t.replace(/^[.0]+/,"").replace(/^([0-9])/,"$1.");return"".concat(r).concat(i,"e-").concat(n)}if(e.match(/^-?[0-9]{7,}\.?/)){var u=t.match(/^[0-9]+/g)[0].length-1;var a=t.replace(/\./,"").replace(/^([0-9])/,"$1.").replace(/0+$/,"").replace(/\.$/,".0");return"".concat(r).concat(a,"e").concat(u)}if(!B.isFloat(this.__value__)){var o=e+".0";return this._minus?"-"+o:o}}return e.replace(/^([0-9]+)e/,"$1.0e")};g.prototype._op=function(e,t){if(t instanceof B){t=t.__value__}var r=B._ops[e];if(e==="/"&&this.__value__===0&&t===0){return NaN}return g(r(this.__value__,t))};g.prototype.toRational=function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:null;if(e===null){return Ho(this.__value__.valueOf())}return Wo(e.valueOf())(this.__value__.valueOf())};g.prototype.sqrt=function(){var e=this.valueOf();if(this.cmp(0)<0){var t=g(Math.sqrt(-e));return m({re:0,im:t})}return g(Math.sqrt(e))};g.prototype.abs=function(){var e=this.valueOf();if(e<0){e=-e}return g(e)};var Ho=Wo(1e-10);function Wo(n){return function(e){var t=function e(n,t,r){var i=function e(t,r){return r0){i=Qo(n,r)}else if(n.cmp(r)<=0){i=r}else if(r.cmp(0)>0){i=Qo(r,n)}else if(t.cmp(0)<0){i=B(Qo(n.sub(),r.sub())).sub()}else{i=B(0)}if(B.isFloat(t)||B.isFloat(e)){return g(i)}return i}function Qo(e,t){var r=B(e).floor();var n=B(t).floor();if(e.cmp(r)<1){return r}else if(r.cmp(n)===0){var i=B(1).div(t.sub(n));var u=B(1).div(e.sub(r));return r.add(B(1).div(Qo(i,u)))}else{return r.add(B(1))}}function E(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:false;if(typeof this!=="undefined"&&!(this instanceof E)||typeof this==="undefined"){return new E(e,t)}if(!B.isRational(e)){throw new Error("Invalid constructor call for LRational")}var r,n;if(e instanceof E){r=B(e.__num__);n=B(e.__denom__)}else{r=B(e.num);n=B(e.denom)}if(!t&&n.cmp(0)!==0){var i=r.op("%",n).cmp(0)===0;if(i){return B(r.div(n))}}this.constant(r,n)}E.prototype=Object.create(B.prototype);E.prototype.constructor=E;E.prototype.constant=function(e,t){Object.defineProperty(this,"__num__",{value:e,enumerable:true});Object.defineProperty(this,"__denom__",{value:t,enumerable:true});Object.defineProperty(this,"__type__",{value:"rational",enumerable:true})};E.prototype.serialize=function(){return{num:this.__num__,denom:this.__denom__}};E.prototype.pow=function(e){if(B.isRational(e)){return Jo(this.valueOf(),e.valueOf())}var t=e.cmp(0);if(t===0){return B(1)}if(t===-1){e=e.sub();var r=this.__denom__.pow(e);var n=this.__num__.pow(e);return E({num:r,denom:n})}var i=this;e=e.valueOf();while(e>1){i=i.mul(this);e--}return i};E.prototype.sqrt=function(){var e=this.__num__.sqrt();var t=this.__denom__.sqrt();if(e instanceof g||t instanceof g){return e.div(t)}return E({num:e,denom:t})};E.prototype.abs=function(){var e=this.__num__;var t=this.__denom__;if(e.cmp(0)===-1){e=e.sub()}if(t.cmp(0)!==1){t=t.sub()}return E({num:e,denom:t})};E.prototype.cmp=function(e){return B(this.valueOf(),true).cmp(e)};E.prototype.toString=function(){var e=this.__num__.gcd(this.__denom__);var t,r;if(e.cmp(1)!==0){t=this.__num__.div(e);if(t instanceof E){t=B(t.valueOf(true))}r=this.__denom__.div(e);if(r instanceof E){r=B(r.valueOf(true))}}else{t=this.__num__;r=this.__denom__}var n=this.cmp(0)<0;if(n){if(t.abs().cmp(r.abs())===0){return t.toString()}}else if(t.cmp(r)===0){return t.toString()}return t.toString()+"/"+r.toString()};E.prototype.valueOf=function(e){if(this.__denom__.cmp(0)===0){if(this.__num__.cmp(0)<0){return Number.NEGATIVE_INFINITY}return Number.POSITIVE_INFINITY}if(e){return B._ops["/"](this.__num__.value,this.__denom__.value)}return g(this.__num__.valueOf()).div(this.__denom__.valueOf())};E.prototype.mul=function(e){if(!(e instanceof B)){e=B(e)}if(B.isRational(e)){var t=this.__num__.mul(e.__num__);var r=this.__denom__.mul(e.__denom__);return E({num:t,denom:r})}var n=B.coerce(this,e),i=b(n,2),u=i[0],a=i[1];return u.mul(a)};E.prototype.div=function(e){if(!(e instanceof B)){e=B(e)}if(B.isRational(e)){var t=this.__num__.mul(e.__denom__);var r=this.__denom__.mul(e.__num__);return E({num:t,denom:r})}var n=B.coerce(this,e),i=b(n,2),u=i[0],a=i[1];var o=u.div(a);return o};E.prototype._op=function(e,t){return this[$o[e]](t)};E.prototype.sub=function(e){if(typeof e==="undefined"){return this.mul(-1)}if(!(e instanceof B)){e=B(e)}if(B.isRational(e)){var t=e.__num__.sub();var r=e.__denom__;return this.add(E({num:t,denom:r}))}if(!(e instanceof B)){e=B(e).sub()}else{e=e.sub()}var n=B.coerce(this,e),i=b(n,2),u=i[0],a=i[1];return u.add(a)};E.prototype.add=function(e){if(!(e instanceof B)){e=B(e)}if(B.isRational(e)){var t=this.__denom__;var r=e.__denom__;var n=this.__num__;var i=e.__num__;var u,a;if(t!==r){a=r.mul(n).add(i.mul(t));u=t.mul(r)}else{a=n.add(i);u=t}return E({num:a,denom:u})}if(B.isFloat(e)){return g(this.valueOf()).add(e)}var o=B.coerce(this,e),s=b(o,2),c=s[0],f=s[1];return c.add(f)};function A(e,t){if(typeof this!=="undefined"&&!(this instanceof A)||typeof this==="undefined"){return new A(e,t)}if(e instanceof A){return A(e.__value__,e._native)}if(!B.isBigInteger(e)){throw new Error("Invalid constructor call for LBigInteger")}this.constant(e,"bigint");Object.defineProperty(this,"_native",{value:t})}A.prototype=Object.create(B.prototype);A.prototype.constructor=A;A.bn_op={"+":"iadd","-":"isub","*":"imul","/":"idiv","%":"imod","|":"ior","&":"iand","~":"inot","<<":"ishrn",">>":"ishln"};A.prototype.serialize=function(){return this.__value__.toString()};A.prototype._op=function(e,t){if(typeof t==="undefined"){if(B.isBN(this.__value__)){e=A.bn_op[e];return A(this.__value__.clone()[e](),false)}return A(B._ops[e](this.__value__),true)}if(B.isBN(this.__value__)&&B.isBN(t.__value__)){e=A.bn_op[e];return A(this.__value__.clone()[e](t),false)}var r=B._ops[e](this.__value__,t.__value__);if(e==="/"){var n=this.op("%",t).cmp(0)===0;if(n){return B(r)}return E({num:this,denom:t})}return A(r,true)};A.prototype.sqrt=function(){var e;var t=this.cmp(0)<0;if(B.isNative(this.__value__)){e=B(Math.sqrt(t?-this.valueOf():this.valueOf()))}else if(B.isBN(this.__value__)){e=t?this.__value__.neg().sqrt():this.__value__.sqrt()}if(t){return m({re:0,im:e})}return e};B.NaN=B(NaN);m.i=m({im:1,re:0});function Zo(e){var n=this;if(typeof this!=="undefined"&&!(this instanceof Zo)||typeof this==="undefined"){return new Zo(e)}F("InputPort",e,"function");f(this,"__type__",fs);var i;Object.defineProperty(this,"__parser__",{enumerable:true,get:function e(){return i},set:function e(t){F("InputPort::__parser__",t,"parser");i=t}});this._read=e;this._with_parser=this._with_init_parser.bind(this,ie(C.mark(function e(){var r;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(n.char_ready()){t.next=5;break}t.next=3;return n._read();case 3:r=t.sent;i=new Du(r,{env:n});case 5:return t.abrupt("return",n.__parser__);case 6:case"end":return t.stop()}},e)})));this.char_ready=function(){return!!this.__parser__&&this.__parser__.__lexer__.peek()!==ls};this._make_defaults()}Zo.prototype._make_defaults=function(){this.read=this._with_parser(function(e){return e.read_object()});this.read_line=this._with_parser(function(e){return e.__lexer__.read_line()});this.read_char=this._with_parser(function(e){return e.__lexer__.read_char()});this.read_string=this._with_parser(function(e,t){if(!B.isInteger(t)){var r=B.getType(t);Ts("read-string",r,"integer")}return e.__lexer__.read_string(t.valueOf())});this.peek_char=this._with_parser(function(e){return e.__lexer__.peek_char()})};Zo.prototype._with_init_parser=function(o,s){var c=this;return ie(C.mark(function e(){var r,n,i,u,a=arguments;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:t.next=2;return o.call(c);case 2:r=t.sent;for(n=a.length,i=new Array(n),u=0;u"};function Xo(e){if(typeof this!=="undefined"&&!(this instanceof Xo)||typeof this==="undefined"){return new Xo(e)}F("OutputPort",e,"function");f(this,"__type__",fs);this.write=e}Xo.prototype.is_open=function(){return this._closed!==true};Xo.prototype.close=function(){Object.defineProperty(this,"_closed",{get:function e(){return true},set:function e(){},configurable:false,enumerable:false});this.write=function(){throw new Error("output-port: port is closed")}};Xo.prototype.flush=function(){};Xo.prototype.toString=function(){return"#"};var es=function(e){G(r,e);function r(e){var t;ue(this,r);t=Hn(this,r,[function(){var e;return(e=t)._write.apply(e,arguments)}]);F("BufferedOutputPort",e,"function");f(L(t),"_fn",e,{hidden:true});f(L(t),"_buffer",[],{hidden:true});return t}ce(r,[{key:"flush",value:function e(){if(this._buffer.length){this._fn(this._buffer.join(""));this._buffer.length=0}}},{key:"_write",value:function e(){var t=this;for(var r=arguments.length,n=new Array(r),i=0;i"};ts.prototype.valueOf=function(){return this.__buffer__.map(function(e){return e.valueOf()}).join("")};function rs(e,t){var r=this;if(typeof this!=="undefined"&&!(this instanceof rs)||typeof this==="undefined"){return new rs(e,t)}F("OutputFilePort",e,"string");f(this,"__filename__",e);f(this,"_fd",t.valueOf(),{hidden:true});f(this,"__type__",fs);this.write=function(e){if(!D.isString(e)){e=ma(e)}else{e=e.valueOf()}r.fs().write(r._fd,e,function(e){if(e){throw e}})}}rs.prototype=Object.create(Xo.prototype);rs.prototype.constructor=rs;rs.prototype.fs=function(){if(!this._fs){this._fs=this.internal("fs")}return this._fs};rs.prototype.internal=function(e){return Fs.get("**internal-env**").get(e)};rs.prototype.close=function(){var n=this;return new Promise(function(t,r){n.fs().close(n._fd,function(e){if(e){r(e)}else{f(n,"_fd",null,{hidden:true});Xo.prototype.close.call(n);t()}})})};rs.prototype.toString=function(){return"#")};function ns(e,t){var r=this;if(typeof this!=="undefined"&&!(this instanceof ns)||typeof this==="undefined"){return new ns(e)}F("InputStringPort",e,"string");t=t||W;e=e.valueOf();this._with_parser=this._with_init_parser.bind(this,function(){if(!r.__parser__){r.__parser__=new Du(e,{env:t})}return r.__parser__});f(this,"__type__",fs);this._make_defaults()}ns.prototype.char_ready=function(){return true};ns.prototype=Object.create(Zo.prototype);ns.prototype.constructor=ns;ns.prototype.toString=function(){return"#"};function is(e){if(typeof this!=="undefined"&&!(this instanceof is)||typeof this==="undefined"){return new is(e)}F("InputByteVectorPort",e,"uint8array");f(this,"__vector__",e);f(this,"__type__",cs);var r=0;Object.defineProperty(this,"__index__",{enumerable:true,get:function e(){return r},set:function e(t){F("InputByteVectorPort::__index__",t,"number");if(t instanceof B){t=t.valueOf()}if(typeof t==="bigint"){t=Number(t)}if(Math.floor(t)!==t){throw new Error("InputByteVectorPort::__index__ value is "+"not integer")}r=t}})}is.prototype=Object.create(Zo.prototype);is.prototype.constructor=is;is.prototype.toString=function(){return"#"};is.prototype.close=function(){var t=this;f(this,"__vector__",V);var r=function e(){throw new Error("Input-binary-port: port is closed")};["read_u8","close","peek_u8","read_u8_vector"].forEach(function(e){t[e]=r});this.u8_ready=this.char_ready=function(){return false}};is.prototype.u8_ready=function(){return true};is.prototype.peek_u8=function(){if(this.__index__>=this.__vector__.length){return ls}return this.__vector__[this.__index__]};is.prototype.skip=function(){if(this.__index__<=this.__vector__.length){++this.__index__}};is.prototype.read_u8=function(){var e=this.peek_u8();this.skip();return e};is.prototype.read_u8_vector=function(e){if(typeof e==="undefined"){e=this.__vector__.length}else if(e>this.__index__+this.__vector__.length){e=this.__index__+this.__vector__.length}if(this.peek_u8()===ls){return ls}return this.__vector__.slice(this.__index__,e)};function us(){if(typeof this!=="undefined"&&!(this instanceof us)||typeof this==="undefined"){return new us}f(this,"__type__",cs);f(this,"_buffer",[],{hidden:true});this.write=function(e){F("write",e,["number","uint8array"]);if(B.isNumber(e)){this._buffer.push(e.valueOf())}else{var t;(t=this._buffer).push.apply(t,U(Array.from(e)))}};Object.defineProperty(this,"__buffer__",{enumerable:true,get:function e(){return Uint8Array.from(this._buffer)}})}us.prototype=Object.create(Xo.prototype);us.prototype.constructor=us;us.prototype.close=function(){Xo.prototype.close.call(this);f(this,"_buffer",null,{hidden:true})};us.prototype._close_guard=function(){if(this._closed){throw new Error("output-port: binary port is closed")}};us.prototype.write_u8=function(e){F("OutputByteVectorPort::write_u8",e,"number");this.write(e)};us.prototype.write_u8_vector=function(e){F("OutputByteVectorPort::write_u8_vector",e,"uint8array");this.write(e)};us.prototype.toString=function(){return"#"};us.prototype.valueOf=function(){return this.__buffer__};function as(e,t){if(typeof this!=="undefined"&&!(this instanceof as)||typeof this==="undefined"){return new as(e,t)}ns.call(this,e);F("InputFilePort",t,"string");f(this,"__filename__",t)}as.prototype=Object.create(ns.prototype);as.prototype.constructor=as;as.prototype.toString=function(){return"#")};function os(e,t){if(typeof this!=="undefined"&&!(this instanceof os)||typeof this==="undefined"){return new os(e,t)}is.call(this,e);F("InputBinaryFilePort",t,"string");f(this,"__filename__",t)}os.prototype=Object.create(is.prototype);os.prototype.constructor=os;os.prototype.toString=function(){return"#")};function ss(e,t){var i=this;if(typeof this!=="undefined"&&!(this instanceof ss)||typeof this==="undefined"){return new ss(e,t)}F("OutputBinaryFilePort",e,"string");f(this,"__filename__",e);f(this,"_fd",t.valueOf(),{hidden:true});f(this,"__type__",cs);var u;this.write=function(e){F("write",e,["number","uint8array"]);var n;if(!u){u=i.internal("fs")}if(B.isNumber(e)){n=new Uint8Array([e.valueOf()])}else{n=new Uint8Array(Array.from(e))}return new Promise(function(t,r){u.write(i._fd,n,function(e){if(e){r(e)}else{t()}})})}}ss.prototype=Object.create(rs.prototype);ss.prototype.constructor=ss;ss.prototype.write_u8=function(e){F("OutputByteVectorPort::write_u8",e,"number");this.write(e)};ss.prototype.write_u8_vector=function(e){F("OutputByteVectorPort::write_u8_vector",e,"uint8array");this.write(e)};var cs=Symbol["for"]("binary");var fs=Symbol["for"]("text");var ls=new hs;function hs(){}hs.prototype.toString=function(){return"#"};function ps(e){var t=this;var r=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},n=r.stderr,i=r.stdin,u=r.stdout,a=r.command_line,o=a===void 0?null:a,s=he(r,zn);if(typeof this!=="undefined"&&!(this instanceof ps)||typeof this==="undefined"){return new ps(e,q({stdin:i,stdout:u,stderr:n,command_line:o},s))}if(typeof e==="undefined"){e="anonymous"}this.__env__=Fs.inherit(e,s);this.__env__.set("parent.frame",l("parent.frame",function(){return t.__env__},W.__env__["parent.frame"].__doc__));var c="**interaction-environment-defaults**";this.set(c,pa(s).concat(c));var f=Es.inherit("internal-".concat(e));if(io(i)){f.set("stdin",i)}if(io(n)){f.set("stderr",n)}if(io(u)){f.set("stdout",u)}f.set("command-line",o);ks(this.__env__,f)}ps.prototype.exec=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};var r=t.use_dynamic,n=r===void 0?false:r,i=t.dynamic_env,u=t.env;F("Interpreter::exec",e,["string","array"],1);F("Interpreter::exec",n,"boolean",2);if(!u){u=this.__env__}if(!i){i=u}W.set("**interaction-environment**",this.__env__);return nc(e,{env:u,dynamic_env:i,use_dynamic:n})};ps.prototype.get=function(e){var t=this.__env__.get(e);if(d(t)){var r=new Xs({env:this.__env__});return t.bind(r)}return t};ps.prototype.set=function(e,t){return this.__env__.set(e,t)};ps.prototype.constant=function(e,t){return this.__env__.constant(e,t)};function _s(e,t){this.name="LipsError";this.message=e;this.args=t;this.stack=(new Error).stack}_s.prototype=new Error;_s.prototype.constructor=_s;var ds=function(e){G(t,e);function t(){ue(this,t);return Hn(this,t,arguments)}return ce(t)}(r(Error));function x(e,t,r){if(arguments.length===1){if(p(arguments[0])==="object"){e=arguments[0];t=null}else if(typeof arguments[0]==="string"){e={};t=null;r=arguments[0]}}this.__docs__=new Map;this.__env__=e;this.__parent__=t;this.__name__=r||"anonymous"}x.prototype.list=function(){return pa(this.__env__)};x.prototype.fs=function(){return this.get("**fs**")};x.prototype.unset=function(e){if(e instanceof Y){e=e.valueOf()}if(e instanceof D){e=e.valueOf()}delete this.__env__[e]};x.prototype.inherit=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};if(p(e)==="object"){t=e}if(!e||p(e)==="object"){e="child of "+(this.__name__||"unknown")}return new x(t||{},this,e)};x.prototype.doc=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:null;var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:false;if(e instanceof Y){e=e.__name__}if(e instanceof D){e=e.valueOf()}if(t){if(!r){t=Bu(t)}this.__docs__.set(e,t);return this}if(this.__docs__.has(e)){return this.__docs__.get(e)}if(this.__parent__){return this.__parent__.doc(e)}};x.prototype.new_frame=function(e,t){var n=this.inherit("__frame__");n.set("parent.frame",l("parent.frame",function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:1;e=e.valueOf();var t=n.__parent__;if(!Ma(t)){return V}if(e<=0){return t}var r=t.get("parent.frame");return r(e-1)},W.__env__["parent.frame"].__doc__));t.callee=e;n.set("arguments",t);return n};x.prototype._lookup=function(e){if(e instanceof Y){e=e.__name__}if(e instanceof D){e=e.valueOf()}if(this.__env__.hasOwnProperty(e)){return vs(this.__env__[e])}if(this.__parent__){return this.__parent__._lookup(e)}};x.prototype.toString=function(){return"#"};x.prototype.clone=function(){var t=this;var r={};Object.keys(this.__env__).forEach(function(e){r[e]=t.__env__[e]});return new x(r,this.__parent__,this.__name__)};x.prototype.merge=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:"merge";F("Environment::merge",e,"environment");return this.inherit(t,e.__env__)};function vs(e){if(typeof this!=="undefined"&&!(this instanceof vs)||typeof this==="undefined"){return new vs(e)}this.value=e}vs.isUndefined=function(e){return e instanceof vs&&typeof e.value==="undefined"};vs.prototype.valueOf=function(){return this.value};function ys(e){if(e.length){if(e.length===1){return e[0]}}if(typeof this!=="undefined"&&!(this instanceof ys)||typeof this==="undefined"){return new ys(e)}this.__values__=e}ys.prototype.toString=function(){return this.__values__.map(function(e){return ma(e)}).join("\n")};ys.prototype.valueOf=function(){return this.__values__};x.prototype.get=function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};F("Environment::get",e,["symbol","string"]);var r=t.throwError,n=r===void 0?true:r;var i=e;if(i instanceof Y||i instanceof D){i=i.valueOf()}var u=this._lookup(i);if(u instanceof vs){if(vs.isUndefined(u)){return undefined}return Za(u.valueOf())}var a;if(e instanceof Y&&e[Y.object]){a=e[Y.object]}else if(typeof i==="string"){a=i.split(".").filter(Boolean)}if(a&&a.length>0){var o=a,s=re(o),c=s[0],f=s.slice(1);u=this._lookup(c);if(f.length){try{if(u instanceof vs){u=u.valueOf()}else{u=bs(ri,c);if(d(u)){u=Xa(u)}}if(typeof u!=="undefined"){return bs.apply(void 0,[u].concat(U(f)))}}catch(e){throw e}}else if(u instanceof vs){return Za(u.valueOf())}u=bs(ri,i)}if(typeof u!=="undefined"){return u}if(n){throw new Error("Unbound variable `"+i.toString()+"'")}};x.prototype.set=function(e,t){var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:null;F("Environment::set",e,["string","symbol"]);if(B.isNumber(t)){t=B(t)}if(e instanceof Y){e=e.__name__}if(e instanceof D){e=e.valueOf()}this.__env__[e]=t;if(r){this.doc(e,r,true)}return this};x.prototype.constant=function(t,e){var r=this;if(this.__env__.hasOwnProperty(t)){throw new Error("Environment::constant: ".concat(t," already exists"))}if(arguments.length===1&&ua(arguments[0])){var n=arguments[0];Object.keys(n).forEach(function(e){r.constant(t,n[e])})}else{Object.defineProperty(this.__env__,t,{value:e,enumerable:true})}return this};x.prototype.has=function(e){return this.__env__.hasOwnProperty(e)};x.prototype.ref=function(e){var t=this;while(true){if(!t){break}if(t.has(e)){return t}t=t.__parent__}};x.prototype.parents=function(){var e=this;var t=[];while(e){t.unshift(e);e=e.__parent__}return t};function ms(e){if(za(e)){return e.then(ms)}if(H(e)||e instanceof Y){e[so]=true}return e}var gs=Au(iu('(lambda ()\n "[native code]"\n (throw "Invalid Invocation"))'))[0];var bs=l("get",function e(t){var r;for(var n=arguments.length,i=new Array(n>1?n-1:0),u=1;u0&&arguments[0]!==undefined?arguments[0]:null;if(e===null){e=ws(this,"stdin")}qs("peek-char",e,"input-port");return e.peek_char()},"(peek-char port)\n\n This function reads and returns a character from the string\n port, or, if there is no more data in the string port, it\n returns an EOF."),"read-line":l("read-line",function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:null;if(e===null){e=ws(this,"stdin")}qs("read-line",e,"input-port");return e.read_line()},"(read-line port)\n\n This function reads and returns the next line from the input\n port."),"read-char":l("read-char",function(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:null;if(e===null){e=ws(this,"stdin")}qs("read-char",e,"input-port");return e.read_char()},"(read-char port)\n\n This function reads and returns the next character from the\n input port."),read:l("read",function(){var e=ie(function(){var f=this;var l=arguments.length>0&&arguments[0]!==undefined?arguments[0]:null;return C.mark(function e(){var r,n,i,u,a,o,s,c;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:r=f.env;if(!D.isString(l)){t.next=30;break}n=false;i=false;t.prev=4;a=ei(Au(l,r));case 6:t.next=8;return a.next();case 8:if(!(n=!(o=t.sent).done)){t.next=14;break}s=o.value;return t.abrupt("return",s);case 11:n=false;t.next=6;break;case 14:t.next=20;break;case 16:t.prev=16;t.t0=t["catch"](4);i=true;u=t.t0;case 20:t.prev=20;t.prev=21;if(!(n&&a["return"]!=null)){t.next=25;break}t.next=25;return a["return"]();case 25:t.prev=25;if(!i){t.next=28;break}throw u;case 28:return t.finish(25);case 29:return t.finish(20);case 30:if(l===null){c=ws(r,"stdin")}else{c=l}qs("read",c,"input-port");return t.abrupt("return",c.read.call(r));case 33:case"end":return t.stop()}},e,null,[[4,16,20,30],[21,,25,29]])})()});function t(){return e.apply(this,arguments)}return t}(),"(read [string])\n\n This function, if used with a string, will parse it and\n return the LIPS code, if there is any. If called with a\n port, it will parse the next item from the port. If called\n without an input, it will read a string from standard input\n (using the browser's prompt or a user defined input method)\n and calls itself with that string. This function can be used\n together with `eval` to evaluate code from a string."),pprint:l("pprint",function e(t){if(H(t)){t=new Mc.Formatter(t.toString(true))["break"]().format();W.get("display").call(W,t)}else{W.get("write").call(W,t)}W.get("newline").call(W)},"(pprint expression)\n\n This function will pretty print its input to stdout. If it is called\n with a non-list, it will just call the print function on its\n input."),print:l("print",function e(){var t=W.get("display");var r=W.get("newline");var n=this.use_dynamic;var i=W;var u=W;for(var a=arguments.length,o=new Array(a),s=0;s1?r-1:0),i=1;in.length){throw new Error("Not enough arguments")}var o=0;var s=W.get("repr");t=t.replace(u,function(e){var t=e[1];if(t==="~"){return"~"}else if(t==="%"){return"\n"}else{var r=n[o++];if(t==="a"){return s(r)}else{return s(r,true)}}});a=t.match(/~([\S])/);if(a){throw new Error("format: Unrecognized escape sequence ".concat(a[1]))}return t},"(format string n1 n2 ...)\n\n This function accepts a string template and replaces any\n escape sequences in its inputs:\n\n * ~a value as if printed with `display`\n * ~s value as if printed with `write`\n * ~% newline character\n * ~~ literal tilde '~'\n\n If there are missing inputs or other escape characters it\n will error."),display:l("display",function e(t){var r=arguments.length>1&&arguments[1]!==undefined?arguments[1]:null;if(r===null){r=ws(this,"stdout")}else{F("display",r,"output-port")}var n=t;if(!(r instanceof ss)){n=W.get("repr")(t)}r.write.call(W,n)},"(display string [port])\n\n This function outputs the string to the standard output or\n the port if given. No newline."),"display-error":l("display-error",function e(){var t=ws(this,"stderr");var r=W.get("repr");for(var n=arguments.length,i=new Array(n),u=0;u1&&arguments[1]!==undefined?arguments[1]:{},r=t.use_dynamic,n=he(t,Yn);var i=this;var a=this;var o;var s=q(q({},n),{},{env:this,dynamic_env:i,use_dynamic:r});var c=k(e.cdr.car,s);c=Vs(c);function f(t,r,n){if(za(t)){return t.then(function(e){return f(t,e,n)})}if(za(r)){return r.then(function(e){return f(t,e,n)})}if(za(n)){return n.then(function(e){return f(t,r,e)})}a.get("set-obj!").call(a,t,r,n);return n}if(H(e.car)&&Y.is(e.car.car,".")){var l=e.car.cdr.car;var h=e.car.cdr.cdr.car;var p=k(l,s);var _=k(h,s);return f(p,_,c)}if(!(e.car instanceof Y)){throw new Error("set! first argument need to be a symbol or "+"dot accessor that evaluate to object.")}var d=e.car.valueOf();o=this.ref(e.car.__name__);return w(c,function(e){if(!o){var t=d.split(".");if(t.length>1){var r=t.pop();var n=t.join(".");var i=u.get(n,{throwError:false});if(i){f(i,r,e);return}}throw new Error("Unbound variable `"+d+"'")}o.set(d,e)})}),"(set! name value)\n\n Macro that can be used to set the value of the variable or slot (mutate it).\n set! searches the scope chain until it finds first non empty slot and sets it."),"unset!":l(new J("set!",function(e){if(!(e.car instanceof Y)){throw new Error("unset! first argument need to be a symbol or "+"dot accessor that evaluate to object.")}var t=e.car;var r=this.ref(t);if(r){delete r.__env__[t.__name__]}}),"(unset! name)\n\n Function to delete the specified name from environment.\n Trying to access the name afterwards will error."),"set-car!":l("set-car!",function(e,t){F("set-car!",e,"pair");e.car=t},"(set-car! obj value)\n\n Function that sets the car (first item) of the list/pair to specified value.\n The old value is lost."),"set-cdr!":l("set-cdr!",function(e,t){F("set-cdr!",e,"pair");e.cdr=t},"(set-cdr! obj value)\n\n Function that sets the cdr (tail) of the list/pair to specified value.\n It will destroy the list. The old tail is lost."),"empty?":l("empty?",function(e){return typeof e==="undefined"||K(e)},"(empty? object)\n\n Function that returns #t if value is nil (an empty list) or undefined."),gensym:l("gensym",cu,"(gensym)\n\n Generates a unique symbol that is not bound anywhere,\n to use with macros as meta name."),load:l("load",function e(o,t){F("load",o,"string");var s=this;if(s.__name__==="__frame__"){s=s.__parent__}if(!(t instanceof x)){if(s===W){t=s}else{t=this.get("**interaction-environment**")}}var c="**module-path**";var f=W.get(c,{throwError:false});o=o.valueOf();if(!o.match(/.[^.]+$/)){o+=".scm"}var r=o.match(/\.xcb$/);function l(e){if(r){e=Bc(e)}else{if(Ys(e)==="buffer"){e=e.toString()}e=e.replace(/^#!.*/,"");if(e.match(/^\{/)){e=Ac(e)}}return nc(e,{env:t})}function n(e){return ri.fetch(e).then(function(e){return r?e.arrayBuffer():e.text()}).then(function(e){if(r){e=new Uint8Array(e)}return e})}if(Is()){return new Promise(function(){var r=ie(C.mark(function e(r,n){var i,u,a;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:i=oi("path");if(!f){t.next=6;break}f=f.valueOf();o=i.join(f,o);t.next=12;break;case 6:u=s.get("command-line",{throwError:false});if(!u){t.next=11;break}t.next=10;return u();case 10:a=t.sent;case 11:if(a&&!K(a)){process.cwd();o=i.join(i.dirname(a.car.valueOf()),o)}case 12:W.set(c,i.dirname(o));oi("fs").readFile(o,function(e,t){if(e){n(e);W.set(c,f)}else{try{l(t).then(function(){r();W.set(c,f)})["catch"](n)}catch(e){n(e)}}});case 14:case"end":return t.stop()}},e)}));return function(e,t){return r.apply(this,arguments)}}())}if(f){f=f.valueOf();o=f+"/"+o.replace(/^\.?\/?/,"")}return n(o).then(function(e){W.set(c,o.replace(/\/[^/]*$/,""));return l(e)}).then(function(){})["finally"](function(){W.set(c,f)})},"(load filename)\n (load filename environment)\n\n Fetches the file (from disk or network) and evaluates its content as LIPS code.\n If the second argument is provided and it's an environment the evaluation\n will happen in that environment."),while:l(new J("while",function(e,t){var r=e.car;var n=q(q({},t),{},{env:this});var i=new $(new Y("begin"),e.cdr);return function t(){return w(k(r,n),function(e){if(e){return w(k(i,n),t)}})}()}),"(while cond body)\n\n Creates a loop, it executes cond and body until cond expression is false."),do:l(new J("do",function(){var r=ie(function(h,e){var p=this;var _=e.use_dynamic,d=e.error;return C.mark(function e(){var r,n,o,s,i,c,f,u,a,l;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:r=p;n=r;o=r.inherit("do");s=h.car;i=h.cdr.car;c=h.cdr.cdr;if(!K(c)){c=new $(Y("begin"),c)}f={env:r,dynamic_env:n,use_dynamic:_,error:d};u=s;case 9:if(K(u)){t.next=20;break}a=u.car;t.t0=o;t.t1=a.car;t.next=15;return k(a.cdr.car,f);case 15:t.t2=t.sent;t.t0.set.call(t.t0,t.t1,t.t2);u=u.cdr;t.next=9;break;case 20:f={env:o,dynamic_env:n,error:d};l=C.mark(function e(){var r,n,i,u,a;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(K(c)){t.next=3;break}t.next=3;return Mc.evaluate(c,f);case 3:r=s;n={};case 5:if(K(r)){t.next=15;break}i=r.car;if(K(i.cdr.cdr)){t.next=12;break}t.next=10;return k(i.cdr.cdr.car,f);case 10:u=t.sent;n[i.car.valueOf()]=u;case 12:r=r.cdr;t.next=5;break;case 15:a=Object.getOwnPropertySymbols(n);Object.keys(n).concat(a).forEach(function(e){o.set(e,n[e])});case 17:case"end":return t.stop()}},e)});case 22:t.next=24;return k(i.car,f);case 24:t.t3=t.sent;if(!(t.t3===false)){t.next=29;break}return t.delegateYield(l(),"t4",27);case 27:t.next=22;break;case 29:if(K(i.cdr)){t.next=33;break}t.next=32;return k(i.cdr.car,f);case 32:return t.abrupt("return",t.sent);case 33:case"end":return t.stop()}},e)})()});return function(e,t){return r.apply(this,arguments)}}()),"(do (( )) (test return) . body)\n\n Iteration macro that evaluates the expression body in scope of the variables.\n On each loop it changes the variables according to the expression and runs\n test to check if the loop should continue. If test is a single value, the macro\n will return undefined. If the test is a pair of expressions the macro will\n evaluate and return the second expression after the loop exits."),if:l(new J("if",function(r,e){var t=e.error,n=e.use_dynamic;var i=this;var u=this;var a={env:u,dynamic_env:i,use_dynamic:n,error:t};var o=function e(t){if(t===false){return k(r.cdr.cdr.car,a)}else{return k(r.cdr.car,a)}};if(K(r)){throw new Error("too few expressions for `if`")}var s=k(r.car,a);return w(s,o)}),"(if cond true-expr false-expr)\n\n Macro that evaluates cond expression and if the value is true, it\n evaluates and returns true-expression, if not it evaluates and returns\n false-expression."),"let-env":new J("let-env",function(t){var e=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};var r=e.dynamic_env,n=e.use_dynamic,i=e.error;F("let-env",t,"pair");var u=k(t.car,{env:this,dynamic_env:r,error:i,use_dynamic:n});return w(u,function(e){F("let-env",e,"environment");return k($(Y("begin"),t.cdr),{env:e,dynamic_env:r,error:i})})},"(let-env env . body)\n\n Special macro that evaluates body in context of given environment\n object."),letrec:l(Ao(Symbol["for"]("letrec")),"(letrec ((a value-a) (b value-b) ...) . body)\n\n Macro that creates a new environment, then evaluates and assigns values to\n names and then evaluates the body in context of that environment.\n Values are evaluated sequentially and the next value can access the\n previous values/names."),"letrec*":l(Ao(Symbol["for"]("letrec")),"(letrec* ((a value-a) (b value-b) ...) . body)\n\n Same as letrec but the order of execution of the binding is guaranteed,\n so you can use recursive code as well as referencing the previous binding.\n\n In LIPS both letrec and letrec* behave the same."),"let*":l(Ao(Symbol["for"]("let*")),"(let* ((a value-a) (b value-b) ...) . body)\n\n Macro similar to `let`, but the subsequent bindings after the first\n are evaluated in the environment including the previous let variables,\n so you can define one variable, and use it in the next's definition."),let:l(Ao(Symbol["for"]("let")),"(let ((a value-a) (b value-b) ...) . body)\n\n Macro that creates a new environment, then evaluates and assigns values to names,\n and then evaluates the body in context of that environment. Values are evaluated\n sequentially but you can't access previous values/names when the next are\n evaluated. You can only get them in the body of the let expression. (If you want\n to define multiple variables and use them in each other's definitions, use\n `let*`.)"),"begin*":l(xo("begin*",function(e){return e.pop()}),"(begin* . body)\n\n This macro is a parallel version of begin. It evaluates each expression\n in the body and if it's a promise it will await it in parallel and return\n the value of the last expression (i.e. it uses Promise.all())."),shuffle:l("shuffle",function(e){F("shuffle",e,["pair","nil","array"]);var t=W.get("random");if(K(e)){return V}if(Array.isArray(e)){return ta(e.slice(),t)}var r=W.get("list->array")(e);r=ta(r,t);return W.get("array->list")(r)},"(shuffle obj)\n\n Order items in vector or list in random order."),begin:l(new J("begin",function(e,t){var n=q(q({},t),{},{env:this});var i=W.get("list->array")(e);var u;return function t(){if(i.length){var e=i.shift();var r=k(e,n);return w(r,function(e){u=e;return t()})}else{return u}}()}),"(begin . args)\n\n Macro that runs a list of expressions in order and returns the value\n of the last one. It can be used in places where you can only have a\n single expression, like (if)."),ignore:new J("ignore",function(e,t){var r=q(q({},t),{},{env:this,dynamic_env:this});k(new $(new Y("begin"),e),r)},"(ignore . body)\n\n Macro that will evaluate the expression and swallow any promises that may\n be created. It will discard any value that may be returned by the last body\n expression. The code should have side effects and/or when it's promise\n it should resolve to undefined."),"call/cc":l(J.defmacro("call/cc",function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};var r=q({env:this},t);return w(k(e.car,r),function(e){if(d(e)){return e(new tc(null))}})}),"(call/cc proc)\n\n Call-with-current-continuation.\n\n NOT SUPPORTED BY LIPS RIGHT NOW"),parameterize:l(new J("parameterize",function(t,e){var i=e.dynamic_env;var u=i.inherit("parameterize").new_frame(null,{});var a=q(q({},e),{},{env:this});var o=t.car;if(!H(o)){var r=Ys(o);throw new Error("Invalid syntax for parameterize expecting pair got ".concat(r))}function s(){var e=new $(new Y("begin"),t.cdr);return k(e,q(q({},a),{},{dynamic_env:u}))}return function r(){var e=o.car;var n=e.car.valueOf();return w(k(e.cdr.car,a),function(e){var t=i.get(n,{throwError:false});if(!La(t)){throw new Error("Unknown parameter ".concat(n))}u.set(n,t.inherit(e));if(!Na(o.cdr)){o=o.cdr;return r()}else{return s()}})}()}),"(parameterize ((name value) ...)\n\n Macro that change the dynamic variable created by make-parameter."),"make-parameter":l(new J("make-parameter",function(e,t){t.dynamic_env;var r=k(e.car,t);var n;if(H(e.cdr.car)){n=k(e.cdr.car,t)}return new Zs(r,n)}),"(make-parameter init converter)\n\n Function creates new dynamic variable that can be custimized with parameterize\n macro. The value should be assigned to a variable e.g.:\n\n (define radix (make-parameter 10))\n\n The result value is a procedure that return the value of dynamic variable."),"define-syntax-parameter":l(new J("define-syntax-parameter",function(e,t){var r=e.car;var n=this;if(!(r instanceof Y)){throw new Error("define-syntax-parameter: invalid syntax expecting symbol got ".concat(Ys(r)))}var i=k(e.cdr.car,q({env:n},t));F("define-syntax-parameter",i,"syntax",2);i.__name__=r.valueOf();if(i.__name__ instanceof D){i.__name__=i.__name__.valueOf()}var u;if(H(e.cdr.cdr)&&D.isString(e.cdr.cdr.car)){u=e.cdr.cdr.car.valueOf()}n.set(e.car,new Ba(i),u,true)}),"(define-syntax-parameter name syntax [__doc__])\n\n Binds to the transformer obtained by evaluating .\n The transformer provides the default expansion for the syntax parameter,\n and in the absence of syntax-parameterize, is functionally equivalent to\n define-syntax."),"syntax-parameterize":l(new J("syntax-parameterize",function(e,t){var r=W.get("list->array")(e.car);var n=this.inherit("syntax-parameterize");while(r.length){var i=r.shift();if(!(H(i)||i.car instanceof Y)){var u="invalid syntax for syntax-parameterize: ".concat(ia(e,true));throw new Error("syntax-parameterize: ".concat(u))}var a=k(i.cdr.car,q(q({},t),{},{env:this}));var o=i.car;F("syntax-parameterize",a,["syntax"]);F("syntax-parameterize",o,"symbol");a.__name__=o.valueOf();if(a.__name__ instanceof D){a.__name__=a.__name__.valueOf()}var s=new Ba(a);if(o.is_gensym()){var c=o.literal();var f=this.get(c,{throwError:false});if(f instanceof Ba){n.set(c,s)}}n.set(o,s)}var l=new $(new Y("begin"),e.cdr);return k(l,q(q({},t),{},{env:n}))}),"(syntax-parameterize (bindings) body)\n\n Macro work similar to let-syntax but the the bindnds will be exposed to the user.\n With syntax-parameterize you can define anaphoric macros."),define:l(J.defmacro("define",function(r,e){var n=this;if(H(r.car)&&r.car.car instanceof Y){var t=new $(new Y("define"),new $(r.car.car,new $(new $(new Y("lambda"),new $(r.car.cdr,r.cdr)))));return t}else if(e.macro_expand){return}e.dynamic_env=this;e.env=n;var i=r.cdr.car;var u;if(H(i)){i=k(i,e);u=true}else if(i instanceof Y){i=n.get(i)}F("define",r.car,"symbol");return w(i,function(e){if(n.__name__===Sa.__merge_env__){n=n.__parent__}if(u&&(d(e)&&bo(e)||e instanceof Sa||La(e))){e.__name__=r.car.valueOf();if(e.__name__ instanceof D){e.__name__=e.__name__.valueOf()}}var t;if(H(r.cdr.cdr)&&D.isString(r.cdr.cdr.car)){t=r.cdr.cdr.car.valueOf()}n.set(r.car,e,t,true)})}),'(define name expression)\n (define name expression "doc string")\n (define (function-name . args) . body)\n\n Macro for defining values. It can be used to define variables,\n or functions. If the first argument is list it will create a function\n with name being first element of the list. This form expands to\n `(define function-name (lambda args body))`'),"set-obj!":l("set-obj!",function(e,t,r){var n=arguments.length>3&&arguments[3]!==undefined?arguments[3]:null;var i=p(e);if(Na(e)||i!=="object"&&i!=="function"){var u=Ts("set-obj!",Ys(e),["object","function"]);throw new Error(u)}F("set-obj!",t,["string","symbol","number"]);e=Xa(e);t=t.valueOf();if(arguments.length===2){delete e[t]}else if(ga(e)&&d(r)){e[t]=Xa(r);e[t][po]=true}else if(d(r)||Ka(r)||K(r)){e[t]=r}else{e[t]=r&&!ga(r)?r.valueOf():r}if(aa){var a=e[t];Object.defineProperty(e,t,q(q({},n),{},{value:a}))}},"(set-obj! obj key value)\n (set-obj! obj key value props)\n\n Function set a property of a JavaScript object. props should be a vector of pairs,\n passed to Object.defineProperty."),"null-environment":l("null-environment",function(){return W.inherit("null")},"(null-environment)\n\n Returns a clean environment with only the standard library."),values:l("values",function e(){for(var t=arguments.length,r=new Array(t),n=0;n1&&arguments[1]!==undefined?arguments[1]:{},y=e.use_dynamic,m=e.error;var g=this;var b;if(H(v.cdr)&&D.isString(v.cdr.car)&&!K(v.cdr.cdr)){b=v.cdr.car.valueOf()}function w(){var e=Ta(this)?this:{dynamic_env:g},r=e.dynamic_env;var n=g.inherit("lambda");r=r.inherit("lambda");if(this&&!Ta(this)){if(this&&!this.__instance__){Object.defineProperty(this,"__instance__",{enumerable:false,get:function e(){return true},set:function e(){},configurable:false})}n.set("this",this)}for(var t=arguments.length,i=new Array(t),u=0;u> SYNTAX");z(e);z(m);var n=w.inherit("syntax");var i=n;var u=this;if(u.__name__===Sa.__merge_env__){var a=Object.getOwnPropertySymbols(u.__env__);a.forEach(function(e){u.__parent__.set(e,u.__env__[e])});u=u.__parent__}var o={env:n,dynamic_env:i,use_dynamic:g,error:b};var s,c,f;if(m.car instanceof Y){s=m.car;f=D(m.cdr.car);c=m.cdr.cdr}else{s="...";f=D(m.car);c=m.cdr}try{while(!K(c)){var l=c.car.car;var h=c.car.cdr.car;z("[[[ RULE");z(l);var p=ja(l,e,f,s,{expansion:this,define:w});if(p){if(fi()){console.log(JSON.stringify(ha(p),true,2));console.log("PATTERN: "+l.toString(true));console.log("MACRO: "+e.toString(true))}var _=[];var d=Pa({bindings:p,expr:h,symbols:f,scope:n,lex_scope:u,names:_,ellipsis:s});z("OUPUT>>> ",d);if(d){h=d}var v=u.merge(n,Sa.__merge_env__);if(r){return{expr:h,scope:v}}var y=k(h,q(q({},o),{},{env:v}));return Ia(y,_)}c=c.cdr}}catch(e){e.message+="\nin macro:\n ".concat(m.toString(true));throw e}throw new Error("syntax-rules: no matching syntax in macro ".concat(e.toString(true)))},w);r.__code__=m;return r},"(syntax-rules () (pattern expression) ...)\n\n Base of hygienic macros, it will return a new syntax expander\n that works like Lisp macros."),quote:l(new J("quote",function(e){return ms(e.car)}),"(quote expression) or 'expression\n\n Macro that returns a single LIPS expression as data (it won't evaluate the\n argument). It will return a list if put in front of LIPS code.\n And if put in front of a symbol it will return the symbol itself, not the value\n bound to that name."),"unquote-splicing":l("unquote-splicing",function(){throw new Error("You can't call `unquote-splicing` outside of quasiquote")},"(unquote-splicing code) or ,@code\n\n Special form used in the quasiquote macro. It evaluates the expression inside and\n splices the list into quasiquote's result. If it is not the last element of the\n expression, the computed value must be a pair."),unquote:l("unquote",function(){throw new Error("You can't call `unquote` outside of quasiquote")},"(unquote code) or ,code\n\n Special form used in the quasiquote macro. It evaluates the expression inside and\n substitutes the value into quasiquote's result."),quasiquote:J.defmacro("quasiquote",function(e,t){var o=t.use_dynamic,s=t.error;var c=this;var f=c;function u(e){return H(e)||ua(e)||Array.isArray(e)}function l(e,t){var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:u;if(H(e)){var n=e.car;var i=e.cdr;if(r(n)){n=t(n)}if(r(i)){i=t(i)}if(za(n)||za(i)){return lu([n,i]).then(function(e){var t=b(e,2),r=t[0],n=t[1];return new $(r,n)})}else{return new $(n,i)}}return e}function a(e,t){if(H(e)){if(!K(t)){e.append(t)}}else{e=new $(e,t)}return e}function r(e){return!!e.filter(function(e){return H(e)&&Y.is(e.car,/^(unquote|unquote-splicing)$/)}).length}function h(e,n,i){return e.reduce(function(e,t){if(!H(t)){e.push(t);return e}if(Y.is(t.car,"unquote-splicing")){var r;if(n+11){var t="You can't splice multiple atoms inside list";throw new Error(t)}if(!(H(i.cdr)&&K(r[0]))){return r[0]}}r=r.map(function(e){if(d.has(e)){return e.clone()}else{d.add(e);return e}});var n=v(i.cdr,0,1);if(K(n)&&K(r[0])){return undefined}return w(n,function(e){if(K(r[0])){return e}if(r.length===1){return a(r[0],e)}var t=r.reduce(function(e,t){return a(e,t)});return a(t,e)})})}(i.car.cdr)}var d=new Set;function v(e,t,r){if(H(e)){if(H(e.car)){if(Y.is(e.car.car,"unquote-splicing")){return _(e,t+1,r)}if(Y.is(e.car.car,"unquote")){if(t+2===r&&H(e.car.cdr)&&H(e.car.cdr.car)&&Y.is(e.car.cdr.car.car,"unquote-splicing")){var n=e.car.cdr;return new $(new $(new Y("unquote"),_(n,t+2,r)),V)}else if(H(e.car.cdr)&&!K(e.car.cdr.cdr)){if(H(e.car.cdr.car)){var i=[];return function t(r){if(K(r)){return $.fromArray(i)}return w(k(r.car,{env:c,dynamic_env:f,use_dynamic:o,error:s}),function(e){i.push(e);return t(r.cdr)})}(e.car.cdr)}else{return e.car.cdr}}}}if(Y.is(e.car,"quasiquote")){var u=v(e.cdr,t,r+1);return new $(e.car,u)}if(Y.is(e.car,"quote")){return new $(e.car,v(e.cdr,t,r))}if(Y.is(e.car,"unquote")){t++;if(tr){throw new Error("You can't call `unquote` outside "+"of quasiquote")}if(H(e.cdr)){if(!K(e.cdr.cdr)){if(H(e.cdr.car)){var a=[];return function t(r){if(K(r)){return $.fromArray(a)}return w(k(r.car,{env:c,dynamic_env:f,use_dynamic:o,error:s}),function(e){a.push(e);return t(r.cdr)})}(e.cdr)}else{return e.cdr}}else{return k(e.cdr.car,{env:c,dynamic_env:f,error:s})}}else{return e.cdr}}return l(e,function(e){return v(e,t,r)})}else if(ua(e)){return p(e,t,r)}else if(e instanceof Array){return h(e,t,r)}return e}function n(e){if(H(e)){delete e[so];if(!e.haveCycles("car")){n(e.car)}if(!e.haveCycles("cdr")){n(e.cdr)}}}if(ua(e.car)&&!r(Object.values(e.car))){return ms(e.car)}if(Array.isArray(e.car)&&!r(e.car)){return ms(e.car)}if(H(e.car)&&!e.car.find("unquote")&&!e.car.find("unquote-splicing")&&!e.car.find("quasiquote")){return ms(e.car)}var i=v(e.car,0,1);return w(i,function(e){n(e);return ms(e)})},"(quasiquote list)\n\n Similar macro to `quote` but inside it you can use special expressions (unquote\n x) abbreviated to ,x that will evaluate x and insert its value verbatim or\n (unquote-splicing x) abbreviated to ,@x that will evaluate x and splice the value\n into the result. Best used with macros but it can be used outside."),clone:l("clone",function e(t){F("clone",t,"pair");return t.clone()},"(clone list)\n\n Function that returns a clone of the list, that does not share any pairs with the\n original, so the clone can be safely mutated without affecting the original."),append:l("append",function e(){var t;for(var r=arguments.length,n=new Array(r),i=0;iarray")(t).reverse();return W.get("array->list")(r)}else if(Array.isArray(t)){return t.reverse()}else{throw new Error(Ts("reverse",Ys(t),"array or pair"))}},"(reverse list)\n\n Function that reverses the list or array. If value is not a list\n or array it will error."),nth:l("nth",function e(t,r){F("nth",t,"number");F("nth",r,["array","pair"]);if(H(r)){var n=r;var i=0;while(iarray")(r).join(t)},"(join separator list)\n\n Function that returns a string by joining elements of the list using separator."),split:l("split",function e(t,r){F("split",t,["regex","string"]);F("split",r,"string");return W.get("array->list")(r.split(t))},"(split separator string)\n\n Function that creates a list by splitting string by separator which can\n be a string or regular expression."),replace:l("replace",function e(t,r,n){F("replace",t,["regex","string"]);F("replace",r,["string","function"]);F("replace",n,"string");return n.replace(t,r)},"(replace pattern replacement string)\n\n Function that changes pattern to replacement inside string. Pattern can be a\n string or regex and replacement can be function or string. See Javascript\n String.replace()."),match:l("match",function e(t,r){F("match",t,["regex","string"]);F("match",r,"string");var n=r.match(t);return n?W.get("array->list")(n):false},"(match pattern string)\n\n Function that returns a match object from JavaScript as a list or #f if\n no match."),search:l("search",function e(t,r){F("search",t,["regex","string"]);F("search",r,"string");return r.search(t)},"(search pattern string)\n\n Function that returns the first found index of the pattern inside a string."),repr:l("repr",function e(t,r){return ma(t,r)},"(repr obj)\n\n Function that returns a LIPS code representation of the object as a string."),"escape-regex":l("escape-regex",function(e){F("escape-regex",e,"string");return Qi(e.valueOf())},"(escape-regex string)\n\n Function that returns a new string where all special operators used in regex,\n are escaped with backslashes so they can be used in the RegExp constructor\n to match a literal string."),env:l("env",function e(e){e=e||this.env;var t=Object.keys(e.__env__).map(Y);var r;if(t.length){r=$.fromArray(t)}else{r=V}if(e.__parent__ instanceof x){return W.get("env").call(this,e.__parent__).append(r)}return r},"(env)\n (env obj)\n\n Function that returns a list of names (functions, macros and variables)\n that are bound in the current environment or one of its parents."),new:l("new",function(e){for(var t=arguments.length,r=new Array(t>1?t-1:0),n=1;n2&&arguments[2]!==undefined?arguments[2]:_u.LITERAL;F("set-special!",e,"string",1);F("set-special!",t,"symbol",2);_u.append(e.valueOf(),t,r)},'(set-special! symbol name [type])\n\n Add a special symbol to the list of transforming operators by the parser.\n e.g.: `(add-special! "#" \'x)` will allow to use `#(1 2 3)` and it will be\n transformed into (x (1 2 3)) so you can write x macro that will process\n the list. 3rd argument is optional, and it can be one of two values:\n lips.specials.LITERAL, which is the default behavior, or\n lips.specials.SPLICE which causes the value to be unpacked into the expression.\n This can be used for e.g. to make `#(1 2 3)` into (x 1 2 3) that is needed\n by # that defines vectors.'),get:bs,".":bs,unbind:l(Xa,"(unbind fn)\n\n Function that removes the weak 'this' binding from a function so you\n can get properties from the actual function object."),type:l(Ys,"(type object)\n\n Function that returns the type of an object as string."),debugger:l("debugger",function(){debugger},'(debugger)\n\n Function that triggers the JavaScript debugger (e.g. the browser devtools)\n using the "debugger;" statement. If a debugger is not running this\n function does nothing.'),in:l("in",function(e,t){if(e instanceof Y||e instanceof D||e instanceof B){e=e.valueOf()}return e in Qa(t)},'(in key value)\n\n Function that uses the Javascript "in" operator to check if key is\n a valid property in the value.'),"instance?":l("instance?",function(e){return $a(e)},"(instance? obj)\n\n Checks if object is an instance, created with a new operator"),instanceof:l("instanceof",function(e,t){return t instanceof Xa(e)},"(instanceof type obj)\n\n Predicate that tests if the obj is an instance of type."),"prototype?":l("prototype?",ga,"(prototype? obj)\n\n Predicate that tests if value is a valid JavaScript prototype,\n i.e. calling (new) with it will not throw ' is not a constructor'."),"macro?":l("macro?",function(e){return e instanceof J},"(macro? expression)\n\n Predicate that tests if value is a macro."),"continuation?":l("continuation?",Ra,"(continuation? expression)\n\n Predicate that tests if value is a callable continuation."),"function?":l("function?",d,"(function? expression)\n\n Predicate that tests if value is a callable function."),"real?":l("real?",function(e){if(Ys(e)!=="number"){return false}if(e instanceof B){return e.isFloat()}return B.isFloat(e)},"(real? number)\n\n Predicate that tests if value is a real number (not complex)."),"number?":l("number?",function(e){return Number.isNaN(e)||B.isNumber(e)},"(number? expression)\n\n Predicate that tests if value is a number or NaN value."),"string?":l("string?",function(e){return D.isString(e)},"(string? expression)\n\n Predicate that tests if value is a string."),"pair?":l("pair?",H,"(pair? expression)\n\n Predicate that tests if value is a pair or list structure."),"regex?":l("regex?",function(e){return e instanceof RegExp},"(regex? expression)\n\n Predicate that tests if value is a regular expression."),"null?":l("null?",function(e){return Na(e)},"(null? expression)\n\n Predicate that tests if value is null-ish (i.e. undefined, nil, or\n Javascript null)."),"boolean?":l("boolean?",function(e){return typeof e==="boolean"},"(boolean? expression)\n\n Predicate that tests if value is a boolean (#t or #f)."),"symbol?":l("symbol?",function(e){return e instanceof Y},"(symbol? expression)\n\n Predicate that tests if value is a LIPS symbol."),"array?":l("array?",function(e){return e instanceof Array},"(array? expression)\n\n Predicate that tests if value is an array."),"object?":l("object?",function(e){return!K(e)&&e!==null&&!(e instanceof h)&&!(e instanceof RegExp)&&!(e instanceof D)&&!H(e)&&!(e instanceof B)&&p(e)==="object"&&!(e instanceof Array)},"(object? expression)\n\n Predicate that tests if value is an plain object (not another LIPS type)."),flatten:l("flatten",function e(t){F("flatten",t,"pair");return t.flatten()},"(flatten list)\n\n Returns a shallow list from tree structure (pairs)."),"array->list":l("array->list",function(e){F("array->list",e,"array");return $.fromArray(e)},"(array->list array)\n\n Function that converts a JavaScript array to a LIPS cons list."),"tree->array":l("tree->array",na("tree->array",true),"(tree->array list)\n\n Function that converts a LIPS cons tree structure into a JavaScript array."),"list->array":l("list->array",na("list->array"),"(list->array list)\n\n Function that converts a LIPS list into a JavaScript array."),apply:l("apply",function e(t){for(var r=arguments.length,n=new Array(r>1?r-1:0),i=1;iarray").call(this,u));return t.apply(this,Hs(t,n))},"(apply fn list)\n\n Function that calls fn with the list of arguments."),length:l("length",function e(t){if(!t||K(t)){return 0}if(H(t)){return t.length()}if("length"in t){return t.length}},'(length expression)\n\n Function that returns the length of the object. The object can be a LIPS\n list or any object that has a "length" property. Returns undefined if the\n length could not be found.'),"string->number":l("string->number",function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:10;F("string->number",e,"string",1);F("string->number",t,"number",2);e=e.valueOf();t=t.valueOf();if(e.match(ji)||e.match(Oi)){return Ti(e,t)}else if(e.match(Ii)||e.match(Ci)){return Ui(e,t)}else{var r=t===10&&!e.match(/e/i)||t===16;if(e.match(Bi)&&r||e.match(Si)){return Li(e,t)}if(e.match(mi)){return Vi(e)}}return false},"(string->number number [radix])\n\n Function that parses a string into a number."),try:l(new J("try",function(r,e){var l=this;var h=e.use_dynamic;e.error;return new Promise(function(t,o){var s,n;if(Y.is(r.cdr.car.car,"catch")){s=r.cdr.car;if(H(r.cdr.cdr)&&Y.is(r.cdr.cdr.car.car,"finally")){n=r.cdr.cdr.car}}else if(Y.is(r.cdr.car.car,"finally")){n=r.cdr.car}if(!(n||s)){throw new Error("try: invalid syntax")}function c(e){t(e);throw new ds("[CATCH]")}var f=function e(t,r){r(t)};if(n){f=function e(t,r){f=o;i.error=function(e){throw e};w(k(new $(new Y("begin"),n.cdr),i),function(){r(t)})}}var i={env:l,use_dynamic:h,dynamic_env:l,error:function e(t){if(t instanceof ds){throw t}var r=l.inherit("try");if(s){var n=s.cdr.car.car;if(!(n instanceof Y)){throw new Error("try: invalid syntax: catch require variable name")}r.set(n,t);var i;var u={env:r,use_dynamic:h,dynamic_env:l,error:function e(t){i=true;o(t);throw new ds("[CATCH]")}};var a=k(new $(new Y("begin"),s.cdr.cdr),u);w(a,function e(t){if(!i){f(t,c)}})}else{f(undefined,function(){throw t})}}};var e=k(r.car,i);w(e,function(e){f(e,t)},i.error)})}),"(try expr (catch (e) code))\n (try expr (catch (e) code) (finally code))\n (try expr (finally code))\n\n Macro that executes expr and catches any exceptions thrown. If catch is provided\n it's executed when an error is thrown. If finally is provided it's always\n executed at the end."),raise:l("raise",function(e){throw e},"(raise obj)\n\n Throws the object verbatim (no wrapping an a new Error)."),throw:l("throw",function(e){throw new Error(e)},"(throw string)\n\n Throws a new exception."),find:l("find",function t(r,n){F("find",r,["regex","function"]);F("find",n,["pair","nil"]);if(Na(n)){return V}var e=Su("find",r);return w(e(n.car),function(e){if(e&&!K(e)){return n.car}return t(r,n.cdr)})},"(find fn list)\n (find regex list)\n\n Higher-order function that finds the first value for which fn return true.\n If called with a regex it will create a matcher function."),"for-each":l("for-each",function(e){var t;F("for-each",e,"function");for(var r=arguments.length,n=new Array(r>1?r-1:0),i=1;i1?t-1:0),u=1;u3?n-3:0),u=3;u3?i-3:0),a=3;aarray")(r);var u=[];var a=Su("filter",t);return function t(r){function e(e){if(e&&!K(e)){u.push(n)}return t(++r)}if(r===i.length){return $.fromArray(u)}var n=i[r];return w(a(n),e)}(0)},"(filter fn list)\n (filter regex list)\n\n Higher-order function that calls `fn` for each element of the list\n and return a new list for only those elements for which fn returns\n a truthy value. If called with a regex it will create a matcher function."),compose:l(Co,"(compose . fns)\n\n Higher-order function that creates a new function that applies all functions\n from right to left and returns the last value. Reverse of pipe.\n e.g.:\n ((compose (curry + 2) (curry * 3)) 10) --\x3e (+ 2 (* 3 10)) --\x3e 32"),pipe:l(ko,"(pipe . fns)\n\n Higher-order function that creates a new function that applies all functions\n from left to right and returns the last value. Reverse of compose.\n e.g.:\n ((pipe (curry + 2) (curry * 3)) 10) --\x3e (* 3 (+ 2 10)) --\x3e 36"),curry:l(Po,"(curry fn . args)\n\n Higher-order function that creates a curried version of the function.\n The result function will have partially applied arguments and it\n will keep returning one-argument functions until all arguments are provided,\n then it calls the original function with the accumulated arguments.\n\n e.g.:\n (define (add a b c d) (+ a b c d))\n (define add1 (curry add 1))\n (define add12 (add 2))\n (display (add12 3 4))"),gcd:l("gcd",function e(){for(var t=arguments.length,r=new Array(t),n=0;no?u%=o:o%=u}u=wa(s*r[a])/(u+o)}return B(u)},"(lcm n1 n2 ...)\n\n Function that returns the least common multiple of the arguments."),"odd?":l("odd?",Bo(function(e){return B(e).isOdd()}),"(odd? number)\n\n Checks if number is odd."),"even?":l("even?",Bo(function(e){return B(e).isEven()}),"(even? number)\n\n Checks if number is even."),"*":l("*",Io(function(e,t){return B(e).mul(t)},B(1)),"(* . numbers)\n\n Multiplies all numbers passed as arguments. If single value is passed\n it will return that value."),"+":l("+",Io(function(e,t){return B(e).add(t)},B(0)),"(+ . numbers)\n\n Sums all numbers passed as arguments. If single value is passed it will\n return that value."),"-":l("-",function(){for(var e=arguments.length,t=new Array(e),r=0;r":l(">",function(){for(var e=arguments.length,t=new Array(e),r=0;r",t,["bigint","float","rational"]);return Da(function(e,t){return B(e).cmp(t)===1},t)},"(> x1 x2 x3 ...)\n\n Function that compares its numerical arguments and checks if they are\n monotonically decreasing, i.e. x1 > x2 and x2 > x3 and so on."),"<":l("<",function(){for(var e=arguments.length,t=new Array(e),r=0;r=":l(">=",function(){for(var e=arguments.length,t=new Array(e),r=0;r=",t,["bigint","float","rational"]);return Da(function(e,t){return[0,1].includes(B(e).cmp(t))},t)},"(>= x1 x2 ...)\n\n Function that compares its numerical arguments and checks if they are\n monotonically nonincreasing, i.e. x1 >= x2 and x2 >= x3 and so on."),"eq?":l("eq?",Ea,"(eq? a b)\n\n Function that compares two values if they are identical."),or:l(new J("or",function(e,t){var i=t.use_dynamic,u=t.error;var a=W.get("list->array")(e);var o=this;var s=o;if(!a.length){return false}var c;return function t(){function e(e){c=e;if(c!==false){return c}else{return t()}}if(!a.length){if(c!==false){return c}else{return false}}else{var r=a.shift();var n=k(r,{env:o,dynamic_env:s,use_dynamic:i,error:u});return w(n,e)}}()}),"(or . expressions)\n\n Macro that executes the values one by one and returns the first that is\n a truthy value. If there are no expressions that evaluate to true it\n returns false."),and:l(new J("and",function(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},r=t.use_dynamic,n=t.error;var i=W.get("list->array")(e);var u=this;var a=u;if(!i.length){return true}var o;var s={env:u,dynamic_env:a,use_dynamic:r,error:n};return function t(){function e(e){o=e;if(o===false){return false}else{return t()}}if(!i.length){if(o!==false){return o}else{return false}}else{var r=i.shift();return w(k(r,s),e)}}()}),"(and . expressions)\n\n Macro that evaluates each expression in sequence and if any value returns false\n it will stop and return false. If each value returns true it will return the\n last value. If it's called without arguments it will return true."),"|":l("|",function(e,t){return B(e).or(t)},"(| a b)\n\n Function that calculates the bitwise or operation."),"&":l("&",function(e,t){return B(e).and(t)},"(& a b)\n\n Function that calculates the bitwise and operation."),"~":l("~",function(e){return B(e).neg()},"(~ number)\n\n Function that calculates the bitwise inverse (flip all the bits)."),">>":l(">>",function(e,t){return B(e).shr(t)},"(>> a b)\n\n Function that right shifts the value a by value b bits."),"<<":l("<<",function(e,t){return B(e).shl(t)},"(<< a b)\n\n Function that left shifts the value a by value b bits."),not:l("not",function e(t){if(Na(t)){return true}return!t},"(not object)\n\n Function that returns the Boolean negation of its argument.")},undefined,"global");var Fs=W.inherit("user-env");function ks(e,t){e.constant("**internal-env**",t);e.doc("**internal-env**","**internal-env**\n\n Constant used to hide stdin, stdout and stderr so they don't interfere\n with variables with the same name. Constants are an internal type\n of variable that can't be redefined, defining a variable with the same name\n will throw an error.");W.set("**interaction-environment**",e)}ks(Fs,Es);W.doc("**interaction-environment**","**interaction-environment**\n\n Internal dynamic, global variable used to find interpreter environment.\n It's used so the read and write functions can locate **internal-env**\n that contains the references to stdin, stdout and stderr.");function Cs(e){Fs.get("**internal-env**").set("fs",e)}(function(){var e={ceil:"ceiling"};["floor","round","ceil"].forEach(function(t){var r=e[t]?e[t]:t;W.set(r,l(r,function(e){F(r,e,"number");if(e instanceof B){return e[t]()}},"(".concat(r," number)\n\n Function that calculates the ").concat(r," of a number.")))})})();function Os(e){if(e.length===1){return e[0]}else{var t=[];var r=Os(e.slice(1));for(var n=0;n3&&arguments[3]!==undefined?arguments[3]:null;var i=e?" in expression `".concat(e,"`"):"";if(n!==null){i+=" (argument ".concat(n,")")}if(d(r)){return"Invalid type: got ".concat(t).concat(i)}if(r instanceof Array){if(r.length===1){var u=r[0].toLowerCase();r="a"+("aeiou".includes(u)?"n ":" ")+r[0]}else{r=new Intl.ListFormat("en",{style:"long",type:"disjunction"}).format(r)}}return"Expecting ".concat(r," got ").concat(t).concat(i)}function Ls(e,t,r){var n=arguments.length>3&&arguments[3]!==undefined?arguments[3]:null;F(e,t,"number",n);var i=t.__type__;var u;if(H(r)){r=r.to_array()}if(r instanceof Array){r=r.map(function(e){return e.valueOf()})}if(r instanceof Array){r=r.map(function(e){return e.valueOf().toLowerCase()});if(r.includes(i)){u=true}}else{r=r.valueOf().toLowerCase()}if(!u&&i!==r){throw new Error(Ts(e,i,r,n))}}function Ms(r,e,n){e.forEach(function(e,t){Ls(r,e,n,t+1)})}function Us(r,e,n){e.forEach(function(e,t){F(r,e,n,t+1)})}function qs(e,t,r){F(e,t,r);if(t.__type__===cs){throw new Error(Ts(e,"binary-port","textual-port"))}}function F(e,t,r){var n=arguments.length>3&&arguments[3]!==undefined?arguments[3]:null;e=e.valueOf();var i=Ys(t).toLowerCase();if(d(r)){if(!r(t)){throw new Error(Ts(e,i,r,n))}return}var u=false;if(H(r)){r=r.to_array()}if(r instanceof Array){r=r.map(function(e){return e.valueOf()})}if(r instanceof Array){r=r.map(function(e){return e.valueOf().toLowerCase()});if(r.includes(i)){u=true}}else{r=r.valueOf().toLowerCase()}if(!u&&i!==r){throw new Error(Ts(e,i,r,n))}}function zs(r){var n=new WeakMap;return function(e){var t=n.get(e);if(!t){t=r(e)}return t}}Ys=zs(Ys);function Ys(e){var t=ii.get(e);if(t){return t}if(p(e)==="object"){for(var r=0,n=Object.entries(ni);r2&&arguments[2]!==undefined?arguments[2]:{},n=r.env,i=r.dynamic_env,u=r.use_dynamic;var a=n===null||n===void 0?void 0:n.new_frame(e,t);var o=i===null||i===void 0?void 0:i.new_frame(e,t);var s=new Xs({env:a,use_dynamic:u,dynamic_env:o});return Vs(e.apply(s,t))}function Gs(n,e){var t=arguments.length>2&&arguments[2]!==undefined?arguments[2]:{},i=t.env,u=t.dynamic_env,a=t.use_dynamic,r=t.error,o=r===void 0?function(){}:r;e=$s(e,{env:i,dynamic_env:u,error:o,use_dynamic:a});return w(e,function(e){if(Do(n)){n=Xa(n)}e=Hs(n,e);var t=e.slice();var r=Ws(n,t,{env:i,dynamic_env:u,use_dynamic:a});return w(r,function(e){if(H(e)){e.markCycles();return ms(e)}return Wa(e)},o)})}var Qs=new WeakMap;var Zs=function(){function n(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:null;var r=arguments.length>2&&arguments[2]!==undefined?arguments[2]:null;ue(this,n);fe(this,"__value__",void 0);fe(this,"__fn__",void 0);Jn(this,Qs,{writable:true,value:void 0});this.__value__=e;if(t){if(!d(t)){throw new Error("Section argument to Parameter need to be function "+"".concat(Ys(t)," given"))}this.__fn__=t}if(r){j(this,Qs,r)}}ce(n,[{key:"__name__",get:function e(){return t(this,Qs)},set:function e(t){j(this,Qs,t);if(this.__fn__){this.__fn__.__name__="fn-".concat(t)}}},{key:"invoke",value:function e(){if(d(this.__fn__)){return this.__fn__(this.__value__)}return this.__value__}},{key:"inherit",value:function e(t){return new n(t,this.__fn__,this.__name__)}}]);return n}();var Xs=function(){function t(e){ue(this,t);fe(this,"env",void 0);fe(this,"dynamic_env",void 0);fe(this,"use_dynamic",void 0);Object.assign(this,e)}ce(t,[{key:"__name__",get:function e(){return this.env.__name__}},{key:"__parent__",get:function e(){return this.env.__parent__}},{key:"get",value:function e(){var t;return(t=this.env).get.apply(t,arguments)}}]);return t}();function ec(e,t){var r=e.get(t.__name__,{throwError:false});if(La(r)&&r!==t){return r}var n=Fs.get("**interaction-environment**");while(true){var i=e.get("parent.frame",{throwError:false});e=i(0);if(e===n){break}r=e.get(t.__name__,{throwError:false});if(La(r)&&r!==t){return r}}return t}var tc=function(){function t(e){ue(this,t);fe(this,"__value__",void 0);this.__value__=e}ce(t,[{key:"invoke",value:function e(){if(this.__value__===null){throw new Error("Continuations are not implemented yet")}}}]);return t}();function k(o){var e=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},s=e.env,c=e.dynamic_env,f=e.use_dynamic,t=e.error,l=t===void 0?Ps:t,r=he(e,$n);return function(e){try{if(!Ma(c)){c=s===true?Fs:s||Fs}if(f){s=c}else if(s===true){s=Fs}else{s=s||W}var t={env:s,dynamic_env:c,use_dynamic:f,error:l};var r;if(Na(o)){return o}if(o instanceof Y){return s.get(o)}if(!H(o)){return o}var n=o.car;var e=o.cdr;if(H(n)){r=Vs(k(n,t));if(za(r)){return r.then(function(e){if(!Ua(e)){throw new Error(Ys(e)+" "+s.get("repr")(e)+" is not callable while evaluating "+o.toString())}return k(new $(e,o.cdr),t)})}else if(!Ua(r)){throw new Error(Ys(r)+" "+s.get("repr")(r)+" is not callable while evaluating "+o.toString())}}if(n instanceof Y){r=s.get(n)}else if(d(n)){r=n}var i;if(r instanceof Sa){i=Js(r,o,t)}else if(r instanceof J){i=Ks(r,e,t)}else if(d(r)){i=Gs(r,e,t)}else if(r instanceof Ba){i=Js(r._syntax,o,t)}else if(La(r)){var u=ec(c,r);if(Na(o.cdr)){i=u.invoke()}else{return w(k(o.cdr.car,t),function(e){u.__value__=e})}}else if(Ra(r)){i=r.invoke()}else if(H(o)){r=n&&n.toString();throw new Error("".concat(Ys(n)," ").concat(r," is not a function"))}else{return o}var a=s.get(Symbol["for"]("__promise__"),{throwError:false});if(a===true&&za(i)){i=i.then(function(e){if(H(e)&&!r[so]){return k(e,t)}return e});return new fu(i)}return i}catch(e){l&&l.call(s,e,o)}}(r)}var rc=uc(function(e){return e});var nc=uc(function(e,t){return t});function ic(e){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},r=t.env,n=t.dynamic_env,i=t.use_dynamic;return k(e,{env:r,dynamic_env:n,use_dynamic:i,error:function e(t,r){if(t&&t.message){if(t.message.match(/^Error:/)){var n=/^(Error:)\s*([^:]+:\s*)/;t.message=t.message.replace(n,"$1 $2")}if(r){if(!(t.__code__ instanceof Array)){t.__code__=[]}t.__code__.push(r.toString(true))}}if(!(t instanceof ds)){throw t}}})}function uc(d){return function(){var t=ie(function(l){var e=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{},h=e.env,p=e.dynamic_env,_=e.use_dynamic;return C.mark(function e(){var r,n,i,u,a,o,s,c,f;return C.wrap(function e(t){while(1)switch(t.prev=t.next){case 0:if(!Ma(p)){p=h===true?Fs:h||Fs}if(h===true){h=Fs}else{h=h||Fs}r=[];if(!H(l)){t.next=8;break}t.next=6;return ic(code,{env:h,dynamic_env:p,use_dynamic:_});case 6:t.t0=t.sent;return t.abrupt("return",[t.t0]);case 8:n=Array.isArray(l)?l:Au(l);i=false;u=false;t.prev=11;o=ei(n);case 13:t.next=15;return o.next();case 15:if(!(i=!(s=t.sent).done)){t.next=31;break}c=s.value;t.next=19;return ic(c,{env:h,dynamic_env:p,use_dynamic:_});case 19:f=t.sent;t.t1=r;t.t2=d;t.t3=c;t.next=25;return f;case 25:t.t4=t.sent;t.t5=(0,t.t2)(t.t3,t.t4);t.t1.push.call(t.t1,t.t5);case 28:i=false;t.next=13;break;case 31:t.next=37;break;case 33:t.prev=33;t.t6=t["catch"](11);u=true;a=t.t6;case 37:t.prev=37;t.prev=38;if(!(i&&o["return"]!=null)){t.next=42;break}t.next=42;return o["return"]();case 42:t.prev=42;if(!u){t.next=45;break}throw a;case 45:return t.finish(42);case 46:return t.finish(37);case 47:return t.abrupt("return",r);case 48:case"end":return t.stop()}},e,null,[[11,33,37,47],[38,,42,46]])})()});function e(e){return t.apply(this,arguments)}return e}()}function ac(e){var t={"[":"]","(":")"};var r;if(typeof e==="string"){r=iu(e)}else{r=e.map(function(e){return e&&e.token?e.token:e})}var n=Object.keys(t);var i=Object.values(t).concat(n);r=r.filter(function(e){return i.includes(e)});var u=new Zi;var a=Gn(r),o;try{for(a.s();!(o=a.n()).done;){var s=o.value;if(n.includes(s)){u.push(s)}else if(!u.is_empty()){var c=u.top();var f=t[c];if(s===f){u.pop()}else{throw new Error("Syntax error: missing closing ".concat(f))}}else{throw new Error("Syntax error: not matched closing ".concat(s))}}}catch(e){a.e(e)}finally{a.f()}return u.is_empty()}function oc(e){var t="("+e.toString()+")()";var r=window.URL||window.webkitURL;var n;try{n=new Blob([t],{type:"application/javascript"})}catch(e){var i=window.BlobBuilder||window.WebKitBlobBuilder||window.MozBlobBuilder;n=new i;n.append(t);n=n.getBlob()}return new ri.Worker(r.createObjectURL(n))}function sc(){return Mc.version.match(/^(\{\{VER\}\}|DEV)$/)}function cc(){if(Is()){return}var e;if(document.currentScript){e=document.currentScript}else{var t=document.querySelectorAll("script");if(!t.length){return}e=t[t.length-1]}var r=e.getAttribute("src");return r}var fc=cc();function lc(){var e=arguments.length>0&&arguments[0]!==undefined?arguments[0]:"";var t="dist/std.xcb";if(e===""){if(fc){e=fc.replace(/[^/]*$/,"std.xcb")}else if(sc()){e="https://cdn.jsdelivr.net/gh/jcubic/lips@devel/".concat(t)}else{e="https://cdn.jsdelivr.net/npm/@jcubic/lips@".concat(Mc.version,"/").concat(t)}}var r=W.get("load");return r.call(Fs,e,W)}function hc(e){this.url=e;var a=this.worker=oc(function(){var a;var o;self.addEventListener("message",function(e){var r=e.data;var t=r.id;if(r.type!=="RPC"||t===null){return}function n(e){self.postMessage({id:t,type:"RPC",result:e})}function i(e){self.postMessage({id:t,type:"RPC",error:e})}if(r.method==="eval"){if(!o){i("Worker RPC: LIPS not initialized, call init first");return}o.then(function(){var e=r.params[0];var t=r.params[1];a.exec(e,{use_dynamic:t}).then(function(e){e=e.map(function(e){return e&&e.valueOf()});n(e)})["catch"](function(e){i(e)})})}else if(r.method==="init"){var u=r.params[0];if(typeof u!=="string"){i("Worker RPC: url is not a string")}else{importScripts("".concat(u,"/dist/lips.min.js"));a=new Mc.Interpreter("worker");o=lc(u);o.then(function(){n(true)})}}})});this.rpc=function(){var n=0;return function e(t,r){var u=++n;return new Promise(function(n,i){a.addEventListener("message",function e(t){var r=t.data;if(r&&r.type==="RPC"&&r.id===u){if(r.error){i(r.error)}else{n(r.result)}a.removeEventListener("message",e)}});a.postMessage({type:"RPC",method:t,id:u,params:r})})}}();this.rpc("init",[e])["catch"](function(e){console.error(e)});this.exec=function(e,t){var r=t.use_dynamic,n=r===void 0?false:r;return this.rpc("eval",[e,n])}}var pc={pair:function e(t){var r=b(t,2),n=r[0],i=r[1];return $(n,i)},number:function e(t){if(D.isString(t)){return B([t,10])}return B(t)},regex:function e(t){var r=b(t,2),n=r[0],i=r[1];return new RegExp(n,i)},nil:function e(){return V},symbol:function e(t){if(D.isString(t)){return Y(t)}else if(Array.isArray(t)){return Y(Symbol["for"](t[0]))}},string:D,character:h};var _c=Object.keys(pc);var dc={};for(var vc=0,yc=Object.entries(_c);vc1){var n=t.reduce(function(e,t){return e+t.length},0);var i=new Uint8Array(n);var u=0;t.forEach(function(e){i.set(e,u);u+=e.length});return i}else if(t.length){return t[0]}}function kc(){var e=1;var t=new TextEncoder("utf-8");return t.encode("LIPS".concat(e.toString().padStart(3," ")))}var Cc=7;function Oc(e){var t=new TextDecoder("utf-8");var r=t.decode(e.slice(0,Cc));var n=r.substring(0,4);if(n==="LIPS"){var i=r.match(/^(....).*([0-9]+)$/);if(i){return{type:i[1],version:Number(i[2])}}}return{type:"unknown"}}function Sc(e){var t=kc();var r=xc.encode(e);return Fc(t,Tn(r,{magic:false}))}function Bc(e){var t=Oc(e),r=t.type,n=t.version;if(r==="LIPS"&&n===1){var i=Ln(e.slice(Cc),{magic:false});return xc.decode(i)}else{throw new Error("Invalid file format ".concat(r))}}function jc(e){console.error(e.message||e);if(Array.isArray(e.code)){console.error(e.code.map(function(e,t){return"[".concat(t+1,"]: ").concat(e)}))}}function Ic(){var o=["text/x-lips","text/x-scheme"];var s;function c(r){return new Promise(function(t){var e=r.getAttribute("src");if(e){return fetch(e).then(function(e){return e.text()}).then(nc).then(t)["catch"](function(e){jc(e);t()})}else{return nc(r.innerHTML).then(t)["catch"](function(e){jc(e);t()})}})}function e(){return new Promise(function(u){var a=Array.from(document.querySelectorAll("script"));return function e(){var t=a.shift();if(!t){u()}else{var r=t.getAttribute("type");if(o.includes(r)){var n;var i=(n=t.getAttribute("bootstrap"))!==null&&n!==void 0?n:t.getAttribute("data-bootstrap");if(!s&&typeof i==="string"){return lc(i).then(function(){return c(t)}).then(e)}else{return c(t).then(e)}}else if(r&&r.match(/lips|lisp/)){console.warn("Expecting "+o.join(" or ")+" found "+r)}return e()}}()})}if(!window.document){return Promise.resolve()}else if(Pc){var t=Pc;var r=t.getAttribute("bootstrap");if(typeof r==="string"){return lc(r).then(function(){s=true;return e()})}}return e()}var Pc=typeof window!=="undefined"&&window.document&&document.currentScript;if(typeof window!=="undefined"){ci(window,Ic)}var Nc=function(){var e=D("Mon, 12 Feb 2024 14:25:33 +0000").valueOf();var t=e==="{{"+"DATE}}"?new Date:new Date(e);var r=function e(t){return t.toString().padStart(2,"0")};var n=t.getFullYear();var i=[n,r(t.getMonth()+1),r(t.getDate())].join("-");var u="\n __ __ __\n / / \\ \\ _ _ ___ ___ \\ \\\n| | \\ \\ | | | || . \\/ __> | |\n| | > \\ | |_ | || _/\\__ \\ | |\n| | / ^ \\ |___||_||_| <___/ | |\n \\_\\ /_/ \\_\\ /_/\n\nLIPS Interpreter DEV (".concat(i,") \nCopyright (c) 2018-").concat(n," Jakub T. Jankiewicz\n\nType (env) to see environment with functions macros and variables. You can also\nuse (help name) to display help for specific function or macro, (apropos name)\nto display list of matched names in environment and (dir object) to list\nproperties of an object.\n").replace(/^.*\n/,"");return u}();f(Ru,"__class__","ahead");f($,"__class__","pair");f(ra,"__class__","nil");f(Tu,"__class__","pattern");f(Nu,"__class__","formatter");f(J,"__class__","macro");f(Sa,"__class__","syntax");f(Sa.Parameter,"__class__","syntax-parameter");f(x,"__class__","environment");f(Zo,"__class__","input-port");f(Xo,"__class__","output-port");f(es,"__class__","output-port");f(ts,"__class__","output-string-port");f(ns,"__class__","input-string-port");f(as,"__class__","input-file-port");f(rs,"__class__","output-file-port");f(_s,"__class__","lips-error");[B,m,E,g,A].forEach(function(e){f(e,"__class__","number")});f(h,"__class__","character");f(Y,"__class__","symbol");f(D,"__class__","string");f(fu,"__class__","promise");f(Zs,"__class__","parameter");var Rc="DEV";var Tc="Mon, 12 Feb 2024 14:25:33 +0000";var Lc=Co(Cu,Au);var Mc={version:Rc,banner:Nc,date:Tc,exec:nc,parse:Lc,tokenize:iu,evaluate:k,compile:rc,serialize:Ec,unserialize:Ac,serialize_bin:Sc,unserialize_bin:Bc,bootstrap:lc,Environment:x,env:Fs,Worker:hc,Interpreter:ps,balanced_parenthesis:ac,balancedParenthesis:ac,balanced:ac,Macro:J,Syntax:Sa,Pair:$,Values:ys,QuotedPromise:fu,Error:_s,quote:ms,InputPort:Zo,OutputPort:Xo,BufferedOutputPort:es,InputFilePort:as,OutputFilePort:rs,InputStringPort:ns,OutputStringPort:ts,InputByteVectorPort:is,OutputByteVectorPort:us,InputBinaryFilePort:os,OutputBinaryFilePort:ss,set_fs:Cs,Formatter:Nu,Parser:Du,Lexer:s,specials:_u,repr:ia,nil:V,eof:ls,LSymbol:Y,LNumber:B,LFloat:g,LComplex:m,LRational:E,LBigInteger:A,LCharacter:h,LString:D,Parameter:Zs,rationalize:Go};W.set("lips",Mc);var Uc={};var qc=Object.freeze({__proto__:null,default:Uc});function zc(e,t){var r=0;for(var n=e.length-1;n>=0;n--){var i=e[n];if(i==="."){e.splice(n,1)}else if(i===".."){e.splice(n,1);r++}else if(r){e.splice(n,1);r--}}if(t){for(;r--;r){e.unshift("..")}}return e}var Yc=/^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/;var Vc=function(e){return Yc.exec(e).slice(1)};function $c(){var e="",t=false;for(var r=arguments.length-1;r>=-1&&!t;r--){var n=r>=0?arguments[r]:"/";if(typeof n!=="string"){throw new TypeError("Arguments to path.resolve must be strings")}else if(!n){continue}e=n+"/"+e;t=n.charAt(0)==="/"}e=zc(rf(e.split("/"),function(e){return!!e}),!t).join("/");return(t?"/":"")+e||"."}function Jc(e){var t=Kc(e),r=nf(e,-1)==="/";e=zc(rf(e.split("/"),function(e){return!!e}),!t).join("/");if(!e&&!t){e="."}if(e&&r){e+="/"}return(t?"/":"")+e}function Kc(e){return e.charAt(0)==="/"}function Hc(){var e=Array.prototype.slice.call(arguments,0);return Jc(rf(e,function(e,t){if(typeof e!=="string"){throw new TypeError("Arguments to path.join must be strings")}return e}).join("/"))}function Wc(e,t){e=$c(e).substr(1);t=$c(t).substr(1);function r(e){var t=0;for(;t=0;r--){if(e[r]!=="")break}if(t>r)return[];return e.slice(t,r-t+1)}var n=r(e.split("/"));var i=r(t.split("/"));var u=Math.min(n.length,i.length);var a=u;for(var o=0;o { @@ -2519,7 +2519,7 @@ Pair.prototype.find = function(item) { Pair.prototype.clone = function(deep = true) { var visited = new Map(); function clone(node) { - if (node instanceof Pair) { + if (is_pair(node)) { if (visited.has(node)) { return visited.get(node); } @@ -2556,7 +2556,7 @@ Pair.prototype.last_pair = function() { // ---------------------------------------------------------------------- Pair.prototype.to_array = function(deep = true) { var result = []; - if (this.car instanceof Pair) { + if (is_pair(this.car)) { if (deep) { result.push(this.car.to_array()); } else { @@ -2565,7 +2565,7 @@ Pair.prototype.to_array = function(deep = true) { } else { result.push(this.car.valueOf()); } - if (this.cdr instanceof Pair) { + if (is_pair(this.cdr)) { result = result.concat(this.cdr.to_array(deep)); } return result; @@ -2575,7 +2575,7 @@ Pair.prototype.to_array = function(deep = true) { // :: TODO: change to Pair.from_array // ---------------------------------------------------------------------- Pair.fromArray = function(array, deep = true, quote = false) { - if (array instanceof Pair || quote && array instanceof Array && array[__data__]) { + if (is_pair(array) || quote && array instanceof Array && array[__data__]) { return array; } if (deep === false) { @@ -2613,7 +2613,7 @@ Pair.prototype.to_object = function(literal = false) { var node = this; var result = {}; while (true) { - if (node instanceof Pair && node.car instanceof Pair) { + if (is_pair(node) && is_pair(node.car)) { var pair = node.car; var name = pair.car; if (name instanceof LSymbol) { @@ -2623,7 +2623,7 @@ Pair.prototype.to_object = function(literal = false) { name = name.valueOf(); } var cdr = pair.cdr; - if (cdr instanceof Pair) { + if (is_pair(cdr)) { cdr = cdr.to_object(literal); } if (is_native(cdr)) { @@ -2664,7 +2664,7 @@ Pair.prototype.reduce = function(fn) { var node = this; var result = nil; while (true) { - if (node !== nil) { + if (!is_nil(node)) { result = fn(result, node.car); node = node.cdr; } else { @@ -2681,7 +2681,7 @@ Pair.prototype.reverse = function() { } var node = this; var prev = nil; - while (node !== nil) { + while (!is_nil(node)) { var next = node.cdr; node.cdr = prev; prev = node; @@ -2694,18 +2694,18 @@ Pair.prototype.reverse = function() { Pair.prototype.transform = function(fn) { var visited = []; function recur(pair) { - if (pair instanceof Pair) { + if (is_pair(pair)) { if (pair.replace) { delete pair.replace; return pair; } var car = fn(pair.car); - if (car instanceof Pair) { + if (is_pair(car)) { car = recur(car); visited.push(car); } var cdr = fn(pair.cdr); - if (cdr instanceof Pair) { + if (is_pair(cdr)) { cdr = recur(cdr); visited.push(cdr); } @@ -2719,7 +2719,7 @@ Pair.prototype.transform = function(fn) { // ---------------------------------------------------------------------- Pair.prototype.map = function(fn) { if (typeof this.car !== 'undefined') { - return new Pair(fn(this.car), this.cdr === nil ? nil : this.cdr.map(fn)); + return new Pair(fn(this.car), is_nil(this.cdr) ? nil : this.cdr.map(fn)); } else { return nil; } @@ -3015,7 +3015,7 @@ function markCycles(pair) { } } function set(node, type, child, parents) { - if (child instanceof Pair) { + if (is_pair(child)) { if (parents.includes(child)) { if (!refs.includes(child)) { refs.push(child); @@ -3032,7 +3032,7 @@ function markCycles(pair) { } } const detect = trampoline(function detect_thunk(pair, parents) { - if (pair instanceof Pair) { + if (is_pair(pair)) { delete pair.ref; delete pair[__cycles__]; visit(pair); @@ -3050,7 +3050,7 @@ function markCycles(pair) { } }); function mark_node(node, type) { - if (node[__cycles__][type] instanceof Pair) { + if (is_pair(node[__cycles__][type])) { const count = ref_nodes.indexOf(node[__cycles__][type]); node[__cycles__][type] = `#${count}#`; } @@ -3106,7 +3106,7 @@ const pair_to_string = (function() { result.push(car); } return new Thunk(() => { - if (pair.cdr instanceof Pair) { + if (is_pair(pair.cdr)) { if (pair[__cycles__] && pair[__cycles__].cdr) { result.push(' . '); result.push(pair[__cycles__].cdr); @@ -3122,7 +3122,7 @@ const pair_to_string = (function() { cont }); } - } else if (pair.cdr !== nil) { + } else if (!is_nil(pair.cdr)) { result.push(' . '); result.push(toString(pair.cdr, quote)); } @@ -3147,7 +3147,7 @@ Pair.prototype.toString = function(quote, { nested = false } = {}) { if (value !== undefined) { arr.push(value); } - if (this.cdr instanceof Pair) { + if (is_pair(this.cdr)) { if (this[__cycles__] && this[__cycles__].cdr) { arr.push(' . '); arr.push(this[__cycles__].cdr); @@ -3160,7 +3160,7 @@ Pair.prototype.toString = function(quote, { nested = false } = {}) { const cdr = this.cdr.toString(quote, { nested: true }); arr.push(cdr); } - } else if (this.cdr !== nil) { + } else if (!is_nil(this.cdr)) { arr = arr.concat([' . ', toString(this.cdr, quote, true)]); } if (!nested || this[__ref__]) { @@ -3172,7 +3172,7 @@ Pair.prototype.toString = function(quote, { nested = false } = {}) { // ---------------------------------------------------------------------- Pair.prototype.set = function(prop, value) { this[prop] = value; - if (value instanceof Pair) { + if (is_pair(value)) { this.markCycles(); } }; @@ -3184,15 +3184,15 @@ Pair.prototype.append = function(arg) { } var p = this; if (p.car === undefined) { - if (arg instanceof Pair) { + if (is_pair(arg)) { this.car = arg.car; this.cdr = arg.cdr; } else { this.car = arg; } - } else if (arg !== nil) { + } else if (!is_nil(arg)) { while (true) { - if (p instanceof Pair && p.cdr !== nil) { + if (is_pair(p) && !is_nil(p.cdr)) { p = p.cdr; } else { break; @@ -3218,7 +3218,7 @@ Pair.prototype[Symbol.iterator] = function() { next: function() { var cur = node; node = cur.cdr; - if (cur === nil) { + if (is_nil(cur)) { return { value: undefined, done: true }; } else { return { value: cur.car, done: false }; @@ -3312,7 +3312,7 @@ function same_atom(a, b) { function is_atom(obj) { return obj instanceof LSymbol || LString.isString(obj) || - obj === nil || + is_nil(obj) || obj === null || obj instanceof LCharacter || obj instanceof LNumber || @@ -3391,7 +3391,7 @@ function macro_expand(single) { return let_macros.includes(name); } function is_procedure(value, node) { - return value === define && node.cdr.car instanceof Pair; + return value === define && is_pair(node.cdr.car); } function is_lambda(value) { return value === lambda; @@ -3399,7 +3399,7 @@ function macro_expand(single) { function proc_bindings(node) { var names = []; while (true) { - if (node !== nil) { + if (!is_nil(node)) { if (node instanceof LSymbol) { names.push(node.valueOf()); break; @@ -3414,7 +3414,7 @@ function macro_expand(single) { } function let_binding(node) { return [...bindings, ...node.to_array(false).map(function(node) { - if (node instanceof Pair) { + if (is_pair(node)) { return node.car.valueOf(); } const t = type(node); @@ -3428,7 +3428,7 @@ function macro_expand(single) { !bindings.includes(name); } async function expand_let_binding(node, n) { - if (node === nil) { + if (is_nil(node)) { return nil; } var pair = node.car; @@ -3441,7 +3441,7 @@ function macro_expand(single) { ); } async function traverse(node, n, env) { - if (node instanceof Pair && node.car instanceof LSymbol) { + if (is_pair(node) && node.car instanceof LSymbol) { if (node[__data__]) { return node; } @@ -3453,7 +3453,7 @@ function macro_expand(single) { is_procedure(value, node) || is_lambda(value); - if (is_binding && node.cdr.car instanceof Pair) { + if (is_binding && is_pair(node.cdr.car)) { var second; if (is_let) { bindings = let_binding(node.cdr.car); @@ -3474,7 +3474,7 @@ function macro_expand(single) { var result = await value.invoke(code, { ...args, env }, true); if (value instanceof Syntax) { const { expr, scope } = result; - if (expr instanceof Pair) { + if (is_pair(expr)) { if (n !== -1 && n <= 1 || n < recur_guard) { return expr; } @@ -3488,7 +3488,7 @@ function macro_expand(single) { if (result instanceof LSymbol) { return quote(result); } - if (result instanceof Pair) { + if (is_pair(result)) { if (n !== -1 && n <= 1 || n < recur_guard) { return result; } @@ -3504,18 +3504,18 @@ function macro_expand(single) { } // TODO: CYCLE DETECT var car = node.car; - if (car instanceof Pair) { + if (is_pair(car)) { car = await traverse(car, n, env); } var cdr = node.cdr; - if (cdr instanceof Pair) { + if (is_pair(cdr)) { cdr = await traverse(cdr, n, env); } var pair = new Pair(car, cdr); return pair; } //var this.__code__ = code; - if (code.cdr instanceof Pair && LNumber.isNumber(code.cdr.car)) { + if (is_pair(code.cdr) && LNumber.isNumber(code.cdr.car)) { return quote((await traverse(code, code.cdr.car.valueOf(), env)).car); } if (single) { @@ -3641,12 +3641,12 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol, scope = {}) { return first && rest; } // pattern (a b (x ...)) and (x ...) match nil - if (pattern instanceof Pair && - pattern.car instanceof Pair && - pattern.car.cdr instanceof Pair && + if (is_pair(pattern) && + is_pair(pattern.car) && + is_pair(pattern.car.cdr) && LSymbol.is(pattern.car.cdr.car, ellipsis_symbol)) { log('>> 0'); - if (code === nil) { + if (is_nil(code)) { log({ pattern }); if (pattern.car.car instanceof LSymbol) { let name = pattern.car.car.valueOf(); @@ -3658,12 +3658,12 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol, scope = {}) { } } } - if (pattern instanceof Pair && - pattern.cdr instanceof Pair && + if (is_pair(pattern) && + is_pair(pattern.cdr) && LSymbol.is(pattern.cdr.car, ellipsis_symbol)) { // pattern (... ???) - SRFI-46 - if (pattern.cdr.cdr !== nil) { - if (pattern.cdr.cdr instanceof Pair) { + if (!is_nil(pattern.cdr.cdr)) { + if (is_pair(pattern.cdr.cdr)) { // if we have (x ... a b) we need to remove two from the end const list_len = pattern.cdr.cdr.length(); if (!is_pair(code)) { @@ -3689,7 +3689,7 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol, scope = {}) { throw new Error('syntax: named ellipsis can only appear onces'); } log('>> 1'); - if (code === nil) { + if (is_nil(code)) { log('>> 2'); if (ellipsis) { log('NIL'); @@ -3698,13 +3698,12 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol, scope = {}) { log('NULL'); bindings['...'].symbols[name] = null; } - } else if (code instanceof Pair && - (code.car instanceof Pair || code.car === nil)) { + } else if (is_pair(code) && (is_pair(code.car) || is_nil(code.car))) { log('>> 3 ' + ellipsis); if (ellipsis) { if (bindings['...'].symbols[name]) { let node = bindings['...'].symbols[name]; - if (node === nil) { + if (is_nil(node)) { node = new Pair(nil, new Pair(code, nil)); } else { node = node.append(new Pair(code, nil)); @@ -3719,12 +3718,11 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol, scope = {}) { } } else { log('>> 6'); - if (code instanceof Pair) { + if (is_pair(code)) { // cons (a . b) => (var ... . x) - if (!(code.cdr instanceof Pair) && - code.cdr !== nil) { + if (!is_pair(code.cdr) && !is_nil(code.cdr)) { log('>> 7 (b)'); - if (pattern.cdr.cdr === nil) { + if (is_nil(pattern.cdr.cdr)) { return false; } else if (!bindings['...'].symbols[name]) { bindings['...'].symbols[name] = new Pair(code.car, nil); @@ -3733,8 +3731,8 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol, scope = {}) { } // code as improper list const last_pair = code.last_pair(); - if (last_pair.cdr !== nil) { - if (pattern.cdr.cdr === nil) { + if (!is_nil(last_pair.cdr)) { + if (is_nil(pattern.cdr.cdr)) { // case (a ...) for (a b . x) return false; } else { @@ -3763,7 +3761,7 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol, scope = {}) { } log({ IIIIII: bindings['...'].symbols[name] }); } else if (pattern.car instanceof LSymbol && - pattern.cdr instanceof Pair && + is_pair(pattern.cdr) && LSymbol.is(pattern.cdr.car, ellipsis_symbol)) { // empty ellipsis with rest (a b ... . d) #290 log('>> 8'); @@ -3776,16 +3774,16 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol, scope = {}) { } } return true; - } else if (pattern.car instanceof Pair) { + } else if (is_pair(pattern.car)) { var names = [...pattern_names]; - if (code === nil) { + if (is_nil(code)) { log('>> 10'); bindings['...'].lists.push(nil); return true; } log('>> 11'); let node = code; - while (node instanceof Pair) { + while (is_pair(node)) { if (!traverse(pattern.car, node.car, names, true)) { return false; } @@ -3795,7 +3793,7 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol, scope = {}) { } if (Array.isArray(pattern.car) ) { var names = [...pattern_names]; let node = code; - while (node instanceof Pair) { + while (is_pair(node)) { if (!traverse(pattern.car, node.car, names, true)) { return false; } @@ -3823,14 +3821,14 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol, scope = {}) { } return true; } - if (pattern instanceof Pair && code instanceof Pair) { + if (is_pair(pattern) && is_pair(code)) { log('>> 13'); log({ a: 13, code, pattern }); - if (code.cdr === nil) { + if (is_nil(code.cdr)) { // last item in in call using in recursive calls on // last element of the list // case of pattern (p . rest) and code (0) @@ -3859,11 +3857,11 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol, scope = {}) { code }); // case (x y) ===> (var0 var1 ... warn) where var1 match nil - if (pattern.cdr instanceof Pair && - pattern.cdr.cdr instanceof Pair && + if (is_pair(pattern.cdr) && + is_pair(pattern.cdr.cdr) && pattern.cdr.car instanceof LSymbol && LSymbol.is(pattern.cdr.cdr.car, ellipsis_symbol) && - pattern.cdr.cdr.cdr instanceof Pair && + is_pair(pattern.cdr.cdr.cdr) && !LSymbol.is(pattern.cdr.cdr.cdr.car, ellipsis_symbol) && traverse(pattern.car, code.car, pattern_names, ellipsis) && traverse(pattern.cdr.cdr.cdr, code.cdr, pattern_names, ellipsis)) { @@ -3891,11 +3889,11 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol, scope = {}) { if (car && cdr) { return true; } - } else if (pattern === nil && (code === nil || code === undefined)) { + } else if (is_nil(pattern) && (is_nil(code) || code === undefined)) { // undefined is case when you don't have body ... // and you do recursive call return true; - } else if (pattern.car instanceof Pair && + } else if (is_pair(pattern.car) && LSymbol.is(pattern.car.car, ellipsis_symbol)) { // pattern (...) throw new Error('syntax: invalid usage of ellipsis'); @@ -3915,7 +3913,7 @@ function extract_patterns(pattern, code, symbols, ellipsis_symbol, scope = {}) { // ---------------------------------------------------------------------- function clear_gensyms(node, gensyms) { function traverse(node) { - if (node instanceof Pair) { + if (is_pair(node)) { if (!gensyms.length) { return node; } @@ -4038,16 +4036,16 @@ function transform_syntax(options = {}) { } log('[t 1'); if (bindings[name]) { - if (bindings[name] instanceof Pair) { + if (is_pair(bindings[name])) { const { car, cdr } = bindings[name]; if (nested) { const { car: caar, cdr: cadr } = car; - if (cadr !== nil) { + if (!is_nil(cadr)) { next(name, new Pair(cadr, nil)); } return caar; } - if (cdr !== nil) { + if (!is_nil(cdr)) { next(name, cdr); } return car; @@ -4059,7 +4057,7 @@ function transform_syntax(options = {}) { return transform(expr); } const is_array = Array.isArray(expr); - if (expr instanceof Pair || is_array) { + if (is_pair(expr) || is_array) { const first = is_array ? expr[0] : expr.car; const second = is_array ? expr[1] : is_pair(expr.cdr) && expr.cdr.car; if (first instanceof LSymbol && @@ -4072,16 +4070,16 @@ function transform_syntax(options = {}) { return; } else if (item) { log({ name, binding: bindings[name] }); - if (item instanceof Pair) { + if (is_pair(item)) { log('[t 2 Pair ' + nested); const { car, cdr } = item; const rest_expr = is_array ? expr.slice(2) : expr.cdr.cdr; if (nested) { - if (cdr !== nil) { + if (!is_nil(cdr)) { log('|| next 1'); next(name, cdr); } - if ((is_array && rest_expr.length) || (rest_expr !== nil && !is_array)) { + if ((is_array && rest_expr.length) || (!is_nil(rest_expr) && !is_array)) { const rest = transform_ellipsis_expr(rest_expr, bindings, state, next); if (is_array) { return car.concat(rest); @@ -4092,13 +4090,13 @@ function transform_syntax(options = {}) { } } return car; - } else if (car instanceof Pair) { - if (car.cdr !== nil) { + } else if (is_pair(car)) { + if (!is_nil(car.cdr)) { log('|| next 2'); next(name, new Pair(car.cdr, cdr)); } return car.car; - } else if (cdr === nil) { + } else if (is_nil(cdr)) { return car; } else { const last_pair = expr.last_pair(); @@ -4150,8 +4148,7 @@ function transform_syntax(options = {}) { if (x === null) { return !skip_nulls; } - return x instanceof Pair || x === nil || - (x instanceof Array && x.length); + return is_pair(x) || is_nil(x) || (Array.isArray(x) && x.length); }); } function get_names(object) { @@ -4164,7 +4161,7 @@ function transform_syntax(options = {}) { if (is_array && expr.length === 0) { return expr; } - if (expr instanceof Pair || is_array) { + if (is_pair(expr) || is_array) { const first = is_array ? expr[0] : expr.car; let second, rest_second; if (is_array) { @@ -4204,7 +4201,7 @@ function transform_syntax(options = {}) { // lists is free ellipsis on pairs ((???) ...) // TODO: will this work in every case? Do we need to handle // nesting here? - if (bindings['...'].lists[0] === nil) { + if (is_nil(bindings['...'].lists[0])) { if (!is_spread) { return traverse(rest_second, { disabled }); } @@ -4256,7 +4253,7 @@ function transform_syntax(options = {}) { log('ZONK {1}'); } } else { - if (result === nil) { + if (is_nil(result)) { result = car; } else { result = result.append(car); @@ -4273,7 +4270,7 @@ function transform_syntax(options = {}) { } bind = new_bind; } - if (result !== nil && !is_spread && !is_array) { + if (!is_nil(result) && !is_spread && !is_array) { result = result.reverse(); } // case of (list) ... (rest code) @@ -4285,7 +4282,7 @@ function transform_syntax(options = {}) { } return result; } - if (expr.cdr.cdr !== nil && + if (!is_nil(expr.cdr.cdr) && !LSymbol.is(expr.cdr.cdr.car, ellipsis_symbol)) { const rest = traverse(expr.cdr.cdr, { disabled }); return result.append(rest); @@ -4346,21 +4343,21 @@ function transform_syntax(options = {}) { } bind = new_bind; } - if (result !== nil && !is_array) { + if (!is_nil(result) && !is_array) { result = result.reverse(); } // case if (x ... y ...) second spread is not processed // and (??? . x) last symbol // by ellipsis transformation - if (expr.cdr instanceof Pair) { - if (expr.cdr.cdr instanceof Pair || + if (is_pair(expr.cdr)) { + if (is_pair(expr.cdr.cdr) || expr.cdr.cdr instanceof LSymbol) { const node = traverse(expr.cdr.cdr, { disabled }); log({node}); if (is_null) { return node; } - if (result === nil) { + if (is_nil(result)) { result = node; } else { result.append(node); @@ -4434,7 +4431,11 @@ function transform_syntax(options = {}) { // :: Check for nullish values // ---------------------------------------------------------------------- function is_null(value) { - return is_undef(value) || value === nil || value === null; + return is_undef(value) || is_nil(value) || value === null; +} +// ---------------------------------------------------------------------- +function is_nil(value) { + return value === nil; } // ---------------------------------------------------------------------- function is_function(o) { @@ -4579,7 +4580,7 @@ function unbox(object) { } // ---------------------------------------------------------------------- function patch_value(value, context) { - if (value instanceof Pair) { + if (is_pair(value)) { value.markCycles(); return quote(value); } @@ -4765,11 +4766,11 @@ function let_macro(symbol) { // named let: // (let iter ((x 10)) (iter (- x 1))) -> (let* ((iter (lambda (x) ... if (code.car instanceof LSymbol) { - if (!(code.cdr.car instanceof Pair || code.cdr.car === nil)) { + if (!(is_pair(code.cdr.car) || is_nil(code.cdr.car))) { throw new Error('let require list of pairs'); } var params; - if (code.cdr.car === nil) { + if (is_nil(code.cdr.car)) { args = nil; params = nil; } else { @@ -4864,7 +4865,7 @@ function parallel(name, fn) { const dynamic_env = this; const results = []; let node = code; - while (node instanceof Pair) { + while (is_pair(node)) { results.push(evaluate(node.car, { env, dynamic_env, use_dynamic, error })); node = node.cdr; } @@ -7228,7 +7229,7 @@ function quote(value) { if (is_promise(value)) { return value.then(quote); } - if (value instanceof Pair || value instanceof LSymbol) { + if (is_pair(value) || value instanceof LSymbol) { value[__data__] = true; } return value; @@ -7404,7 +7405,7 @@ var global_env = new Environment({ together with \`eval\` to evaluate code from a string.`), // ------------------------------------------------------------------ pprint: doc('pprint', function pprint(arg) { - if (arg instanceof Pair) { + if (is_pair(arg)) { arg = new lips.Formatter(arg.toString(true)).break().format(); global_env.get('display').call(global_env, arg); } else { @@ -7519,7 +7520,7 @@ var global_env = new Environment({ var symbol; if (code.car instanceof LSymbol) { symbol = code.car; - } else if (code.car instanceof Pair && code.car.car instanceof LSymbol) { + } else if (is_pair(code.car) && code.car.car instanceof LSymbol) { symbol = code.car.car; } else { var env = this; @@ -7592,7 +7593,7 @@ var global_env = new Environment({ env.get('set-obj!').call(env, object, key, value); return value; } - if (code.car instanceof Pair && LSymbol.is(code.car.car, '.')) { + if (is_pair(code.car) && LSymbol.is(code.car.car, '.')) { var second = code.car.cdr.car; var third = code.car.cdr.cdr.car; var object = evaluate(second, eval_args); @@ -7661,7 +7662,7 @@ var global_env = new Environment({ It will destroy the list. The old tail is lost.`), // ------------------------------------------------------------------ 'empty?': doc('empty?', function(x) { - return typeof x === 'undefined' || x === nil; + return typeof x === 'undefined' || is_nil(x); }, `(empty? object) Function that returns #t if value is nil (an empty list) or undefined.`), @@ -7734,7 +7735,7 @@ var global_env = new Environment({ if (cmd) { args = await cmd(); } - if (args && args !== nil) { + if (args && !is_nil(args)) { cwd = process.cwd(); file = path.join(path.dirname(args.car.valueOf()), file); } @@ -7796,26 +7797,26 @@ var global_env = new Environment({ const vars = code.car; const test = code.cdr.car; let body = code.cdr.cdr; - if (body !== nil) { + if (!is_nil(body)) { body = new Pair(LSymbol('begin'), body); } let eval_args = { env: self, dynamic_env, use_dynamic, error }; let node = vars; - while (node !== nil) { + while (!is_nil(node)) { const item = node.car; scope.set(item.car, await evaluate(item.cdr.car, eval_args)); node = node.cdr; } eval_args = { env: scope, dynamic_env, error }; while ((await evaluate(test.car, eval_args)) === false) { - if (body !== nil) { + if (!is_nil(body)) { await lips.evaluate(body, eval_args); } let node = vars; const next = {}; - while (node !== nil) { + while (!is_nil(node)) { const item = node.car; - if (item.cdr.cdr !== nil) { + if (!is_nil(item.cdr.cdr)) { const value = await evaluate(item.cdr.cdr.car, eval_args); next[item.car.valueOf()] = value; } @@ -7826,7 +7827,7 @@ var global_env = new Environment({ scope.set(key, next[key]); }); } - if (test.cdr !== nil) { + if (!is_nil(test.cdr)) { return await evaluate(test.cdr.car, eval_args); } }), `(do (( )) (test return) . body) @@ -7848,7 +7849,7 @@ var global_env = new Environment({ return evaluate(code.cdr.car, eval_args); } }; - if (code === nil) { + if (is_nil(code)) { throw new Error('too few expressions for `if`'); } const cond = evaluate(code.car, eval_args); @@ -7922,7 +7923,7 @@ var global_env = new Environment({ shuffle: doc('shuffle', function(arg) { typecheck('shuffle', arg, ['pair', 'nil', 'array']); const random = global_env.get('random') - if (arg === nil) { + if (is_nil(arg)) { return nil; } if (Array.isArray(arg)) { @@ -8022,7 +8023,7 @@ var global_env = new Environment({ const dynamic_env = eval_args.dynamic_env; const init = evaluate(code.car, eval_args); let fn; - if (code.cdr.car instanceof Pair) { + if (is_pair(code.cdr.car)) { fn = evaluate(code.cdr.car, eval_args); } return new Parameter(init, fn); @@ -8048,7 +8049,7 @@ var global_env = new Environment({ syntax.__name__ = syntax.__name__.valueOf(); } let __doc__; - if (code.cdr.cdr instanceof Pair && + if (is_pair(code.cdr.cdr) && LString.isString(code.cdr.cdr.car)) { __doc__ = code.cdr.cdr.car.valueOf(); } @@ -8098,7 +8099,7 @@ var global_env = new Environment({ // ------------------------------------------------------------------ define: doc(Macro.defmacro('define', function(code, eval_args) { var env = this; - if (code.car instanceof Pair && + if (is_pair(code.car) && code.car.car instanceof LSymbol) { var new_code = new Pair( new LSymbol("define"), @@ -8124,7 +8125,7 @@ var global_env = new Environment({ eval_args.env = env; var value = code.cdr.car; let new_expr; - if (value instanceof Pair) { + if (is_pair(value)) { value = evaluate(value, eval_args); new_expr = true; } else if (value instanceof LSymbol) { @@ -8144,7 +8145,7 @@ var global_env = new Environment({ } } let __doc__; - if (code.cdr.cdr instanceof Pair && + if (is_pair(code.cdr.cdr) && LString.isString(code.cdr.cdr.car)) { __doc__ = code.cdr.cdr.car.valueOf(); } @@ -8173,7 +8174,7 @@ var global_env = new Environment({ } else if (is_prototype(obj) && is_function(value)) { obj[key] = unbind(value); obj[key][__prototype__] = true; - } else if (is_function(value) || is_native(value) || value === nil) { + } else if (is_function(value) || is_native(value) || is_nil(value)) { obj[key] = value; } else { obj[key] = value && !is_prototype(value) ? value.valueOf() : value; @@ -8257,9 +8258,9 @@ var global_env = new Environment({ lambda: new Macro('lambda', function(code, { use_dynamic, error } = {}) { var self = this; var __doc__; - if (code.cdr instanceof Pair && + if (is_pair(code.cdr) && LString.isString(code.cdr.car) && - code.cdr.cdr !== nil) { + !is_nil(code.cdr.cdr)) { __doc__ = code.cdr.car.valueOf(); } function lambda(...args) { @@ -8296,9 +8297,9 @@ var global_env = new Environment({ } let name = code.car; let i = 0; - if (name instanceof LSymbol || name !== nil) { + if (name instanceof LSymbol || !is_nil(name)) { while (true) { - if (name.car !== nil) { + if (!is_nil(name.car)) { if (name instanceof LSymbol) { // rest argument, can also be first argument const value = quote(Pair.fromArray(args.slice(i), false)); @@ -8309,7 +8310,7 @@ var global_env = new Environment({ set(name.car, value); } } - if (name.cdr === nil) { + if (is_nil(name.cdr)) { break; } i++; @@ -8326,10 +8327,10 @@ var global_env = new Environment({ } return evaluate(output, eval_args); } - var length = code.car instanceof Pair ? code.car.length() : null; + var length = is_pair(code.car) ? code.car.length() : null; lambda.__code__ = new Pair(new LSymbol('lambda'), code); lambda[__lambda__] = true; - if (!(code.car instanceof Pair)) { + if (!is_pair(code.car)) { return doc(lambda, __doc__, true); // variable arguments } // wrap and decorate with __doc__ @@ -8345,10 +8346,10 @@ var global_env = new Environment({ 'macroexpand-1': new Macro('macroexpand-1', macro_expand(true)), // ------------------------------------------------------------------ 'define-macro': doc(new Macro(macro, function(macro, { use_dynamic, error }) { - if (macro.car instanceof Pair && macro.car.car instanceof LSymbol) { + if (is_pair(macro.car) && macro.car.car instanceof LSymbol) { var name = macro.car.car.__name__; var __doc__; - if (LString.isString(macro.cdr.car) && macro.cdr.cdr instanceof Pair) { + if (LString.isString(macro.cdr.car) && is_pair(macro.cdr.cdr)) { __doc__ = macro.cdr.car.valueOf(); } var makro_instance = Macro.defmacro(name, function(code) { @@ -8356,26 +8357,26 @@ var global_env = new Environment({ var name = macro.car.cdr; var arg = code; while (true) { - if (name === nil) { + if (is_nil(name)) { break; } if (name instanceof LSymbol) { env.__env__[name.__name__] = arg; break; - } else if (name.car !== nil) { - if (arg === nil) { + } else if (!is_nil(name.car)) { + if (is_nil(arg)) { env.__env__[name.car.__name__] = nil; } else { - if (arg.car instanceof Pair) { + if (is_pair(arg.car)) { arg.car[__data__] = true; } env.__env__[name.car.__name__] = arg.car; } } - if (name.cdr === nil) { + if (is_nil(name.cdr)) { break; } - if (arg !== nil) { + if (!is_nil(arg)) { arg = arg.cdr; } name = name.cdr; @@ -8387,7 +8388,7 @@ var global_env = new Environment({ error }; // evaluate macro - if (macro.cdr instanceof Pair) { + if (is_pair(macro.cdr)) { // this eval will return lips code var rest = __doc__ ? macro.cdr.cdr : macro.cdr; var result = rest.reduce(function(result, node) { @@ -8420,7 +8421,7 @@ var global_env = new Environment({ var env = this; function get_identifiers(node) { let symbols = []; - while (node !== nil) { + while (!is_nil(node)) { const x = node.car; symbols.push(x.valueOf()); node = node.cdr; @@ -8428,7 +8429,7 @@ var global_env = new Environment({ return symbols; } function validate_identifiers(node) { - while (node !== nil) { + while (!is_nil(node)) { const x = node.car; if (!(x instanceof LSymbol)) { throw new Error('syntax-rules: wrong identifier'); @@ -8469,7 +8470,7 @@ var global_env = new Environment({ rules = macro.cdr; } try { - while (rules !== nil) { + while (!is_nil(rules)) { var rule = rules.car.car; var expr = rules.car.cdr.car; log('[[[ RULE'); @@ -8555,13 +8556,13 @@ var global_env = new Environment({ const dynamic_env = self; // ----------------------------------------------------------------- function is_struct(value) { - return value instanceof Pair || + return is_pair(value) || is_plain_object(value) || Array.isArray(value); } // ----------------------------------------------------------------- function resolve_pair(pair, fn, test = is_struct) { - if (pair instanceof Pair) { + if (is_pair(pair)) { var car = pair.car; var cdr = pair.cdr; if (test(car)) { @@ -8582,11 +8583,11 @@ var global_env = new Environment({ } // ----------------------------------------------------------------- function join(eval_pair, value) { - if (eval_pair === nil && value === nil) { + if (is_nil(eval_pair) && is_nil(value)) { //return nil; } - if (eval_pair instanceof Pair) { - if (value !== nil) { + if (is_pair(eval_pair)) { + if (!is_nil(value)) { eval_pair.append(value); } } else { @@ -8600,14 +8601,14 @@ var global_env = new Environment({ // ----------------------------------------------------------------- function unquoted_arr(arr) { return !!arr.filter(value => { - return value instanceof Pair && + return is_pair(value) && LSymbol.is(value.car, /^(unquote|unquote-splicing)$/); }).length; } // ----------------------------------------------------------------- function quote_vector(arr, unquote_cnt, max_unq) { return arr.reduce((acc, x) => { - if (!(x instanceof Pair)) { + if (!is_pair(x)) { acc.push(x); return acc; } @@ -8623,7 +8624,7 @@ var global_env = new Environment({ error }); } - if (!(result instanceof Pair)) { + if (!is_pair(result)) { throw new Error(`Expecting list ${type(x)} found`); } return acc.concat(result.to_array()); @@ -8638,7 +8639,7 @@ var global_env = new Environment({ unquote_cnt++; Object.keys(object).forEach(key => { const value = object[key]; - if (value instanceof Pair) { + if (is_pair(value)) { if (LSymbol.is(value.car, 'unquote-splicing')) { throw new Error("You can't call `unquote-splicing` " + "inside object"); @@ -8684,18 +8685,18 @@ var global_env = new Environment({ error }); lists.push(value); - if (node.cdr instanceof Pair) { + if (is_pair(node.cdr)) { return next(node.cdr); } return unpromise(lists, function(arr) { - if (arr.some(x => !(x instanceof Pair))) { - if (pair.cdr instanceof Pair && + if (arr.some(x => !is_pair(x))) { + if (is_pair(pair.cdr) && LSymbol.is(pair.cdr.car, '.') && - pair.cdr.cdr instanceof Pair && - pair.cdr.cdr.cdr === nil) { + is_pair(pair.cdr.cdr) && + is_nil(pair.cdr.cdr.cdr)) { return pair.cdr.cdr.car; } - if (!(pair.cdr === nil || pair.cdr instanceof Pair)) { + if (!(is_nil(pair.cdr) || is_pair(pair.cdr))) { const msg = "You can't splice atom inside list"; throw new Error(msg); } @@ -8703,7 +8704,7 @@ var global_env = new Environment({ const msg = "You can't splice multiple atoms inside list"; throw new Error(msg); } - if (!(pair.cdr instanceof Pair && arr[0] === nil)) { + if (!(is_pair(pair.cdr) && is_nil(arr[0]))) { return arr[0]; } } @@ -8717,11 +8718,11 @@ var global_env = new Environment({ } }); const value = recur(pair.cdr, 0, 1); - if (value === nil && arr[0] === nil) { + if (is_nil(value) && is_nil(arr[0])) { return undefined; } return unpromise(value, value => { - if (arr[0] === nil) { + if (is_nil(arr[0])) { return value; } if (arr.length === 1) { @@ -8738,16 +8739,16 @@ var global_env = new Environment({ // ----------------------------------------------------------------- var splices = new Set(); function recur(pair, unquote_cnt, max_unq) { - if (pair instanceof Pair) { - if (pair.car instanceof Pair) { + if (is_pair(pair)) { + if (is_pair(pair.car)) { if (LSymbol.is(pair.car.car, 'unquote-splicing')) { return unquote_splice(pair, unquote_cnt + 1, max_unq); } if (LSymbol.is(pair.car.car, 'unquote')) { // + 2 - one for unquote and one for unquote splicing if (unquote_cnt + 2 === max_unq && - pair.car.cdr instanceof Pair && - pair.car.cdr.car instanceof Pair && + is_pair(pair.car.cdr) && + is_pair(pair.car.cdr.car) && LSymbol.is(pair.car.cdr.car.car, 'unquote-splicing')) { const rest = pair.car.cdr; return new Pair( @@ -8757,13 +8758,13 @@ var global_env = new Environment({ ), nil ); - } else if (pair.car.cdr instanceof Pair && - pair.car.cdr.cdr !== nil) { - if (pair.car.cdr.car instanceof Pair) { + } else if (is_pair(pair.car.cdr) && + !is_nil(pair.car.cdr.cdr)) { + if (is_pair(pair.car.cdr.car)) { // values inside unquote are lists const result = []; return (function recur(node) { - if (node === nil) { + if (is_nil(node)) { return Pair.fromArray(result); } return unpromise(evaluate(node.car, { @@ -8807,9 +8808,9 @@ var global_env = new Environment({ throw new Error("You can't call `unquote` outside " + "of quasiquote"); } - if (pair.cdr instanceof Pair) { - if (pair.cdr.cdr !== nil) { - if (pair.cdr.car instanceof Pair) { + if (is_pair(pair.cdr)) { + if (!is_nil(pair.cdr.cdr)) { + if (is_pair(pair.cdr.car)) { // TODO: test if this part is needed // this part was duplicated in previous section // if (LSymbol.is(pair.car.car, 'unquote')) { @@ -8817,7 +8818,7 @@ var global_env = new Environment({ const result = []; // evaluate all values in unquote return (function recur(node) { - if (node === nil) { + if (is_nil(node)) { return Pair.fromArray(result); } return unpromise(evaluate(node.car, { @@ -8856,7 +8857,7 @@ var global_env = new Environment({ } // ----------------------------------------------------------------- function clear(node) { - if (node instanceof Pair) { + if (is_pair(node)) { delete node[__data__]; if (!node.haveCycles('car')) { clear(node.car); @@ -8873,7 +8874,7 @@ var global_env = new Environment({ if (Array.isArray(arg.car) && !unquoted_arr(arg.car)) { return quote(arg.car); } - if (arg.car instanceof Pair && + if (is_pair(arg.car) && !arg.car.find('unquote') && !arg.car.find('unquote-splicing') && !arg.car.find('quasiquote')) { @@ -8902,7 +8903,7 @@ var global_env = new Environment({ // ------------------------------------------------------------------ append: doc('append', function append(...items) { items = items.map(item => { - if (item instanceof Pair) { + if (is_pair(item)) { return item.clone(); } return item; @@ -8917,11 +8918,11 @@ var global_env = new Environment({ var is_list = global_env.get('list?'); return items.reduce((acc, item) => { typecheck('append!', acc, ['nil', 'pair']); - if ((item instanceof Pair || item === nil) && !is_list(item)) { + if ((is_pair(item) || is_nil(item)) && !is_list(item)) { throw new Error('append!: Invalid argument, value is not a list'); } - if (acc === nil) { - if (item === nil) { + if (is_nil(acc)) { + if (is_nil(item)) { return nil; } return item; @@ -8939,10 +8940,10 @@ var global_env = new Environment({ // ------------------------------------------------------------------ reverse: doc('reverse', function reverse(arg) { typecheck('reverse', arg, ['array', 'pair', 'nil']); - if (arg === nil) { + if (is_nil(arg)) { return nil; } - if (arg instanceof Pair) { + if (is_pair(arg)) { var arr = global_env.get('list->array')(arg).reverse(); return global_env.get('array->list')(arr); } else if (Array.isArray(arg)) { @@ -8958,11 +8959,11 @@ var global_env = new Environment({ nth: doc('nth', function nth(index, obj) { typecheck('nth', index, 'number'); typecheck('nth', obj, ['array', 'pair']); - if (obj instanceof Pair) { + if (is_pair(obj)) { var node = obj; var count = 0; while (count < index) { - if (!node.cdr || node.cdr === nil || node.haveCycles('cdr')) { + if (!node.cdr || is_nil(node.cdr) || node.haveCycles('cdr')) { return nil; } node = node.cdr; @@ -9229,11 +9230,12 @@ var global_env = new Environment({ Predicate that tests if value is a string.`), // ------------------------------------------------------------------ - 'pair?': doc('pair?', function(obj) { - return obj instanceof Pair; - }, `(pair? expression) + 'pair?': doc( + 'pair?', + is_pair, + `(pair? expression) - Predicate that tests if value is a pair or list structure.`), + Predicate that tests if value is a pair or list structure.`), // ------------------------------------------------------------------ 'regex?': doc('regex?', function(obj) { return obj instanceof RegExp; @@ -9267,11 +9269,11 @@ var global_env = new Environment({ Predicate that tests if value is an array.`), // ------------------------------------------------------------------ 'object?': doc('object?', function(obj) { - return obj !== nil && obj !== null && + return !is_nil(obj) && obj !== null && !(obj instanceof LCharacter) && !(obj instanceof RegExp) && !(obj instanceof LString) && - !(obj instanceof Pair) && + !is_pair(obj) && !(obj instanceof LNumber) && typeof obj === 'object' && !(obj instanceof Array); @@ -9318,10 +9320,10 @@ var global_env = new Environment({ Function that calls fn with the list of arguments.`), // ------------------------------------------------------------------ length: doc('length', function length(obj) { - if (!obj || obj === nil) { + if (!obj || is_nil(obj)) { return 0; } - if (obj instanceof Pair) { + if (is_pair(obj)) { return obj.length(); } if ("length" in obj) { @@ -9361,7 +9363,7 @@ var global_env = new Environment({ let catch_clause, finally_clause, body_error; if (LSymbol.is(code.cdr.car.car, 'catch')) { catch_clause = code.cdr.car; - if (code.cdr.cdr instanceof Pair && + if (is_pair(code.cdr.cdr) && LSymbol.is(code.cdr.cdr.car.car, 'finally')) { finally_clause = code.cdr.cdr.car; } @@ -9468,7 +9470,7 @@ var global_env = new Environment({ } var fn = matcher('find', arg); return unpromise(fn(list.car), function(value) { - if (value && value !== nil) { + if (value && !is_nil(value)) { return list.car; } return find(arg, list.cdr); @@ -9504,14 +9506,14 @@ var global_env = new Environment({ lists.forEach((arg, i) => { typecheck('map', arg, ['pair', 'nil'], i + 1); // detect cycles - if (arg instanceof Pair && !is_list.call(this, arg)) { + if (is_pair(arg) && !is_list.call(this, arg)) { throw new Error(`map: argument ${i + 1} is not a list`); } }); if (lists.length === 0) { return nil; } - if (lists.some(x => x === nil)) { + if (lists.some(is_nil)) { return nil; } var args = lists.map(l => l.car); @@ -9534,10 +9536,10 @@ var global_env = new Environment({ 'list?': doc('list?', function(obj) { var node = obj; while (true) { - if (node === nil) { + if (is_nil(node)) { return true; } - if (!(node instanceof Pair)) { + if (!is_pair(node)) { return false; } if (node.haveCycles('cdr')) { @@ -9572,7 +9574,7 @@ var global_env = new Environment({ lists.forEach((arg, i) => { typecheck('fold', arg, ['pair', 'nil'], i + 1); }); - if (lists.some(x => x === nil)) { + if (lists.some(is_nil)) { return init; } const value = fold.call(this, fn, init, ...lists.map(l => l.cdr)); @@ -9613,7 +9615,7 @@ var global_env = new Environment({ lists.forEach((arg, i) => { typecheck('reduce', arg, ['pair', 'nil'], i + 1); }); - if (lists.some(x => x === nil)) { + if (lists.some(is_nil)) { return init; } return unpromise(fn(...lists.map(l => l.car), init), (value) => { @@ -9636,7 +9638,7 @@ var global_env = new Environment({ var fn = matcher('filter', arg); return (function loop(i) { function next(value) { - if (value && value !== nil) { + if (value && !is_nil(value)) { result.push(item); } return loop(++i); @@ -10200,7 +10202,7 @@ function typecheck_number(fn, arg, expected, position = null) { typecheck(fn, arg, 'number', position); const arg_type = arg.__type__; let match; - if (expected instanceof Pair) { + if (is_pair(expected)) { expected = expected.to_array(); } if (expected instanceof Array) { @@ -10254,7 +10256,7 @@ function typecheck(fn, arg, expected, position = null) { return; } var match = false; - if (expected instanceof Pair) { + if (is_pair(expected)) { expected = expected.to_array(); } if (expected instanceof Array) { @@ -10340,7 +10342,7 @@ function resolve_promises(arg) { function traverse(node) { if (is_promise(node)) { promises.push(node); - } else if (node instanceof Pair) { + } else if (is_pair(node)) { if (!node.haveCycles('car')) { traverse(node.car); } @@ -10365,7 +10367,7 @@ function resolve_promises(arg) { if (node instanceof Array) { return promise_all(node.map(resolve)); } - if (node instanceof Pair && promises.length) { + if (is_pair(node) && promises.length) { return promise(node); } return node; @@ -10380,7 +10382,7 @@ function evaluate_args(rest, { use_dynamic, ...options }) { return args; } return (function loop() { - if (node instanceof Pair) { + if (is_pair(node)) { let arg = evaluate(node.car, { use_dynamic, ...options }); if (use_dynamic) { // NOTE: why native function need bind to env? @@ -10399,7 +10401,7 @@ function evaluate_args(rest, { use_dynamic, ...options }) { node = node.cdr; return loop(); }); - } else if (node === nil) { + } else if (is_nil(node)) { return next(); } else { throw new Error('Syntax Error: improper list found in apply'); @@ -10410,7 +10412,7 @@ function evaluate_args(rest, { use_dynamic, ...options }) { function evaluate_syntax(macro, code, eval_args) { var value = macro.invoke(code, eval_args); return unpromise(resolve_promises(value), function(value) { - if (value instanceof Pair) { + if (is_pair(value)) { value.markCycles(); } return quote(value); @@ -10419,7 +10421,7 @@ function evaluate_syntax(macro, code, eval_args) { // ------------------------------------------------------------------------- function evaluate_macro(macro, code, eval_args) { function finalize(result) { - if (result instanceof Pair) { + if (is_pair(result)) { result.markCycles(); return result; } @@ -10499,7 +10501,7 @@ function apply(fn, args, { env, dynamic_env, use_dynamic, error = () => {} } = { const _args = args.slice(); const result = call_function(fn, _args, { env, dynamic_env, use_dynamic }); return unpromise(result, (result) => { - if (result instanceof Pair) { + if (is_pair(result)) { result.markCycles(); return quote(result); } @@ -10623,12 +10625,12 @@ function evaluate(code, { env, dynamic_env, use_dynamic, error = noop, ...rest } if (code instanceof LSymbol) { return env.get(code); } - if (!(code instanceof Pair)) { + if (!is_pair(code)) { return code; } var first = code.car; var rest = code.cdr; - if (first instanceof Pair) { + if (is_pair(first)) { value = resolve_promises(evaluate(first, eval_args)); if (is_promise(value)) { return value.then((value) => { @@ -10673,7 +10675,7 @@ function evaluate(code, { env, dynamic_env, use_dynamic, error = noop, ...rest } } } else if (is_continuation(value)) { result = value.invoke(); - } else if (code instanceof Pair) { + } else if (is_pair(code)) { value = first && first.toString(); throw new Error(`${type(first)} ${value} is not a function`); } else { @@ -10686,7 +10688,7 @@ function evaluate(code, { env, dynamic_env, use_dynamic, error = noop, ...rest } // When promise is not quoted it happen automatically, when returning // promise from evaluate. result = result.then(result => { - if (result instanceof Pair && !value[__data__]) { + if (is_pair(result) && !value[__data__]) { return evaluate(result, eval_args); } return result;