Ecaml.TimerYou can set up a timer to call a function at a specified future time or after a certain length of idleness.
Emacs cannot run timers at any arbitrary point in a program; it can run them only when Emacs could accept output from a subprocess: namely, while waiting or inside certain primitive functions such as sit-for or read-event which _can_ wait. Therefore, a timer's execution may be delayed if Emacs is busy. However, the time of execution is very precise if Emacs is idle.
(Info-goto-node "(elisp)Timers")
include Ecaml_value.Value.Subtypetype t = private Ecaml_value.Value.tWe expose private value for free identity conversions when the value is nested in some covariant type, e.g. (symbols : Symbol.t list :> Value.t list) rather than List.map symbols ~f:Symbol.to_value.
val sexp_of_t : t -> Sexplib0.Sexp.teq t1 t2 = Value.eq (to_value t1) (to_value t2), i.e. eq checks whether the Emacs values underlying t1 and t2 are physically equal. This is different than phys_equal t1 t2, because we don't always wrap eq Emacs values in phys_equal OCaml values. I.e. phys_equal t1 t2 implies eq t1 t2, but not the converse.
val is_in_subtype : Ecaml_value.Value.t -> boolval of_value_exn : Ecaml_value__.Value0.t -> tval to_value : t -> Ecaml_value__.Value0.tval type_ : t Ecaml_value.Value.Type.tval t : t Ecaml_value.Value.Type.tval all_scheduled : unit -> t list(describe-variable 'timer-list)
val is_scheduled : t -> boolval run_after :
?repeat:Core.Time_ns.Span.t ->
Core.Source_code_position.t ->
Core.Time_ns.Span.t ->
f:(unit -> unit) ->
name:Symbol.t ->
docstring:string ->
t(describe-function 'run-at-time) (Info-goto-node "(elisp)Timers")
val run_after_i :
?repeat:Core.Time_ns.Span.t ->
Core.Source_code_position.t ->
Core.Time_ns.Span.t ->
f:(unit -> unit) ->
name:Symbol.t ->
docstring:string ->
unitrun_after_i s f = ignore (run_after s f)
val cancel : t -> unit(describe-function 'cancel-timer) (Info-goto-node "(elisp)Timers")
val sit_for :
?redisplay:bool ->
Core.Time_ns.Span.t ->
unit Async_kernel.Deferred.t(describe-function 'sit-for) (Info-goto-node "(elisp)Waiting")
val sleep_for : Core.Time_ns.Span.t -> unit Async_kernel.Deferred.t(describe-function 'sleep-for) (Info-goto-node "(elisp)Waiting")