Module Shape.Flag_info

type t = {
name : Core_kernel__.Import.string;

See flag_name below.

doc : Core_kernel__.Import.string;
aliases : Core_kernel__.Import.string Core_kernel__.Import.list;
}
val compare : t -> t -> Core_kernel__.Import.int
val aliases : t -> Core_kernel__.Import.string Core_kernel__.Import.list
val doc : t -> Core_kernel__.Import.string
val name : t -> Core_kernel__.Import.string
module Fields : sig ... end
val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t
val flag_name : t -> Core_kernel__.Import.string Core_kernel.Or_error.t

flag_name infers the string which one would pass on the command line. It is not the same as the raw name field, which additionally encodes num_occurrences and requires_arg (sort of).

val num_occurrences : t -> Core_kernel__Command_shape.Num_occurrences.t Core_kernel.Or_error.t
val requires_arg : t -> Core_kernel__.Import.bool Core_kernel.Or_error.t

requires_arg gives undefined behavior on escape flags. This is a limitation of the underlying shape representation.

include Core_kernel.Binable.S with type t := t
type t
include Bin_prot.Binable.S_only_functions with type t := t
type t
val bin_size_t : t Bin_prot.Size.sizer
val bin_write_t : t Bin_prot.Write.writer
val bin_read_t : t Bin_prot.Read.reader
val __bin_read_t__ : (int -> t) Bin_prot.Read.reader

This function only needs implementation if t exposed to be a polymorphic variant. Despite what the type reads, this does *not* produce a function after reading; instead it takes the constructor tag (int) before reading and reads the rest of the variant t afterwards.

val bin_shape_t : Bin_prot.Shape.t
val bin_writer_t : t Bin_prot.Type_class.writer
val bin_reader_t : t Bin_prot.Type_class.reader
val bin_t : t Bin_prot.Type_class.t
val t_of_sexp : Core_kernel.Sexp.t -> t
val sort : t Core_kernel__.Import.list -> t Core_kernel__.Import.list
val to_string : t Core_kernel__.Import.list -> Core_kernel__.Import.string