Legend:
Page
Library
Module
Module type
Parameter
Class
Class type
Source
Page
Library
Module
Module type
Parameter
Class
Class type
Source
val.ml1 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 80 81 82 83 84 85open Ctypes type t = (Bindings.Extism_val.t, [ `Struct ]) Ctypes.structured let t = Bindings.Extism_val.t let of_i32 (x : int32) : t = let u = Ctypes.make Bindings.Extism_val_union.t in u @. Bindings.Extism_val_union.i32 <-@ x; let t = Ctypes.make Bindings.Extism_val.t in t @. Bindings.Extism_val.ty <-@ Val_type.I32; t @. Bindings.Extism_val.v <-@ u; t let of_i64 (x : int64) : t = let u = Ctypes.make Bindings.Extism_val_union.t in u @. Bindings.Extism_val_union.i64 <-@ x; let t = Ctypes.make Bindings.Extism_val.t in t @. Bindings.Extism_val.ty <-@ Val_type.I64; t @. Bindings.Extism_val.v <-@ u; t let of_f32 (x : float) : t = let u = Ctypes.make Bindings.Extism_val_union.t in u @. Bindings.Extism_val_union.f32 <-@ x; let t = Ctypes.make Bindings.Extism_val.t in t @. Bindings.Extism_val.ty <-@ Val_type.F32; t @. Bindings.Extism_val.v <-@ u; t let of_f64 (x : float) : t = let u = Ctypes.make Bindings.Extism_val_union.t in u @. Bindings.Extism_val_union.f64 <-@ x; let t = Ctypes.make Bindings.Extism_val.t in t @. Bindings.Extism_val.ty <-@ Val_type.F64; t @. Bindings.Extism_val.v <-@ u; t let to_i32 t : int32 option = let ty = t @. Bindings.Extism_val.ty in let v = t @. Bindings.Extism_val.v in match !@ty with | Bindings.Extism_val_type.I32 -> Some !@(!@v @. Bindings.Extism_val_union.i32) | _ -> None let to_i64 t : int64 option = let ty = t @. Bindings.Extism_val.ty in let v = t @. Bindings.Extism_val.v in match !@ty with | Bindings.Extism_val_type.I64 -> Some !@(!@v @. Bindings.Extism_val_union.i64) | _ -> None let to_f32 t : float option = let ty = t @. Bindings.Extism_val.ty in let v = t @. Bindings.Extism_val.v in match !@ty with | Bindings.Extism_val_type.F32 -> Some !@(!@v @. Bindings.Extism_val_union.f32) | _ -> None let to_f64 t : float option = let ty = t @. Bindings.Extism_val.ty in let v = t @. Bindings.Extism_val.v in match !@ty with | Bindings.Extism_val_type.F64 -> Some !@(!@v @. Bindings.Extism_val_union.f64) | _ -> None let ty t = !@(t @. Bindings.Extism_val.ty) let make_exn f x = match f x with Some x -> x | None -> Error.throw (`Msg "invalid type") let to_i32_exn = make_exn to_i32 let to_i64_exn = make_exn to_i64 let to_f32_exn = make_exn to_f32 let to_f64_exn = make_exn to_f64 module Array = struct type nonrec t = t Ctypes.CArray.t let get t i = Ctypes.CArray.get t i let set t i x = Ctypes.CArray.set t i x let length t = Ctypes.CArray.length t let ( .$[] ) = get let ( .$[]<- ) = set end