Module Ecaml_value.Symbol

include Ecaml_value__.Symbol_intf.Symbol
include 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 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_
include Core_kernel.Equal.S with type t := t
type t
val equal : t Core_kernel.Equal.equal
include Value.Funcall with type t := t
type t
type value
val funcall0 : (t -> value) Ecaml_value__.Value_intf.funcall
val funcall1 : (t -> value -> value) Ecaml_value__.Value_intf.funcall
val funcall2 : (t -> value -> value -> value) Ecaml_value__.Value_intf.funcall
val funcall3 : (t -> value -> value -> value -> value) Ecaml_value__.Value_intf.funcall
val funcall4 : (t -> value -> value -> value -> value -> value) Ecaml_value__.Value_intf.funcall
val funcall5 : (t -> value -> value -> value -> value -> value -> value) Ecaml_value__.Value_intf.funcall
val funcallN : (t -> value list -> value) Ecaml_value__.Value_intf.funcall
val funcallN_array : (t -> value array -> value) Ecaml_value__.Value_intf.funcall
val funcall0_i : (t -> unit) Ecaml_value__.Value_intf.funcall
val funcall1_i : (t -> value -> unit) Ecaml_value__.Value_intf.funcall
val funcall2_i : (t -> value -> value -> unit) Ecaml_value__.Value_intf.funcall
val funcall3_i : (t -> value -> value -> value -> unit) Ecaml_value__.Value_intf.funcall
val funcall4_i : (t -> value -> value -> value -> value -> unit) Ecaml_value__.Value_intf.funcall
val funcall5_i : (t -> value -> value -> value -> value -> value -> unit) Ecaml_value__.Value_intf.funcall
val funcallN_i : (t -> value list -> unit) Ecaml_value__.Value_intf.funcall
val funcallN_array_i : (t -> value array -> unit) Ecaml_value__.Value_intf.funcall
val funcall_int_int_value_value_unit : (t -> int -> int -> value -> value -> unit) Ecaml_value__.Value_intf.funcall
val funcall_int_int_value_unit : (t -> int -> int -> value -> unit) Ecaml_value__.Value_intf.funcall
val intern : string -> t
val name : t -> string