UNPKG

bs-platform

Version:

bucklescript compiler, ocaml standard libary by bucklescript and its required runtime support

125 lines (112 loc) 2.43 kB
'use strict'; var Caml_bytes = require("./caml_bytes.js"); var Caml_builtin_exceptions = require("./caml_builtin_exceptions.js"); function chr(n) { if (n < 0 || n > 255) { throw [ Caml_builtin_exceptions.invalid_argument, "Char.chr" ]; } 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 Caml_bytes.bytes_to_string(s); case 2 : var s$1 = [0]; s$1[0] = c; return Caml_bytes.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; } exports.chr = chr; exports.escaped = escaped; exports.lowercase = lowercase; exports.uppercase = uppercase; exports.lowercase_ascii = lowercase_ascii; exports.uppercase_ascii = uppercase_ascii; exports.compare = compare; exports.equal = equal; /* No side effect */