1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79
|
// Js_of_ocaml runtime support
// http://www.ocsigen.org/js_of_ocaml/
//
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU Lesser General Public License as published by
// the Free Software Foundation, with linking exception;
// either version 2.1 of the License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public License
// along with this program; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
//Raise exception
//Provides: caml_raise_constant (const)
function caml_raise_constant(tag) {
throw tag;
}
//Provides: caml_raise_with_arg (const, mutable)
//Requires: caml_maybe_attach_backtrace
function caml_raise_with_arg(tag, arg) {
throw caml_maybe_attach_backtrace([0, tag, arg]);
}
//Provides: caml_raise_with_args (const, mutable)
//Requires: caml_maybe_attach_backtrace
function caml_raise_with_args(tag, args) {
throw caml_maybe_attach_backtrace([0, tag].concat(args));
}
//Provides: caml_raise_with_string (const, const)
//Requires: caml_raise_with_arg, caml_string_of_jsbytes
function caml_raise_with_string(tag, msg) {
caml_raise_with_arg(tag, caml_string_of_jsbytes(msg));
}
//Provides: caml_failwith (const)
//Requires: caml_raise_with_string, caml_global_data, caml_string_of_jsbytes
function caml_failwith(msg) {
if (!caml_global_data.Failure)
caml_global_data.Failure = [248, caml_string_of_jsbytes("Failure"), -3];
caml_raise_with_string(caml_global_data.Failure, msg);
}
//Provides: caml_invalid_argument (const)
//Requires: caml_raise_with_string, caml_global_data
function caml_invalid_argument(msg) {
caml_raise_with_string(caml_global_data.Invalid_argument, msg);
}
//Provides: caml_raise_end_of_file
//Requires: caml_raise_constant, caml_global_data
function caml_raise_end_of_file() {
caml_raise_constant(caml_global_data.End_of_file);
}
//Provides: caml_raise_zero_divide
//Requires: caml_raise_constant, caml_global_data
function caml_raise_zero_divide() {
caml_raise_constant(caml_global_data.Division_by_zero);
}
//Provides: caml_raise_not_found
//Requires: caml_raise_constant, caml_global_data
function caml_raise_not_found() {
caml_raise_constant(caml_global_data.Not_found);
}
//Provides: caml_array_bound_error
//Requires: caml_invalid_argument
function caml_array_bound_error() {
caml_invalid_argument("index out of bounds");
}
|