ppxlib
Library
Module
Module type
Parameter
Class
Class type
include module type of struct include Ast_414.Parsetree end
type constant = Parsetree.constant =
| Pconst_integer of string * char option | (* Integer constants such as Suffixes |
| Pconst_char of char | (* Character such as |
| Pconst_string of string * Location.t * string option | (* Constant string such as The location span the content of the string, without the delimiters. *) |
| Pconst_float of string * char option | (* Float constant such as Suffixes |
type location_stack = Location.t list
Extension points
type attribute = Parsetree.attribute = {
attr_name : string Location.loc; |
attr_payload : payload; |
attr_loc : Location.t; |
}
Attributes such as [\@id ARG]
and [\@\@id ARG]
.
Metadata containers passed around within the AST. The compiler ignores unknown attributes.
and extension = string Location.loc * payload
Extension points such as [%id ARG] and [%%id ARG]
.
Sub-language placeholder -- rejected by the typechecker.
and attributes = attribute list
and payload = Parsetree.payload =
| PStr of structure | |
| PSig of signature | (*
|
| PTyp of core_type | (*
|
| PPat of pattern * expression option | (*
|
Core language
Type expressions
and core_type = Parsetree.core_type = {
ptyp_desc : core_type_desc; | |
ptyp_loc : Location.t; | |
ptyp_loc_stack : location_stack; | |
ptyp_attributes : attributes; | (*
|
}
and core_type_desc = Parsetree.core_type_desc =
| Ptyp_any | (*
|
| Ptyp_var of string | (* A type variable such as |
| Ptyp_arrow of Asttypes.arg_label * core_type * core_type | (*
|
| Ptyp_tuple of core_type list | (*
Invariant: |
| Ptyp_constr of Longident.t Location.loc * core_type list | (*
|
| Ptyp_object of object_field list * Asttypes.closed_flag | (*
|
| Ptyp_class of Longident.t Location.loc * core_type list | (*
|
| Ptyp_alias of core_type * string | (*
|
| Ptyp_variant of row_field list * Asttypes.closed_flag * string list option | (*
|
| Ptyp_poly of string Location.loc list * core_type | (*
Can only appear in the following context:
|
| Ptyp_package of package_type | (*
|
| Ptyp_extension of extension | (*
|
and package_type =
Longident.t Location.loc * (Longident.t Location.loc * core_type) list
As package_type
typed values:
(S, [])
represents(module S)
,(S, [(t1, T1) ; ... ; (tn, Tn)])
represents(module S with type t1 = T1 and ... and tn = Tn)
.
and row_field = Parsetree.row_field = {
prf_desc : row_field_desc; |
prf_loc : Location.t; |
prf_attributes : attributes; |
}
and row_field_desc = Parsetree.row_field_desc =
| Rtag of string Location.loc * bool * core_type list | (*
|
| Rinherit of core_type | (*
|
and object_field = Parsetree.object_field = {
pof_desc : object_field_desc; |
pof_loc : Location.t; |
pof_attributes : attributes; |
}
and object_field_desc = Parsetree.object_field_desc =
| Otag of string Location.loc * core_type |
| Oinherit of core_type |
Patterns
and pattern = Parsetree.pattern = {
ppat_desc : pattern_desc; | |
ppat_loc : Location.t; | |
ppat_loc_stack : location_stack; | |
ppat_attributes : attributes; | (*
|
}
and pattern_desc = Parsetree.pattern_desc =
| Ppat_any | (* The pattern |
| Ppat_var of string Location.loc | (* A variable pattern such as |
| Ppat_alias of pattern * string Location.loc | (* An alias pattern such as |
| Ppat_constant of constant | (* Patterns such as |
| Ppat_interval of constant * constant | (* Patterns such as Other forms of interval are recognized by the parser but rejected by the type-checker. *) |
| Ppat_tuple of pattern list | (* Patterns Invariant: |
| Ppat_construct of Longident.t Location.loc
* (string Location.loc list * pattern) option | (*
|
| Ppat_variant of string * pattern option | (*
|
| Ppat_record of (Longident.t Location.loc * pattern) list * Asttypes.closed_flag | (*
Invariant: |
| Ppat_array of pattern list | (* Pattern |
| Ppat_or of pattern * pattern | (* Pattern |
| Ppat_constraint of pattern * core_type | (* Pattern |
| Ppat_type of Longident.t Location.loc | (* Pattern |
| Ppat_lazy of pattern | (* Pattern |
| Ppat_unpack of string option Location.loc | (*
Note: |
| Ppat_exception of pattern | (* Pattern |
| Ppat_extension of extension | (* Pattern |
| Ppat_open of Longident.t Location.loc * pattern | (* Pattern |
Value expressions
and expression = Parsetree.expression = {
pexp_desc : expression_desc; | |
pexp_loc : Location.t; | |
pexp_loc_stack : location_stack; | |
pexp_attributes : attributes; | (*
|
}
and expression_desc = Parsetree.expression_desc =
| Pexp_ident of Longident.t Location.loc | (* Identifiers such as |
| Pexp_constant of constant | (* Expressions constant such as |
| Pexp_let of Asttypes.rec_flag * value_binding list * expression | (*
|
| Pexp_function of case list | (*
|
| Pexp_fun of Asttypes.arg_label * expression option * pattern * expression | (*
Notes:
|
| Pexp_apply of expression * (Asttypes.arg_label * expression) list | (*
Invariant: |
| Pexp_match of expression * case list | (*
|
| Pexp_try of expression * case list | (*
|
| Pexp_tuple of expression list | (* Expressions Invariant: |
| Pexp_construct of Longident.t Location.loc * expression option | (*
|
| Pexp_variant of string * expression option | (*
|
| Pexp_record of (Longident.t Location.loc * expression) list * expression option | (*
Invariant: |
| Pexp_field of expression * Longident.t Location.loc | (*
|
| Pexp_setfield of expression * Longident.t Location.loc * expression | (*
|
| Pexp_array of expression list | (*
|
| Pexp_ifthenelse of expression * expression * expression option | (*
|
| Pexp_sequence of expression * expression | (*
|
| Pexp_while of expression * expression | (*
|
| Pexp_for of pattern
* expression
* expression
* Asttypes.direction_flag
* expression | (*
|
| Pexp_constraint of expression * core_type | (*
|
| Pexp_coerce of expression * core_type option * core_type | (*
|
| Pexp_send of expression * string Location.loc | (*
|
| Pexp_new of Longident.t Location.loc | (*
|
| Pexp_setinstvar of string Location.loc * expression | (*
|
| Pexp_override of (string Location.loc * expression) list | (*
|
| Pexp_letmodule of string option Location.loc * module_expr * expression | (*
|
| Pexp_letexception of extension_constructor * expression | (*
|
| Pexp_assert of expression | (*
Note: |
| Pexp_lazy of expression | (*
|
| Pexp_poly of expression * core_type option | (* Used for method bodies. Can only be used as the expression under |
| Pexp_object of class_structure | (*
|
| Pexp_newtype of string Location.loc * expression | (*
|
| Pexp_pack of module_expr | (*
|
| Pexp_open of open_declaration * expression | (*
|
| Pexp_letop of letop | (*
|
| Pexp_extension of extension | (*
|
| Pexp_unreachable | (*
|
Values of type case
represents (P -> E)
or (P when E0 -> E)
and binding_op = Parsetree.binding_op = {
pbop_op : string Location.loc; |
pbop_pat : pattern; |
pbop_exp : expression; |
pbop_loc : Location.t; |
}
Value descriptions
and value_description = Parsetree.value_description = {
pval_name : string Location.loc; | |
pval_type : core_type; | |
pval_prim : string list; | |
pval_attributes : attributes; | (*
|
pval_loc : Location.t; |
}
Values of type value_description
represents:
Type declarations
and type_declaration = Parsetree.type_declaration = {
ptype_name : string Location.loc; | |
ptype_params : (core_type * (Asttypes.variance * Asttypes.injectivity)) list; | (*
|
ptype_cstrs : (core_type * core_type * Location.t) list; | (*
|
ptype_kind : type_kind; | |
ptype_private : Asttypes.private_flag; | (* for |
ptype_manifest : core_type option; | (* represents |
ptype_attributes : attributes; | (*
|
ptype_loc : Location.t; |
}
Here are type declarations and their representation, for various ptype_kind
and ptype_manifest
values:
type t
whentype_kind
isPtype_abstract
, andmanifest
isNone
,type t = T0
whentype_kind
isPtype_abstract
, andmanifest
isSome T0
,type t = C of T | ...
whentype_kind
isPtype_variant
, andmanifest
isNone
,type t = T0 = C of T | ...
whentype_kind
isPtype_variant
, andmanifest
isSome T0
,type t = {l: T; ...}
whentype_kind
isPtype_record
, andmanifest
isNone
,type t = T0 = {l : T; ...}
whentype_kind
isPtype_record
, andmanifest
isSome T0
,type t = ..
whentype_kind
isPtype_open
, andmanifest
isNone
.
and type_kind = Parsetree.type_kind =
| Ptype_abstract | |
| Ptype_variant of constructor_declaration list | |
| Ptype_record of label_declaration list | (* Invariant: non-empty list *) |
| Ptype_open |
and label_declaration = Parsetree.label_declaration = {
pld_name : string Location.loc; | |
pld_mutable : Asttypes.mutable_flag; | |
pld_type : core_type; | |
pld_loc : Location.t; | |
pld_attributes : attributes; | (*
|
}
{ ...; l: T; ... }
whenpld_mutable
isImmutable
,{ ...; mutable l: T; ... }
whenpld_mutable
isMutable
.
Note: T
can be a Ptyp_poly
.
and constructor_declaration = Parsetree.constructor_declaration = {
pcd_name : string Location.loc; | |
pcd_vars : string Location.loc list; | |
pcd_args : constructor_arguments; | |
pcd_res : core_type option; | |
pcd_loc : Location.t; | |
pcd_attributes : attributes; | (*
|
}
and constructor_arguments = Parsetree.constructor_arguments =
| Pcstr_tuple of core_type list | |
| Pcstr_record of label_declaration list | (* Values of type
|
and type_extension = Parsetree.type_extension = {
ptyext_path : Longident.t Location.loc; | |
ptyext_params : (core_type * (Asttypes.variance * Asttypes.injectivity)) list; | |
ptyext_constructors : extension_constructor list; | |
ptyext_private : Asttypes.private_flag; | |
ptyext_loc : Location.t; | |
ptyext_attributes : attributes; | (* ... |
}
Definition of new extensions constructors for the extensive sum type t
(type t += ...
).
and extension_constructor = Parsetree.extension_constructor = {
pext_name : string Location.loc; | |
pext_kind : extension_constructor_kind; | |
pext_loc : Location.t; | |
pext_attributes : attributes; | (*
|
}
and type_exception = Parsetree.type_exception = {
ptyexn_constructor : extension_constructor; | |
ptyexn_loc : Location.t; | |
ptyexn_attributes : attributes; | (*
|
}
Definition of a new exception (exception E
).
and extension_constructor_kind = Parsetree.extension_constructor_kind =
| Pext_decl of string Location.loc list
* constructor_arguments
* core_type option | (*
|
| Pext_rebind of Longident.t Location.loc | (*
|
Class language
Type expressions for the class language
and class_type = Parsetree.class_type = {
pcty_desc : class_type_desc; | |
pcty_loc : Location.t; | |
pcty_attributes : attributes; | (*
|
}
and class_type_desc = Parsetree.class_type_desc =
| Pcty_constr of Longident.t Location.loc * core_type list | (*
|
| Pcty_signature of class_signature | (*
|
| Pcty_arrow of Asttypes.arg_label * core_type * class_type | (*
|
| Pcty_extension of extension | (*
|
| Pcty_open of open_description * class_type | (*
|
and class_signature = Parsetree.class_signature = {
pcsig_self : core_type; |
pcsig_fields : class_type_field list; |
}
Values of type class_signature
represents:
object('selfpat) ... end
object ... end
whenpcsig_self
isPtyp_any
and class_type_field = Parsetree.class_type_field = {
pctf_desc : class_type_field_desc; | |
pctf_loc : Location.t; | |
pctf_attributes : attributes; | (*
|
}
and class_type_field_desc = Parsetree.class_type_field_desc =
| Pctf_inherit of class_type | (*
|
| Pctf_val of string Location.loc
* Asttypes.mutable_flag
* Asttypes.virtual_flag
* core_type | (*
|
| Pctf_method of string Location.loc
* Asttypes.private_flag
* Asttypes.virtual_flag
* core_type | (*
Note: |
| Pctf_constraint of core_type * core_type | (*
|
| Pctf_attribute of attribute | (*
|
| Pctf_extension of extension | (*
|
and 'a class_infos = 'a Parsetree.class_infos = {
pci_virt : Asttypes.virtual_flag; | |
pci_params : (core_type * (Asttypes.variance * Asttypes.injectivity)) list; | |
pci_name : string Location.loc; | |
pci_expr : 'a; | |
pci_loc : Location.t; | |
pci_attributes : attributes; | (*
|
}
Values of type class_expr class_infos
represents:
class c = ...
class ['a1,...,'an] c = ...
class virtual c = ...
They are also used for "class type" declaration.
and class_description = class_type class_infos
and class_type_declaration = class_type class_infos
Value expressions for the class language
and class_expr = Parsetree.class_expr = {
pcl_desc : class_expr_desc; | |
pcl_loc : Location.t; | |
pcl_attributes : attributes; | (*
|
}
and class_expr_desc = Parsetree.class_expr_desc =
| Pcl_constr of Longident.t Location.loc * core_type list | (*
|
| Pcl_structure of class_structure | (*
|
| Pcl_fun of Asttypes.arg_label * expression option * pattern * class_expr | (*
|
| Pcl_apply of class_expr * (Asttypes.arg_label * expression) list | (*
Invariant: |
| Pcl_let of Asttypes.rec_flag * value_binding list * class_expr | (*
|
| Pcl_constraint of class_expr * class_type | (*
|
| Pcl_extension of extension | (*
|
| Pcl_open of open_description * class_expr | (*
|
and class_structure = Parsetree.class_structure = {
pcstr_self : pattern; |
pcstr_fields : class_field list; |
}
Values of type class_structure
represents:
object(selfpat) ... end
object ... end
whenpcstr_self
isPpat_any
and class_field = Parsetree.class_field = {
pcf_desc : class_field_desc; | |
pcf_loc : Location.t; | |
pcf_attributes : attributes; | (*
|
}
and class_field_desc = Parsetree.class_field_desc =
| Pcf_inherit of Asttypes.override_flag * class_expr * string Location.loc option | (*
|
| Pcf_val of string Location.loc * Asttypes.mutable_flag * class_field_kind | (*
|
| Pcf_method of string Location.loc * Asttypes.private_flag * class_field_kind | (**) |
| Pcf_constraint of core_type * core_type | (*
|
| Pcf_initializer of expression | (*
|
| Pcf_attribute of attribute | (*
|
| Pcf_extension of extension | (*
|
and class_field_kind = Parsetree.class_field_kind =
| Cfk_virtual of core_type |
| Cfk_concrete of Asttypes.override_flag * expression |
and class_declaration = class_expr class_infos
Module language
Type expressions for the module language
and module_type = Parsetree.module_type = {
pmty_desc : module_type_desc; | |
pmty_loc : Location.t; | |
pmty_attributes : attributes; | (*
|
}
and module_type_desc = Parsetree.module_type_desc =
| Pmty_ident of Longident.t Location.loc | (*
|
| Pmty_signature of signature | (*
|
| Pmty_functor of functor_parameter * module_type | (*
|
| Pmty_with of module_type * with_constraint list | (*
|
| Pmty_typeof of module_expr | (*
|
| Pmty_extension of extension | (*
|
| Pmty_alias of Longident.t Location.loc | (*
|
and functor_parameter = Parsetree.functor_parameter =
| Unit | (*
|
| Named of string option Location.loc * module_type | (*
|
and signature = signature_item list
and signature_item = Parsetree.signature_item = {
psig_desc : signature_item_desc; |
psig_loc : Location.t; |
}
and signature_item_desc = Parsetree.signature_item_desc =
| Psig_value of value_description | (*
|
| Psig_type of Asttypes.rec_flag * type_declaration list | (*
|
| Psig_typesubst of type_declaration list | (*
|
| Psig_typext of type_extension | (*
|
| Psig_exception of type_exception | (*
|
| Psig_module of module_declaration | (*
|
| Psig_modsubst of module_substitution | (*
|
| Psig_recmodule of module_declaration list | (*
|
| Psig_modtype of module_type_declaration | (*
|
| Psig_modtypesubst of module_type_declaration | (*
|
| Psig_open of open_description | (*
|
| Psig_include of include_description | (*
|
| Psig_class of class_description list | (*
|
| Psig_class_type of class_type_declaration list | (*
|
| Psig_attribute of attribute | (*
|
| Psig_extension of extension * attributes | (*
|
and module_declaration = Parsetree.module_declaration = {
pmd_name : string option Location.loc; | |
pmd_type : module_type; | |
pmd_attributes : attributes; | (*
|
pmd_loc : Location.t; |
}
Values of type module_declaration
represents S : MT
and module_substitution = Parsetree.module_substitution = {
pms_name : string Location.loc; | |
pms_manifest : Longident.t Location.loc; | |
pms_attributes : attributes; | (*
|
pms_loc : Location.t; |
}
Values of type module_substitution
represents S := M
and module_type_declaration = Parsetree.module_type_declaration = {
pmtd_name : string Location.loc; | |
pmtd_type : module_type option; | |
pmtd_attributes : attributes; | (*
|
pmtd_loc : Location.t; |
}
Values of type module_type_declaration
represents:
S = MT
,S
for abstract module type declaration, whenpmtd_type
isNone
.
and 'a open_infos = 'a Parsetree.open_infos = {
popen_expr : 'a; |
popen_override : Asttypes.override_flag; |
popen_loc : Location.t; |
popen_attributes : attributes; |
}
Values of type 'a open_infos
represents:
open! X
whenpopen_override
isOverride
(silences the "used identifier shadowing" warning)open X
whenpopen_override
isFresh
and open_description = Longident.t Location.loc open_infos
Values of type open_description
represents:
open M.N
open M(N).O
and open_declaration = module_expr open_infos
Values of type open_declaration
represents:
open M.N
open M(N).O
open struct ... end
and 'a include_infos = 'a Parsetree.include_infos = {
pincl_mod : 'a; |
pincl_loc : Location.t; |
pincl_attributes : attributes; |
}
and include_description = module_type include_infos
Values of type include_description
represents include MT
and include_declaration = module_expr include_infos
Values of type include_declaration
represents include ME
and with_constraint = Parsetree.with_constraint =
| Pwith_type of Longident.t Location.loc * type_declaration | (*
Note: the last component of the longident must match the name of the type_declaration. *) |
| Pwith_module of Longident.t Location.loc * Longident.t Location.loc | (*
|
| Pwith_modtype of Longident.t Location.loc * module_type | (*
|
| Pwith_modtypesubst of Longident.t Location.loc * module_type | (*
|
| Pwith_typesubst of Longident.t Location.loc * type_declaration | (*
|
| Pwith_modsubst of Longident.t Location.loc * Longident.t Location.loc | (*
|
Value expressions for the module language
and module_expr = Parsetree.module_expr = {
pmod_desc : module_expr_desc; | |
pmod_loc : Location.t; | |
pmod_attributes : attributes; | (*
|
}
and module_expr_desc = Parsetree.module_expr_desc =
| Pmod_ident of Longident.t Location.loc | (*
|
| Pmod_structure of structure | (*
|
| Pmod_functor of functor_parameter * module_expr | (*
|
| Pmod_apply of module_expr * module_expr | (*
|
| Pmod_constraint of module_expr * module_type | (*
|
| Pmod_unpack of expression | (*
|
| Pmod_extension of extension | (*
|
and structure = structure_item list
and structure_item = Parsetree.structure_item = {
pstr_desc : structure_item_desc; |
pstr_loc : Location.t; |
}
and structure_item_desc = Parsetree.structure_item_desc =
| Pstr_eval of expression * attributes | (*
|
| Pstr_value of Asttypes.rec_flag * value_binding list | (*
|
| Pstr_primitive of value_description | (*
|
| Pstr_type of Asttypes.rec_flag * type_declaration list | (*
|
| Pstr_typext of type_extension | (*
|
| Pstr_exception of type_exception | (*
|
| Pstr_module of module_binding | (*
|
| Pstr_recmodule of module_binding list | (*
|
| Pstr_modtype of module_type_declaration | (*
|
| Pstr_open of open_declaration | (*
|
| Pstr_class of class_declaration list | (*
|
| Pstr_class_type of class_type_declaration list | (*
|
| Pstr_include of include_declaration | (*
|
| Pstr_attribute of attribute | (*
|
| Pstr_extension of extension * attributes | (*
|
and value_binding = Parsetree.value_binding = {
pvb_pat : pattern; |
pvb_expr : expression; |
pvb_attributes : attributes; |
pvb_loc : Location.t; |
}
and module_binding = Parsetree.module_binding = {
pmb_name : string option Location.loc; |
pmb_expr : module_expr; |
pmb_attributes : attributes; |
pmb_loc : Location.t; |
}
Values of type module_binding
represents module X = ME
Toplevel
Toplevel phrases
type toplevel_phrase = Parsetree.toplevel_phrase =
| Ptop_def of structure | |
| Ptop_dir of toplevel_directive | (*
|
and toplevel_directive = Parsetree.toplevel_directive = {
pdir_name : string Location.loc; |
pdir_arg : directive_argument option; |
pdir_loc : Location.t; |
}
and directive_argument = Parsetree.directive_argument = {
pdira_desc : directive_argument_desc; |
pdira_loc : Location.t; |
}
and directive_argument_desc = Parsetree.directive_argument_desc =
| Pdir_string of string |
| Pdir_int of string * char option |
| Pdir_ident of Longident.t |
| Pdir_bool of bool |