time-to-botec/squiggle/node_modules/@rescript/std/lib/js/stream.js

495 lines
10 KiB
JavaScript
Raw Normal View History

'use strict';
var List = require("./list.js");
var Curry = require("./curry.js");
var Caml_bytes = require("./caml_bytes.js");
var Caml_option = require("./caml_option.js");
var Caml_string = require("./caml_string.js");
var Caml_exceptions = require("./caml_exceptions.js");
var CamlinternalLazy = require("./camlinternalLazy.js");
var Failure = /* @__PURE__ */Caml_exceptions.create("Stream.Failure");
var $$Error = /* @__PURE__ */Caml_exceptions.create("Stream.Error");
function count(param) {
if (param !== undefined) {
return param.count;
} else {
return 0;
}
}
function data(param) {
if (param !== undefined) {
return param.data;
} else {
return /* Sempty */0;
}
}
function get_data(count, _d) {
while(true) {
var d = _d;
if (typeof d === "number") {
return d;
}
switch (d.TAG | 0) {
case /* Scons */0 :
return d;
case /* Sapp */1 :
var d2 = d._1;
var match = get_data(count, d._0);
if (typeof match === "number") {
_d = d2;
continue ;
}
if (match.TAG === /* Scons */0) {
return {
TAG: /* Scons */0,
_0: match._0,
_1: {
TAG: /* Sapp */1,
_0: match._1,
_1: d2
}
};
}
throw {
RE_EXN_ID: "Assert_failure",
_1: [
"stream.ml",
48,
12
],
Error: new Error()
};
case /* Slazy */2 :
_d = CamlinternalLazy.force(d._0);
continue ;
case /* Sgen */3 :
var g = d._0;
var match$1 = g.curr;
if (match$1 !== undefined) {
var a = Caml_option.valFromOption(match$1);
if (a !== undefined) {
g.curr = undefined;
return {
TAG: /* Scons */0,
_0: Caml_option.valFromOption(a),
_1: d
};
} else {
return /* Sempty */0;
}
}
var a$1 = Curry._1(g.func, count);
if (a$1 !== undefined) {
return {
TAG: /* Scons */0,
_0: Caml_option.valFromOption(a$1),
_1: d
};
} else {
g.curr = Caml_option.some(undefined);
return /* Sempty */0;
}
}
};
}
function peek_data(s) {
while(true) {
var f = s.data;
if (typeof f === "number") {
return ;
}
switch (f.TAG | 0) {
case /* Scons */0 :
return Caml_option.some(f._0);
case /* Sapp */1 :
var d = get_data(s.count, s.data);
if (typeof d === "number") {
return ;
}
if (d.TAG === /* Scons */0) {
s.data = d;
return Caml_option.some(d._0);
}
throw {
RE_EXN_ID: "Assert_failure",
_1: [
"stream.ml",
71,
12
],
Error: new Error()
};
case /* Slazy */2 :
s.data = CamlinternalLazy.force(f._0);
continue ;
case /* Sgen */3 :
var g = f._0;
var a = g.curr;
if (a !== undefined) {
return Caml_option.valFromOption(a);
}
var x = Curry._1(g.func, s.count);
g.curr = Caml_option.some(x);
return x;
}
};
}
function peek(s) {
if (s !== undefined) {
return peek_data(s);
}
}
function junk_data(s) {
while(true) {
var g = s.data;
if (typeof g !== "number") {
switch (g.TAG | 0) {
case /* Scons */0 :
s.count = s.count + 1 | 0;
s.data = g._1;
return ;
case /* Sgen */3 :
var g$1 = g._0;
var match = g$1.curr;
if (match !== undefined) {
s.count = s.count + 1 | 0;
g$1.curr = undefined;
return ;
}
break;
default:
}
}
var match$1 = peek_data(s);
if (match$1 === undefined) {
return ;
}
continue ;
};
}
function junk(data) {
if (data !== undefined) {
return junk_data(data);
}
}
function nget_data(n, s) {
if (n <= 0) {
return [
/* [] */0,
s.data,
0
];
}
var a = peek_data(s);
if (a === undefined) {
return [
/* [] */0,
s.data,
0
];
}
var a$1 = Caml_option.valFromOption(a);
junk_data(s);
var match = nget_data(n - 1 | 0, s);
return [
{
hd: a$1,
tl: match[0]
},
{
TAG: /* Scons */0,
_0: a$1,
_1: match[1]
},
match[2] + 1 | 0
];
}
function npeek(n, d) {
if (d !== undefined) {
var match = nget_data(n, d);
d.count = d.count - match[2] | 0;
d.data = match[1];
return match[0];
} else {
return /* [] */0;
}
}
function next(s) {
var a = peek(s);
if (a !== undefined) {
junk(s);
return Caml_option.valFromOption(a);
}
throw {
RE_EXN_ID: Failure,
Error: new Error()
};
}
function empty(s) {
var match = peek(s);
if (match === undefined) {
return ;
}
throw {
RE_EXN_ID: Failure,
Error: new Error()
};
}
function iter(f, strm) {
var _param;
while(true) {
var a = peek(strm);
if (a === undefined) {
return ;
}
junk(strm);
Curry._1(f, Caml_option.valFromOption(a));
_param = undefined;
continue ;
};
}
function from(f) {
return {
count: 0,
data: {
TAG: /* Sgen */3,
_0: {
curr: undefined,
func: f
}
}
};
}
function of_list(l) {
return {
count: 0,
data: List.fold_right((function (x, l) {
return {
TAG: /* Scons */0,
_0: x,
_1: l
};
}), l, /* Sempty */0)
};
}
function of_string(s) {
var count = {
contents: 0
};
return from(function (param) {
var c = count.contents;
if (c < s.length) {
count.contents = count.contents + 1 | 0;
return Caml_string.get(s, c);
}
});
}
function of_bytes(s) {
var count = {
contents: 0
};
return from(function (param) {
var c = count.contents;
if (c < s.length) {
count.contents = count.contents + 1 | 0;
return Caml_bytes.get(s, c);
}
});
}
function iapp(i, s) {
return {
count: 0,
data: {
TAG: /* Sapp */1,
_0: data(i),
_1: data(s)
}
};
}
function icons(i, s) {
return {
count: 0,
data: {
TAG: /* Scons */0,
_0: i,
_1: data(s)
}
};
}
function ising(i) {
return {
count: 0,
data: {
TAG: /* Scons */0,
_0: i,
_1: /* Sempty */0
}
};
}
function lapp(f, s) {
return {
count: 0,
data: {
TAG: /* Slazy */2,
_0: {
LAZY_DONE: false,
VAL: (function () {
return {
TAG: /* Sapp */1,
_0: data(Curry._1(f, undefined)),
_1: data(s)
};
})
}
}
};
}
function lcons(f, s) {
return {
count: 0,
data: {
TAG: /* Slazy */2,
_0: {
LAZY_DONE: false,
VAL: (function () {
return {
TAG: /* Scons */0,
_0: Curry._1(f, undefined),
_1: data(s)
};
})
}
}
};
}
function lsing(f) {
return {
count: 0,
data: {
TAG: /* Slazy */2,
_0: {
LAZY_DONE: false,
VAL: (function () {
return {
TAG: /* Scons */0,
_0: Curry._1(f, undefined),
_1: /* Sempty */0
};
})
}
}
};
}
function slazy(f) {
return {
count: 0,
data: {
TAG: /* Slazy */2,
_0: {
LAZY_DONE: false,
VAL: (function () {
return data(Curry._1(f, undefined));
})
}
}
};
}
function dump_data(f, param) {
if (typeof param === "number") {
console.log("Sempty");
return ;
}
switch (param.TAG | 0) {
case /* Scons */0 :
console.log("Scons (");
Curry._1(f, param._0);
console.log(", ");
dump_data(f, param._1);
console.log(")");
return ;
case /* Sapp */1 :
console.log("Sapp (");
dump_data(f, param._0);
console.log(", ");
dump_data(f, param._1);
console.log(")");
return ;
case /* Slazy */2 :
console.log("Slazy");
return ;
case /* Sgen */3 :
console.log("Sgen");
return ;
}
}
function dump(f, s) {
console.log("{count = ");
var i = count(s);
console.log(String(i));
console.log("; data = ");
dump_data(f, data(s));
console.log("}");
console.log("");
}
var sempty;
exports.Failure = Failure;
exports.$$Error = $$Error;
exports.from = from;
exports.of_list = of_list;
exports.of_string = of_string;
exports.of_bytes = of_bytes;
exports.iter = iter;
exports.next = next;
exports.empty = empty;
exports.peek = peek;
exports.junk = junk;
exports.count = count;
exports.npeek = npeek;
exports.iapp = iapp;
exports.icons = icons;
exports.ising = ising;
exports.lapp = lapp;
exports.lcons = lcons;
exports.lsing = lsing;
exports.sempty = sempty;
exports.slazy = slazy;
exports.dump = dump;
/* No side effect */