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

476 lines
10 KiB
JavaScript
Raw Normal View History

'use strict';
var Bytes = require("./bytes.js");
var Curry = require("./curry.js");
var $$String = require("./string.js");
var Caml_bytes = require("./caml_bytes.js");
var Caml_string = require("./caml_string.js");
function create(n) {
var n$1 = n < 1 ? 1 : n;
var s = Caml_bytes.create(n$1);
return {
buffer: s,
position: 0,
length: n$1,
initial_buffer: s
};
}
function contents(b) {
return Bytes.sub_string(b.buffer, 0, b.position);
}
function to_bytes(b) {
return Bytes.sub(b.buffer, 0, b.position);
}
function sub(b, ofs, len) {
if (ofs < 0 || len < 0 || ofs > (b.position - len | 0)) {
throw {
RE_EXN_ID: "Invalid_argument",
_1: "Buffer.sub",
Error: new Error()
};
}
return Bytes.sub_string(b.buffer, ofs, len);
}
function blit(src, srcoff, dst, dstoff, len) {
if (len < 0 || srcoff < 0 || srcoff > (src.position - len | 0) || dstoff < 0 || dstoff > (dst.length - len | 0)) {
throw {
RE_EXN_ID: "Invalid_argument",
_1: "Buffer.blit",
Error: new Error()
};
}
Bytes.blit(src.buffer, srcoff, dst, dstoff, len);
}
function nth(b, ofs) {
if (ofs < 0 || ofs >= b.position) {
throw {
RE_EXN_ID: "Invalid_argument",
_1: "Buffer.nth",
Error: new Error()
};
}
return b.buffer[ofs];
}
function length(b) {
return b.position;
}
function clear(b) {
b.position = 0;
}
function reset(b) {
b.position = 0;
b.buffer = b.initial_buffer;
b.length = b.buffer.length;
}
function resize(b, more) {
var len = b.length;
var new_len = len;
while((b.position + more | 0) > new_len) {
new_len = (new_len << 1);
};
var new_buffer = Caml_bytes.create(new_len);
Bytes.blit(b.buffer, 0, new_buffer, 0, b.position);
b.buffer = new_buffer;
b.length = new_len;
}
function add_char(b, c) {
var pos = b.position;
if (pos >= b.length) {
resize(b, 1);
}
b.buffer[pos] = c;
b.position = pos + 1 | 0;
}
function add_utf_8_uchar(b, u) {
var u$1 = u;
if (u$1 < 0) {
throw {
RE_EXN_ID: "Assert_failure",
_1: [
"buffer.ml",
78,
19
],
Error: new Error()
};
}
if (u$1 <= 127) {
return add_char(b, u$1);
}
if (u$1 <= 2047) {
var pos = b.position;
if ((pos + 2 | 0) > b.length) {
resize(b, 2);
}
b.buffer[pos] = 192 | (u$1 >>> 6);
b.buffer[pos + 1 | 0] = 128 | u$1 & 63;
b.position = pos + 2 | 0;
return ;
}
if (u$1 <= 65535) {
var pos$1 = b.position;
if ((pos$1 + 3 | 0) > b.length) {
resize(b, 3);
}
b.buffer[pos$1] = 224 | (u$1 >>> 12);
b.buffer[pos$1 + 1 | 0] = 128 | (u$1 >>> 6) & 63;
b.buffer[pos$1 + 2 | 0] = 128 | u$1 & 63;
b.position = pos$1 + 3 | 0;
return ;
}
if (u$1 <= 1114111) {
var pos$2 = b.position;
if ((pos$2 + 4 | 0) > b.length) {
resize(b, 4);
}
b.buffer[pos$2] = 240 | (u$1 >>> 18);
b.buffer[pos$2 + 1 | 0] = 128 | (u$1 >>> 12) & 63;
b.buffer[pos$2 + 2 | 0] = 128 | (u$1 >>> 6) & 63;
b.buffer[pos$2 + 3 | 0] = 128 | u$1 & 63;
b.position = pos$2 + 4 | 0;
return ;
}
throw {
RE_EXN_ID: "Assert_failure",
_1: [
"buffer.ml",
111,
8
],
Error: new Error()
};
}
function add_utf_16be_uchar(b, u) {
var u$1 = u;
if (u$1 < 0) {
throw {
RE_EXN_ID: "Assert_failure",
_1: [
"buffer.ml",
114,
19
],
Error: new Error()
};
}
if (u$1 <= 65535) {
var pos = b.position;
if ((pos + 2 | 0) > b.length) {
resize(b, 2);
}
b.buffer[pos] = (u$1 >>> 8);
b.buffer[pos + 1 | 0] = u$1 & 255;
b.position = pos + 2 | 0;
return ;
}
if (u$1 <= 1114111) {
var u$p = u$1 - 65536 | 0;
var hi = 55296 | (u$p >>> 10);
var lo = 56320 | u$p & 1023;
var pos$1 = b.position;
if ((pos$1 + 4 | 0) > b.length) {
resize(b, 4);
}
b.buffer[pos$1] = (hi >>> 8);
b.buffer[pos$1 + 1 | 0] = hi & 255;
b.buffer[pos$1 + 2 | 0] = (lo >>> 8);
b.buffer[pos$1 + 3 | 0] = lo & 255;
b.position = pos$1 + 4 | 0;
return ;
}
throw {
RE_EXN_ID: "Assert_failure",
_1: [
"buffer.ml",
132,
8
],
Error: new Error()
};
}
function add_utf_16le_uchar(b, u) {
var u$1 = u;
if (u$1 < 0) {
throw {
RE_EXN_ID: "Assert_failure",
_1: [
"buffer.ml",
135,
19
],
Error: new Error()
};
}
if (u$1 <= 65535) {
var pos = b.position;
if ((pos + 2 | 0) > b.length) {
resize(b, 2);
}
b.buffer[pos] = u$1 & 255;
b.buffer[pos + 1 | 0] = (u$1 >>> 8);
b.position = pos + 2 | 0;
return ;
}
if (u$1 <= 1114111) {
var u$p = u$1 - 65536 | 0;
var hi = 55296 | (u$p >>> 10);
var lo = 56320 | u$p & 1023;
var pos$1 = b.position;
if ((pos$1 + 4 | 0) > b.length) {
resize(b, 4);
}
b.buffer[pos$1] = hi & 255;
b.buffer[pos$1 + 1 | 0] = (hi >>> 8);
b.buffer[pos$1 + 2 | 0] = lo & 255;
b.buffer[pos$1 + 3 | 0] = (lo >>> 8);
b.position = pos$1 + 4 | 0;
return ;
}
throw {
RE_EXN_ID: "Assert_failure",
_1: [
"buffer.ml",
153,
8
],
Error: new Error()
};
}
function add_substring(b, s, offset, len) {
if (offset < 0 || len < 0 || offset > (s.length - len | 0)) {
throw {
RE_EXN_ID: "Invalid_argument",
_1: "Buffer.add_substring/add_subbytes",
Error: new Error()
};
}
var new_position = b.position + len | 0;
if (new_position > b.length) {
resize(b, len);
}
Bytes.blit_string(s, offset, b.buffer, b.position, len);
b.position = new_position;
}
function add_subbytes(b, s, offset, len) {
add_substring(b, Bytes.unsafe_to_string(s), offset, len);
}
function add_string(b, s) {
var len = s.length;
var new_position = b.position + len | 0;
if (new_position > b.length) {
resize(b, len);
}
Bytes.blit_string(s, 0, b.buffer, b.position, len);
b.position = new_position;
}
function add_bytes(b, s) {
add_string(b, Bytes.unsafe_to_string(s));
}
function add_buffer(b, bs) {
add_subbytes(b, bs.buffer, 0, bs.position);
}
function closing(param) {
if (param === 40) {
return /* ')' */41;
}
if (param === 123) {
return /* '}' */125;
}
throw {
RE_EXN_ID: "Assert_failure",
_1: [
"buffer.ml",
181,
9
],
Error: new Error()
};
}
function advance_to_closing(opening, closing, k, s, start) {
var _k = k;
var _i = start;
var lim = s.length;
while(true) {
var i = _i;
var k$1 = _k;
if (i >= lim) {
throw {
RE_EXN_ID: "Not_found",
Error: new Error()
};
}
if (Caml_string.get(s, i) === opening) {
_i = i + 1 | 0;
_k = k$1 + 1 | 0;
continue ;
}
if (Caml_string.get(s, i) === closing) {
if (k$1 === 0) {
return i;
}
_i = i + 1 | 0;
_k = k$1 - 1 | 0;
continue ;
}
_i = i + 1 | 0;
continue ;
};
}
function advance_to_non_alpha(s, start) {
var _i = start;
var lim = s.length;
while(true) {
var i = _i;
if (i >= lim) {
return lim;
}
var match = Caml_string.get(s, i);
if (match >= 91) {
if (match >= 97) {
if (match >= 123) {
return i;
}
} else if (match !== 95) {
return i;
}
} else if (match >= 58) {
if (match < 65) {
return i;
}
} else if (match < 48) {
return i;
}
_i = i + 1 | 0;
continue ;
};
}
function find_ident(s, start, lim) {
if (start >= lim) {
throw {
RE_EXN_ID: "Not_found",
Error: new Error()
};
}
var c = Caml_string.get(s, start);
if (c !== 40 && c !== 123) {
var stop = advance_to_non_alpha(s, start + 1 | 0);
return [
$$String.sub(s, start, stop - start | 0),
stop
];
}
var new_start = start + 1 | 0;
var stop$1 = advance_to_closing(c, closing(c), 0, s, new_start);
return [
$$String.sub(s, new_start, (stop$1 - start | 0) - 1 | 0),
stop$1 + 1 | 0
];
}
function add_substitute(b, f, s) {
var lim = s.length;
var _previous = /* ' ' */32;
var _i = 0;
while(true) {
var i = _i;
var previous = _previous;
if (i >= lim) {
if (previous === /* '\\' */92) {
return add_char(b, previous);
} else {
return ;
}
}
var current = Caml_string.get(s, i);
if (current !== 36) {
if (previous === /* '\\' */92) {
add_char(b, /* '\\' */92);
add_char(b, current);
_i = i + 1 | 0;
_previous = /* ' ' */32;
continue ;
}
if (current !== 92) {
add_char(b, current);
_i = i + 1 | 0;
_previous = current;
continue ;
}
_i = i + 1 | 0;
_previous = current;
continue ;
}
if (previous === /* '\\' */92) {
add_char(b, current);
_i = i + 1 | 0;
_previous = /* ' ' */32;
continue ;
}
var j = i + 1 | 0;
var match = find_ident(s, j, lim);
add_string(b, Curry._1(f, match[0]));
_i = match[1];
_previous = /* ' ' */32;
continue ;
};
}
function truncate(b, len) {
if (len < 0 || len > b.position) {
throw {
RE_EXN_ID: "Invalid_argument",
_1: "Buffer.truncate",
Error: new Error()
};
}
b.position = len;
}
exports.create = create;
exports.contents = contents;
exports.to_bytes = to_bytes;
exports.sub = sub;
exports.blit = blit;
exports.nth = nth;
exports.length = length;
exports.clear = clear;
exports.reset = reset;
exports.add_char = add_char;
exports.add_utf_8_uchar = add_utf_8_uchar;
exports.add_utf_16le_uchar = add_utf_16le_uchar;
exports.add_utf_16be_uchar = add_utf_16be_uchar;
exports.add_string = add_string;
exports.add_bytes = add_bytes;
exports.add_substring = add_substring;
exports.add_subbytes = add_subbytes;
exports.add_substitute = add_substitute;
exports.add_buffer = add_buffer;
exports.truncate = truncate;
/* No side effect */