package linol

  1. Overview
  2. Docs

Blocking IO with a new thread for each spawn

type 'a t = 'a
val return : 'a -> 'a t
val failwith : string -> 'a t
val let+ : 'a t -> ('a -> 'b) -> 'b t
val let* : 'a t -> ('a -> 'b t) -> 'b t
val and+ : 'a t -> 'b t -> ('a * 'b) t
type in_channel = in_channel
type out_channel = out_channel
val stdin : in_channel
val stdout : out_channel
val read : in_channel -> bytes -> int -> int -> unit t
val read_line : in_channel -> string t
val write : out_channel -> bytes -> int -> int -> unit t
val write_string : out_channel -> string -> unit t
val spawn : (unit -> unit t) -> unit

Spawn a new task that executes concurrently.

val fail : exn -> unit t
val catch : (unit -> 'a t) -> (exn -> 'a t) -> 'a t
val set_spawn_function : ((unit -> unit) -> unit) -> unit

Change the way the LSP server spawns new threads to handle client queries. For example, one might use a thread pool.

OCaml

Innovation. Community. Security.