time-to-botec/squiggle/node_modules/@rescript/std/lib/es6/char.js
NunoSempere b6addc7f05 feat: add the node modules
Necessary in order to clearly see the squiggle hotwiring.
2022-12-03 12:44:49 +00:00

127 lines
2.2 KiB
JavaScript

import * as Bytes from "./bytes.js";
function chr(n) {
if (n < 0 || n > 255) {
throw {
RE_EXN_ID: "Invalid_argument",
_1: "Char.chr",
Error: new Error()
};
}
return n;
}
function escaped(c) {
var exit = 0;
if (c >= 40) {
if (c === 92) {
return "\\\\";
}
exit = c >= 127 ? 1 : 2;
} else if (c >= 32) {
if (c >= 39) {
return "\\'";
}
exit = 2;
} else if (c >= 14) {
exit = 1;
} else {
switch (c) {
case 8 :
return "\\b";
case 9 :
return "\\t";
case 10 :
return "\\n";
case 0 :
case 1 :
case 2 :
case 3 :
case 4 :
case 5 :
case 6 :
case 7 :
case 11 :
case 12 :
exit = 1;
break;
case 13 :
return "\\r";
}
}
switch (exit) {
case 1 :
var s = [
0,
0,
0,
0
];
s[0] = /* '\\' */92;
s[1] = 48 + (c / 100 | 0) | 0;
s[2] = 48 + (c / 10 | 0) % 10 | 0;
s[3] = 48 + c % 10 | 0;
return Bytes.to_string(s);
case 2 :
var s$1 = [0];
s$1[0] = c;
return Bytes.to_string(s$1);
}
}
function lowercase(c) {
if (c >= /* 'A' */65 && c <= /* 'Z' */90 || c >= /* '\192' */192 && c <= /* '\214' */214 || c >= /* '\216' */216 && c <= /* '\222' */222) {
return c + 32 | 0;
} else {
return c;
}
}
function uppercase(c) {
if (c >= /* 'a' */97 && c <= /* 'z' */122 || c >= /* '\224' */224 && c <= /* '\246' */246 || c >= /* '\248' */248 && c <= /* '\254' */254) {
return c - 32 | 0;
} else {
return c;
}
}
function lowercase_ascii(c) {
if (c >= /* 'A' */65 && c <= /* 'Z' */90) {
return c + 32 | 0;
} else {
return c;
}
}
function uppercase_ascii(c) {
if (c >= /* 'a' */97 && c <= /* 'z' */122) {
return c - 32 | 0;
} else {
return c;
}
}
function compare(c1, c2) {
return c1 - c2 | 0;
}
function equal(c1, c2) {
return (c1 - c2 | 0) === 0;
}
export {
chr ,
escaped ,
lowercase ,
uppercase ,
lowercase_ascii ,
uppercase_ascii ,
compare ,
equal ,
}
/* No side effect */