package async_kernel

  1. Overview
  2. Docs
Legend:
Library
Module
Module type
Parameter
Class
Class type
val iter : Async_kernel__.Types.Scheduler.t -> check_access: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit -> unit) option) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) option -> 'a) -> job_pool: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (Execution_context.t, Stdlib.Obj.t -> unit, Stdlib.Obj.t) Tuple_pool.Slots.t3 Tuple_pool.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (Execution_context.t, Stdlib.Obj.t -> unit, Stdlib.Obj.t) Tuple_pool.Slots.t3 Tuple_pool.t -> 'b) -> normal_priority_jobs: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel__.Types.Job_queue.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel__.Types.Job_queue.t -> 'c) -> low_priority_jobs: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel__.Types.Job_queue.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel__.Types.Job_queue.t -> 'd) -> very_low_priority_workers: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel__.Types.Very_low_priority_worker.t Core_kernel.Deque.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel__.Types.Very_low_priority_worker.t Core_kernel.Deque.t -> 'e) -> main_execution_context: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Execution_context.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Execution_context.t -> 'f) -> current_execution_context: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Execution_context.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Execution_context.t -> 'g) -> uncaught_exn: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (Core_kernel.Exn.t * Core_kernel.Sexp.t) option) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (Core_kernel.Exn.t * Core_kernel.Sexp.t) option -> 'h) -> cycle_count: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, int) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> int -> 'i) -> cycle_start: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Core_kernel.Time_ns.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Core_kernel.Time_ns.t -> 'j) -> in_cycle: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, bool) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> bool -> 'k) -> run_every_cycle_start: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit -> unit) list) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) list -> 'l) -> run_every_cycle_end: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit -> unit) list) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) list -> 'm) -> last_cycle_time: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t -> 'n) -> last_cycle_num_jobs: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, int) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> int -> 'o) -> total_cycle_time: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t -> 'p) -> time_source: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Core_kernel.read_write Async_kernel__.Types.Time_source.t1) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Core_kernel.read_write Async_kernel__.Types.Time_source.t1 -> 'q) -> external_jobs: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel__.Types.External_job.t Thread_safe_queue.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel__.Types.External_job.t Thread_safe_queue.t -> 'r) -> thread_safe_external_job_hook: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, unit -> unit) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) -> 's) -> job_queued_hook: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (Priority.t -> unit) option) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (Priority.t -> unit) option -> 't) -> event_added_hook: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (Core_kernel.Time_ns.t -> unit) option) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (Core_kernel.Time_ns.t -> unit) option -> 'u) -> yield: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t -> 'v) -> yield_until_no_jobs_remain: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t -> 'w) -> check_invariants: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, bool) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> bool -> 'x) -> max_num_jobs_per_priority_per_cycle: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel_config.Max_num_jobs_per_priority_per_cycle.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel_config.Max_num_jobs_per_priority_per_cycle.t -> 'y) -> record_backtraces: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, bool) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> bool -> 'z) -> on_start_of_cycle: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, unit -> unit) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) -> 'a1) -> on_end_of_cycle: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, unit -> unit) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) -> 'b1) -> 'c1
val fold : Async_kernel__.Types.Scheduler.t -> init:'a -> check_access: ('b -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit -> unit) option) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) option -> 'c) -> job_pool: ('d -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (Execution_context.t, Stdlib.Obj.t -> unit, Stdlib.Obj.t) Tuple_pool.Slots.t3 Tuple_pool.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (Execution_context.t, Stdlib.Obj.t -> unit, Stdlib.Obj.t) Tuple_pool.Slots.t3 Tuple_pool.t -> 'e) -> normal_priority_jobs: ('f -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel__.Types.Job_queue.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel__.Types.Job_queue.t -> 'g) -> low_priority_jobs: ('h -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel__.Types.Job_queue.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel__.Types.Job_queue.t -> 'i) -> very_low_priority_workers: ('j -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel__.Types.Very_low_priority_worker.t Core_kernel.Deque.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel__.Types.Very_low_priority_worker.t Core_kernel.Deque.t -> 'k) -> main_execution_context: ('l -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Execution_context.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Execution_context.t -> 'm) -> current_execution_context: ('n -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Execution_context.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Execution_context.t -> 'o) -> uncaught_exn: ('p -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (Core_kernel.Exn.t * Core_kernel.Sexp.t) option) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (Core_kernel.Exn.t * Core_kernel.Sexp.t) option -> 'q) -> cycle_count: ('r -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, int) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> int -> 's) -> cycle_start: ('t -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Core_kernel.Time_ns.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Core_kernel.Time_ns.t -> 'u) -> in_cycle: ('v -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, bool) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> bool -> 'w) -> run_every_cycle_start: ('x -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit -> unit) list) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) list -> 'y) -> run_every_cycle_end: ('z -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit -> unit) list) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) list -> 'a1) -> last_cycle_time: ('b1 -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t -> 'c1) -> last_cycle_num_jobs: ('d1 -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, int) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> int -> 'e1) -> total_cycle_time: ('f1 -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t -> 'g1) -> time_source: ('h1 -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Core_kernel.read_write Async_kernel__.Types.Time_source.t1) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Core_kernel.read_write Async_kernel__.Types.Time_source.t1 -> 'i1) -> external_jobs: ('j1 -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel__.Types.External_job.t Thread_safe_queue.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel__.Types.External_job.t Thread_safe_queue.t -> 'k1) -> thread_safe_external_job_hook: ('l1 -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, unit -> unit) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) -> 'm1) -> job_queued_hook: ('n1 -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (Priority.t -> unit) option) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (Priority.t -> unit) option -> 'o1) -> event_added_hook: ('p1 -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (Core_kernel.Time_ns.t -> unit) option) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (Core_kernel.Time_ns.t -> unit) option -> 'q1) -> yield: ('r1 -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t -> 's1) -> yield_until_no_jobs_remain: ('t1 -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t -> 'u1) -> check_invariants: ('v1 -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, bool) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> bool -> 'w1) -> max_num_jobs_per_priority_per_cycle: ('x1 -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel_config.Max_num_jobs_per_priority_per_cycle.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel_config.Max_num_jobs_per_priority_per_cycle.t -> 'y1) -> record_backtraces: ('z1 -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, bool) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> bool -> 'a2) -> on_start_of_cycle: ('b2 -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, unit -> unit) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) -> 'c2) -> on_end_of_cycle: ('d2 -> ([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, unit -> unit) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) -> 'e2) -> 'f2
val for_all : Async_kernel__.Types.Scheduler.t -> check_access: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit -> unit) option) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) option -> bool) -> job_pool: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (Execution_context.t, Stdlib.Obj.t -> unit, Stdlib.Obj.t) Tuple_pool.Slots.t3 Tuple_pool.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (Execution_context.t, Stdlib.Obj.t -> unit, Stdlib.Obj.t) Tuple_pool.Slots.t3 Tuple_pool.t -> bool) -> normal_priority_jobs: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel__.Types.Job_queue.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel__.Types.Job_queue.t -> bool) -> low_priority_jobs: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel__.Types.Job_queue.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel__.Types.Job_queue.t -> bool) -> very_low_priority_workers: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel__.Types.Very_low_priority_worker.t Core_kernel.Deque.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel__.Types.Very_low_priority_worker.t Core_kernel.Deque.t -> bool) -> main_execution_context: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Execution_context.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Execution_context.t -> bool) -> current_execution_context: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Execution_context.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Execution_context.t -> bool) -> uncaught_exn: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (Core_kernel.Exn.t * Core_kernel.Sexp.t) option) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (Core_kernel.Exn.t * Core_kernel.Sexp.t) option -> bool) -> cycle_count: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, int) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> int -> bool) -> cycle_start: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Core_kernel.Time_ns.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Core_kernel.Time_ns.t -> bool) -> in_cycle: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, bool) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> bool -> bool) -> run_every_cycle_start: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit -> unit) list) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) list -> bool) -> run_every_cycle_end: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit -> unit) list) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) list -> bool) -> last_cycle_time: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t -> bool) -> last_cycle_num_jobs: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, int) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> int -> bool) -> total_cycle_time: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t -> bool) -> time_source: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Core_kernel.read_write Async_kernel__.Types.Time_source.t1) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Core_kernel.read_write Async_kernel__.Types.Time_source.t1 -> bool) -> external_jobs: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel__.Types.External_job.t Thread_safe_queue.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel__.Types.External_job.t Thread_safe_queue.t -> bool) -> thread_safe_external_job_hook: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, unit -> unit) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) -> bool) -> job_queued_hook: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (Priority.t -> unit) option) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (Priority.t -> unit) option -> bool) -> event_added_hook: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (Core_kernel.Time_ns.t -> unit) option) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (Core_kernel.Time_ns.t -> unit) option -> bool) -> yield: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t -> bool) -> yield_until_no_jobs_remain: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t -> bool) -> check_invariants: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, bool) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> bool -> bool) -> max_num_jobs_per_priority_per_cycle: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel_config.Max_num_jobs_per_priority_per_cycle.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel_config.Max_num_jobs_per_priority_per_cycle.t -> bool) -> record_backtraces: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, bool) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> bool -> bool) -> on_start_of_cycle: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, unit -> unit) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) -> bool) -> on_end_of_cycle: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, unit -> unit) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) -> bool) -> bool
val exists : Async_kernel__.Types.Scheduler.t -> check_access: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit -> unit) option) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) option -> bool) -> job_pool: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (Execution_context.t, Stdlib.Obj.t -> unit, Stdlib.Obj.t) Tuple_pool.Slots.t3 Tuple_pool.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (Execution_context.t, Stdlib.Obj.t -> unit, Stdlib.Obj.t) Tuple_pool.Slots.t3 Tuple_pool.t -> bool) -> normal_priority_jobs: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel__.Types.Job_queue.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel__.Types.Job_queue.t -> bool) -> low_priority_jobs: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel__.Types.Job_queue.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel__.Types.Job_queue.t -> bool) -> very_low_priority_workers: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel__.Types.Very_low_priority_worker.t Core_kernel.Deque.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel__.Types.Very_low_priority_worker.t Core_kernel.Deque.t -> bool) -> main_execution_context: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Execution_context.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Execution_context.t -> bool) -> current_execution_context: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Execution_context.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Execution_context.t -> bool) -> uncaught_exn: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (Core_kernel.Exn.t * Core_kernel.Sexp.t) option) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (Core_kernel.Exn.t * Core_kernel.Sexp.t) option -> bool) -> cycle_count: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, int) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> int -> bool) -> cycle_start: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Core_kernel.Time_ns.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Core_kernel.Time_ns.t -> bool) -> in_cycle: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, bool) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> bool -> bool) -> run_every_cycle_start: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit -> unit) list) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) list -> bool) -> run_every_cycle_end: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit -> unit) list) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) list -> bool) -> last_cycle_time: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t -> bool) -> last_cycle_num_jobs: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, int) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> int -> bool) -> total_cycle_time: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t -> bool) -> time_source: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Core_kernel.read_write Async_kernel__.Types.Time_source.t1) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Core_kernel.read_write Async_kernel__.Types.Time_source.t1 -> bool) -> external_jobs: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel__.Types.External_job.t Thread_safe_queue.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel__.Types.External_job.t Thread_safe_queue.t -> bool) -> thread_safe_external_job_hook: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, unit -> unit) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) -> bool) -> job_queued_hook: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (Priority.t -> unit) option) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (Priority.t -> unit) option -> bool) -> event_added_hook: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (Core_kernel.Time_ns.t -> unit) option) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (Core_kernel.Time_ns.t -> unit) option -> bool) -> yield: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t -> bool) -> yield_until_no_jobs_remain: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t -> bool) -> check_invariants: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, bool) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> bool -> bool) -> max_num_jobs_per_priority_per_cycle: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel_config.Max_num_jobs_per_priority_per_cycle.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel_config.Max_num_jobs_per_priority_per_cycle.t -> bool) -> record_backtraces: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, bool) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> bool -> bool) -> on_start_of_cycle: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, unit -> unit) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) -> bool) -> on_end_of_cycle: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, unit -> unit) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) -> bool) -> bool
val to_list : Async_kernel__.Types.Scheduler.t -> check_access: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit -> unit) option) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) option -> 'a) -> job_pool: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (Execution_context.t, Stdlib.Obj.t -> unit, Stdlib.Obj.t) Tuple_pool.Slots.t3 Tuple_pool.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (Execution_context.t, Stdlib.Obj.t -> unit, Stdlib.Obj.t) Tuple_pool.Slots.t3 Tuple_pool.t -> 'b) -> normal_priority_jobs: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel__.Types.Job_queue.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel__.Types.Job_queue.t -> 'c) -> low_priority_jobs: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel__.Types.Job_queue.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel__.Types.Job_queue.t -> 'd) -> very_low_priority_workers: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel__.Types.Very_low_priority_worker.t Core_kernel.Deque.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel__.Types.Very_low_priority_worker.t Core_kernel.Deque.t -> 'e) -> main_execution_context: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Execution_context.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Execution_context.t -> 'f) -> current_execution_context: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Execution_context.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Execution_context.t -> 'g) -> uncaught_exn: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (Core_kernel.Exn.t * Core_kernel.Sexp.t) option) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (Core_kernel.Exn.t * Core_kernel.Sexp.t) option -> 'h) -> cycle_count: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, int) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> int -> 'i) -> cycle_start: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Core_kernel.Time_ns.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Core_kernel.Time_ns.t -> 'j) -> in_cycle: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, bool) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> bool -> 'k) -> run_every_cycle_start: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit -> unit) list) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) list -> 'l) -> run_every_cycle_end: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit -> unit) list) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) list -> 'm) -> last_cycle_time: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t -> 'n) -> last_cycle_num_jobs: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, int) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> int -> 'o) -> total_cycle_time: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t -> 'p) -> time_source: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Core_kernel.read_write Async_kernel__.Types.Time_source.t1) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Core_kernel.read_write Async_kernel__.Types.Time_source.t1 -> 'q) -> external_jobs: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel__.Types.External_job.t Thread_safe_queue.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel__.Types.External_job.t Thread_safe_queue.t -> 'r) -> thread_safe_external_job_hook: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, unit -> unit) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) -> 's) -> job_queued_hook: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (Priority.t -> unit) option) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (Priority.t -> unit) option -> 't) -> event_added_hook: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (Core_kernel.Time_ns.t -> unit) option) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (Core_kernel.Time_ns.t -> unit) option -> 'u) -> yield: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t -> 'v) -> yield_until_no_jobs_remain: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t -> 'w) -> check_invariants: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, bool) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> bool -> 'x) -> max_num_jobs_per_priority_per_cycle: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel_config.Max_num_jobs_per_priority_per_cycle.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel_config.Max_num_jobs_per_priority_per_cycle.t -> 'y) -> record_backtraces: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, bool) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> bool -> 'z) -> on_start_of_cycle: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, unit -> unit) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) -> 'a1) -> on_end_of_cycle: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, unit -> unit) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) -> 'b1) -> 'c1 list
val map : Async_kernel__.Types.Scheduler.t -> check_access: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit -> unit) option) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) option -> (unit -> unit) option) -> job_pool: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (Execution_context.t, Stdlib.Obj.t -> unit, Stdlib.Obj.t) Tuple_pool.Slots.t3 Tuple_pool.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (Execution_context.t, Stdlib.Obj.t -> unit, Stdlib.Obj.t) Tuple_pool.Slots.t3 Tuple_pool.t -> (Execution_context.t, Stdlib.Obj.t -> unit, Stdlib.Obj.t) Tuple_pool.Slots.t3 Tuple_pool.t) -> normal_priority_jobs: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel__.Types.Job_queue.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel__.Types.Job_queue.t -> Async_kernel__.Types.Job_queue.t) -> low_priority_jobs: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel__.Types.Job_queue.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel__.Types.Job_queue.t -> Async_kernel__.Types.Job_queue.t) -> very_low_priority_workers: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel__.Types.Very_low_priority_worker.t Core_kernel.Deque.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel__.Types.Very_low_priority_worker.t Core_kernel.Deque.t -> Async_kernel__.Types.Very_low_priority_worker.t Core_kernel.Deque.t) -> main_execution_context: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Execution_context.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Execution_context.t -> Execution_context.t) -> current_execution_context: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Execution_context.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Execution_context.t -> Execution_context.t) -> uncaught_exn: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (Core_kernel.Exn.t * Core_kernel.Sexp.t) option) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (Core_kernel.Exn.t * Core_kernel.Sexp.t) option -> (Core_kernel.Exn.t * Core_kernel.Sexp.t) option) -> cycle_count: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, int) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> int -> int) -> cycle_start: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Core_kernel.Time_ns.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Core_kernel.Time_ns.t -> Core_kernel.Time_ns.t) -> in_cycle: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, bool) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> bool -> bool) -> run_every_cycle_start: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit -> unit) list) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) list -> (unit -> unit) list) -> run_every_cycle_end: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit -> unit) list) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) list -> (unit -> unit) list) -> last_cycle_time: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t -> Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t) -> last_cycle_num_jobs: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, int) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> int -> int) -> total_cycle_time: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t -> Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t) -> time_source: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Core_kernel.read_write Async_kernel__.Types.Time_source.t1) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Core_kernel.read_write Async_kernel__.Types.Time_source.t1 -> Core_kernel.read_write Async_kernel__.Types.Time_source.t1) -> external_jobs: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel__.Types.External_job.t Thread_safe_queue.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel__.Types.External_job.t Thread_safe_queue.t -> Async_kernel__.Types.External_job.t Thread_safe_queue.t) -> thread_safe_external_job_hook: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, unit -> unit) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) -> unit -> unit) -> job_queued_hook: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (Priority.t -> unit) option) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (Priority.t -> unit) option -> (Priority.t -> unit) option) -> event_added_hook: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (Core_kernel.Time_ns.t -> unit) option) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (Core_kernel.Time_ns.t -> unit) option -> (Core_kernel.Time_ns.t -> unit) option) -> yield: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t -> (unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t) -> yield_until_no_jobs_remain: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, (unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t -> (unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t) -> check_invariants: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, bool) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> bool -> bool) -> max_num_jobs_per_priority_per_cycle: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, Async_kernel_config.Max_num_jobs_per_priority_per_cycle.t) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> Async_kernel_config.Max_num_jobs_per_priority_per_cycle.t -> Async_kernel_config.Max_num_jobs_per_priority_per_cycle.t) -> record_backtraces: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, bool) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> bool -> bool) -> on_start_of_cycle: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, unit -> unit) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) -> unit -> unit) -> on_end_of_cycle: (([< `Read | `Set_and_create ], Async_kernel__.Types.Scheduler.t, unit -> unit) Fieldslib.Field.t_with_perm -> Async_kernel__.Types.Scheduler.t -> (unit -> unit) -> unit -> unit) -> Async_kernel__.Types.Scheduler.t
val set_all_mutable_fields : Async_kernel__.Types.Scheduler.t -> check_access:(unit -> unit) option -> job_pool: (Execution_context.t, Stdlib.Obj.t -> unit, Stdlib.Obj.t) Tuple_pool.Slots.t3 Tuple_pool.t -> main_execution_context:Execution_context.t -> current_execution_context:Execution_context.t -> uncaught_exn:(Core_kernel.Exn.t * Core_kernel.Sexp.t) option -> cycle_count:int -> cycle_start:Core_kernel.Time_ns.t -> in_cycle:bool -> run_every_cycle_start:(unit -> unit) list -> run_every_cycle_end:(unit -> unit) list -> last_cycle_time:Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t -> last_cycle_num_jobs:int -> total_cycle_time: Core_kernel.Core_kernel_private.Time_ns_alternate_sexp.Span.t -> time_source:Core_kernel.read_write Async_kernel__.Types.Time_source.t1 -> thread_safe_external_job_hook:(unit -> unit) -> job_queued_hook:(Priority.t -> unit) option -> event_added_hook:(Core_kernel.Time_ns.t -> unit) option -> yield:(unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t -> yield_until_no_jobs_remain: (unit, Core_kernel.read_write) Async_kernel__.Types.Bvar.t -> check_invariants:bool -> max_num_jobs_per_priority_per_cycle: Async_kernel_config.Max_num_jobs_per_priority_per_cycle.t -> record_backtraces:bool -> on_start_of_cycle:(unit -> unit) -> on_end_of_cycle:(unit -> unit) -> unit
OCaml

Innovation. Community. Security.