Module Ecaml__.Window

type t = Ecaml__.Window0.t
val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t
include Core_kernel.Equal.S with type t := t
type t
val equal : t Core_kernel.Equal.equal
include Ecaml__.Import.Value.Subtype with type t := t
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 than List.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 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 : value -> bool
include Ecaml_value__.Valueable0.S with type t := t
type t
type 'a type_
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_
val is_live : t -> bool

(describe-function 'window-live-p).

val body_height_exn : t -> int

(describe-function 'window-body-height)

val buffer_exn : t -> Ecaml__.Import.Buffer.t

(describe-function 'window-buffer)

val get_buffer_window : Ecaml__.Import.Buffer.t -> t

(describe-function 'get-buffer-window)

val height_exn : t -> int

(describe-function 'window-height)

val point_exn : t -> Ecaml.Position.t

(describe-function 'window-point)

val width_exn : t -> int

(describe-function 'window-width)

val set_buffer_exn : ?⁠keep_margins:bool -> t -> Ecaml__.Import.Buffer.t -> unit Async_kernel.Deferred.t

(describe-function 'set-window-buffer)

val set_point_exn : t -> Ecaml.Position.t -> unit

(describe-function 'set-window-point)

val set_window_margins : ?⁠left_margin:int -> ?⁠right_margin:int -> t -> unit

(Info-goto-node "(elisp)Display Margins") (describe-function 'set-window-margins)

val delete_exn : t -> unit

(describe-function 'delete-window)

val delete_other_windows : t option -> unit

(describe-function 'delete-other-windows)

val start : t -> Ecaml.Position.t

(describe-function 'window-start)

val set_start : t -> Ecaml.Position.t -> unit

(describe-function 'set-window-start)

val end_ : ?⁠update:bool -> t -> Ecaml.Position.t

(describe-function 'window-end)

val frame : t -> Ecaml.Frame.t

(describe-function 'window-frame)

val fit_to_buffer : ?⁠max_columns:int -> ?⁠max_lines:int -> ?⁠min_columns:int -> ?⁠min_lines:int -> ?⁠preserve_size:bool -> t -> unit

(describe-function 'fit-window-to-buffer)

module Tree = Ecaml__.Window0.Tree
module Blocking : sig ... end