Module Ecaml.Keymap
The command bindings of input events are recorded in data structures called keymaps. Each entry in a keymap associates (or "binds") an individual event type, either to another keymap or to a command. When an event type is bound to a keymap, that keymap is used to look up the next input event; this continues until a command is found. The whole process is called "key lookup".
(Info-goto-node "(elisp)Keymaps")
include Ecaml__.Import.Value.Subtype
type value
type t
= private value
We 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 thanList.map symbols ~f:Symbol.to_value
.
val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t
val eq : t -> t -> bool
eq t1 t2 = Value.eq (to_value t1) (to_value t2)
, i.e.eq
checks whether the Emacs values underlyingt1
andt2
are physically equal. This is different thanphys_equal t1 t2
, because we don't always wrapeq
Emacs values inphys_equal
OCaml values. I.e.phys_equal t1 t2
implieseq t1 t2
, but not the converse.
val is_in_subtype : value -> bool
include Ecaml_value__.Valueable0.S with type t := t
val of_value_exn : Ecaml_value__.Value0.t -> t
val to_value : t -> Ecaml_value__.Value0.t
val type_ : t type_
val t : t type_
type keymap
= t
val parent : t -> t option
(describe-function 'keymap-parent)
(Info-goto-node "(elisp)Inheritance and Keymaps")
val set_parent : t -> t option -> unit
(describe-function 'set-keymap-parent)
(Info-goto-node "(elisp)Inheritance and Keymaps")
module Kind : sig ... end
val create : ?kind:Kind.t -> ?menu_name:string -> unit -> t
(describe-function 'make-sparse-keymap)
(describe-function 'make-keymap)
(Info-goto-node "(elisp) Creating Keymaps")
val global : unit -> t
(describe-function 'current-global-map)
(Info-goto-node "(elisp)Controlling Active Maps")
val set_global : t -> unit
(describe-function 'use-global-map)
(Info-goto-node "(elisp)Controlling Active Maps")
val set_transient : t -> unit
(describe-function 'set-transient-map)
module Entry : sig ... end
val lookup_key_exn : ?accept_defaults:bool -> t -> Key_sequence.t -> Entry.t
(describe-function 'lookup-key)
(Info-goto-node "(elisp)Functions for Key Lookup")
val define_key : t -> Key_sequence.t -> Entry.t -> unit
(describe-function 'define-key)
(Info-goto-node "(elisp)Functions for Key Lookup")
val override_minor_mode_map : Symbol.t -> f:(t -> unit) -> unit
override_minor_mode_map minor_mode ~f
overrides the bindings forminor_mode
in the current buffer with the result of callingf
on the keymap forminor_mode
.If no such map exists, an empty sparse map is created.
(describe-variable 'minor-mode-map-alist)
(describe-variable 'minor-mode-overriding-map-alist)
(Info-goto-node "(elisp)Controlling Active Maps")
val suppress_keymap : ?suppress_digits:bool -> t -> unit
(describe-function 'suppress-keymap)