package lintcstubs-arity

  1. Overview
  2. Docs
Legend:
Library
Module
Module type
Parameter
Class
Class type

Typedtree has an unstable API (depends on compiler version), so extract the parts we need and convert to types defined in this file. If the build breaks with new compiler versions then only this module needs to be updated (perhaps by using Dune's support to conditionally select files based on compiler versions)

type native_arg =
  1. | Value
  2. | Double
  3. | Int32
  4. | Int64
  5. | Intnat of {
    1. untagged_int : bool;
    }
  6. | Bytecode_argv
  7. | Bytecode_argn
val ctype_of_native_arg : native_arg -> string

ctype_of_native_arg arg returns the C type used when implementing primitives for native code mode.

type t = {
  1. byte_name : string;
    (*

    name of C function implementing the primitive in bytecode mode

    *)
  2. native_name : string;
    (*

    name of C function implementinmg the primitive in native code mode

    *)
  3. arity : int;
    (*

    number of arguments to C function in native code mode

    *)
  4. alloc : bool;
    (*

    whether it allocates/raises exceptions

    *)
  5. native_result : native_arg;
    (*

    result type of the C function implementing the primitive in native code mode

    *)
  6. native_args : native_arg list;
    (*

    type of the arguments of the C function implementing the primitive in native code mode

    *)
}
val iter_primitives_exn : path:string -> (Types.type_expr -> t -> unit) -> unit

iter_primitives_exn ~path primitive_description will load the .cmt/.cmti file path and iterate on any primitives defined using primitive_description.

Exceptions from compiler-libs may escape, so it is recommended to wrap calls using with_report_exceptions.

val with_report_exceptions : (unit -> 'a) -> 'a

with_report_exceptions f will report any compiler-libs exceptions escaping from f and exit the process with code 2.

OCaml

Innovation. Community. Security.