spice/lib/runtime/value.ml

72 lines
1.4 KiB
OCaml
Raw Normal View History

type slotidx = int
type mthdidx = int
2023-11-29 22:56:42 +00:00
type vtable = {
n_slots : int;
elems : (string, elem) Hashtbl.t;
mthds : mthd array;
2023-11-29 22:56:42 +00:00
}
and elem =
| Field of slotidx
| Method of mthdidx
2023-11-29 22:56:42 +00:00
and mthd = ..
2023-11-29 22:56:42 +00:00
2023-11-29 21:48:24 +00:00
type t =
| Nil
| True
| False
| Int of int64
2023-11-29 22:56:42 +00:00
| Obj of vtable * t array
2023-11-29 21:48:24 +00:00
2023-11-29 22:56:42 +00:00
let make_obj vtable = Obj (vtable, Array.make vtable.n_slots Nil)
let bool = function
| true -> True
| false -> False
2023-12-02 20:31:29 +00:00
let of_elem e =
let idx =
match e with
| Field i -> i
| Method i -> -succ i
in
Int (Int64.of_int idx)
let to_elem = function
| Int idx ->
let i = Int64.to_int idx in
if i >= 0 then Field i else Method (-succ i)
| _ -> invalid_arg "to_elem: non integer value"
2023-11-29 22:56:42 +00:00
let rec pp ppf = function
| Obj (vtable, slots) -> pp_obj ppf vtable slots
| Int n -> Fmt.string ppf (Int64.to_string n)
| v -> Fmt.pf ppf "%S" (to_string v)
and to_string = function
2023-11-29 21:48:24 +00:00
| Nil -> "nil"
| True -> "true"
| False -> "false"
2023-11-29 22:56:42 +00:00
| v -> Fmt.str "%a" pp v
2023-11-29 21:48:24 +00:00
2023-11-29 22:56:42 +00:00
and pp_obj ppf vtable slots =
Fmt.pf ppf "{";
let sep = ref "" in
Hashtbl.iter
(fun name -> function
| Method _ -> ()
2023-11-29 22:56:42 +00:00
| Field idx ->
Fmt.pf ppf "%s%S:%a" !sep name pp slots.(idx);
sep := ",")
vtable.elems;
Fmt.pf ppf "}"
2023-12-02 20:31:29 +00:00
type mthd += Native_function of (t -> t list -> t)
2023-12-02 20:31:29 +00:00
let call mthd self args =
match mthd with
| Native_function f -> f self args
| _ -> raise Not_found