rescript
Version:
232 lines (208 loc) • 4.68 kB
JavaScript
function set(s, i, ch) {
if (i < 0 || i >= s.length) {
throw {
RE_EXN_ID: "Invalid_argument",
_1: "index out of bounds",
Error: new Error()
};
}
s[i] = ch;
}
function get(s, i) {
if (i < 0 || i >= s.length) {
throw {
RE_EXN_ID: "Invalid_argument",
_1: "index out of bounds",
Error: new Error()
};
}
return s[i];
}
function caml_fill_bytes(s, i, l, c) {
if (l <= 0) {
return ;
}
for(var k = i ,k_finish = l + i | 0; k < k_finish; ++k){
s[k] = c;
}
}
function caml_create_bytes(len) {
if (len < 0) {
throw {
RE_EXN_ID: "Invalid_argument",
_1: "String.create",
Error: new Error()
};
}
var result = new Array(len);
for(var i = 0; i < len; ++i){
result[i] = /* '\000' */0;
}
return result;
}
function caml_blit_bytes(s1, i1, s2, i2, len) {
if (len <= 0) {
return ;
}
if (s1 === s2) {
if (i1 < i2) {
var range_a = (s1.length - i2 | 0) - 1 | 0;
var range_b = len - 1 | 0;
var range = range_a > range_b ? range_b : range_a;
for(var j = range; j >= 0; --j){
s1[i2 + j | 0] = s1[i1 + j | 0];
}
return ;
}
if (i1 <= i2) {
return ;
}
var range_a$1 = (s1.length - i1 | 0) - 1 | 0;
var range_b$1 = len - 1 | 0;
var range$1 = range_a$1 > range_b$1 ? range_b$1 : range_a$1;
for(var k = 0; k <= range$1; ++k){
s1[i2 + k | 0] = s1[i1 + k | 0];
}
return ;
}
var off1 = s1.length - i1 | 0;
if (len <= off1) {
for(var i = 0; i < len; ++i){
s2[i2 + i | 0] = s1[i1 + i | 0];
}
return ;
}
for(var i$1 = 0; i$1 < off1; ++i$1){
s2[i2 + i$1 | 0] = s1[i1 + i$1 | 0];
}
for(var i$2 = off1; i$2 < len; ++i$2){
s2[i2 + i$2 | 0] = /* '\000' */0;
}
}
function bytes_to_string(a) {
var i = 0;
var len = a.length;
var s = "";
var s_len = len;
if (i === 0 && len <= 4096 && len === a.length) {
return String.fromCharCode.apply(null, a);
}
var offset = 0;
while(s_len > 0) {
var next = s_len < 1024 ? s_len : 1024;
var tmp_bytes = new Array(next);
for(var k = 0; k < next; ++k){
tmp_bytes[k] = a[k + offset | 0];
}
s = s + String.fromCharCode.apply(null, tmp_bytes);
s_len = s_len - next | 0;
offset = offset + next | 0;
};
return s;
}
function caml_blit_string(s1, i1, s2, i2, len) {
if (len <= 0) {
return ;
}
var off1 = s1.length - i1 | 0;
if (len <= off1) {
for(var i = 0; i < len; ++i){
s2[i2 + i | 0] = s1.charCodeAt(i1 + i | 0);
}
return ;
}
for(var i$1 = 0; i$1 < off1; ++i$1){
s2[i2 + i$1 | 0] = s1.charCodeAt(i1 + i$1 | 0);
}
for(var i$2 = off1; i$2 < len; ++i$2){
s2[i2 + i$2 | 0] = /* '\000' */0;
}
}
function bytes_of_string(s) {
var len = s.length;
var res = new Array(len);
for(var i = 0; i < len; ++i){
res[i] = s.charCodeAt(i);
}
return res;
}
function caml_bytes_compare_aux(s1, s2, _off, len, def) {
while(true) {
var off = _off;
if (off >= len) {
return def;
}
var a = s1[off];
var b = s2[off];
if (a > b) {
return 1;
}
if (a < b) {
return -1;
}
_off = off + 1 | 0;
continue ;
};
}
function caml_bytes_compare(s1, s2) {
var len1 = s1.length;
var len2 = s2.length;
if (len1 === len2) {
return caml_bytes_compare_aux(s1, s2, 0, len1, 0);
} else if (len1 < len2) {
return caml_bytes_compare_aux(s1, s2, 0, len1, -1);
} else {
return caml_bytes_compare_aux(s1, s2, 0, len2, 1);
}
}
function caml_bytes_equal(s1, s2) {
var len1 = s1.length;
var len2 = s2.length;
if (len1 === len2) {
var _off = 0;
while(true) {
var off = _off;
if (off === len1) {
return true;
}
var a = s1[off];
var b = s2[off];
if (a !== b) {
return false;
}
_off = off + 1 | 0;
continue ;
};
} else {
return false;
}
}
function caml_bytes_greaterthan(s1, s2) {
return caml_bytes_compare(s1, s2) > 0;
}
function caml_bytes_greaterequal(s1, s2) {
return caml_bytes_compare(s1, s2) >= 0;
}
function caml_bytes_lessthan(s1, s2) {
return caml_bytes_compare(s1, s2) < 0;
}
function caml_bytes_lessequal(s1, s2) {
return caml_bytes_compare(s1, s2) <= 0;
}
export {
caml_create_bytes ,
caml_fill_bytes ,
get ,
set ,
bytes_to_string ,
caml_blit_bytes ,
caml_blit_string ,
bytes_of_string ,
caml_bytes_compare ,
caml_bytes_greaterthan ,
caml_bytes_greaterequal ,
caml_bytes_lessthan ,
caml_bytes_lessequal ,
caml_bytes_equal ,
}
/* No side effect */