package ppxlib
Install
dune-project
Dependency
Authors
Maintainers
Sources
sha256=89a98c95ddd0bfbac17b5a936f6811af7097be3258c482d5859b73e9de9b4552
sha512=b19306473d867252d382e58e9b697531c5edccdc9283b5eaf72f524803c2fca2a58a5e8f25bee198b00de82cf8ef805b43f7488791c3ac5beb0ffba938ded826
doc/ppxlib/Ppxlib/Extension/index.html
Module Ppxlib.ExtensionSource
Declare extenders to rewrite extension nodes.
Type of declared extensions.
val declare :
string ->
'context Context.t ->
(Astlib.Ast_502.Parsetree.payload, 'a, 'context) Ast_pattern.t ->
(loc:Location.t -> path:string -> 'a) ->
tdeclare name context pattern expander declares the extension names name for context.
expander is responsible for producing the code to replace the extension in the AST. It receives as argument:
loc: the location of the enclosing node. For instance for expression it is thepexp_locfieldpath: the current module path
val declare_with_path_arg :
string ->
'context Context.t ->
(Astlib.Ast_502.Parsetree.payload, 'a, 'context) Ast_pattern.t ->
(loc:Location.t ->
path:string ->
arg:Longident.t Ppxlib_ast.Asttypes.loc option ->
'a) ->
tSame as declare except that the extension name takes an additional path argument. The path is the part of the name that start with a capitalized component. For instance in the following, the extension "map" would receive the path argument Foo.Bar:
let%map.Foo.Bar x = 1 in
...val declare_inline :
string ->
'context Context.t ->
(Astlib.Ast_502.Parsetree.payload, 'a, 'context list) Ast_pattern.t ->
(loc:Location.t -> path:string -> 'a) ->
tInline the result of the expansion into its parent. Only works for these contexts:
class_fieldclass_type_fieldsignature_itemstructure_item
val declare_inline_with_path_arg :
string ->
'context Context.t ->
(Astlib.Ast_502.Parsetree.payload, 'a, 'context list) Ast_pattern.t ->
(loc:Location.t ->
path:string ->
arg:Longident.t Ppxlib_ast.Asttypes.loc option ->
'a) ->
tThis module is used to implement Context_free.map_top_down
Given a context and a list of extension expander, returns all the ones that are for this context.
This module allows to declare extensions that do not produce a value of the context type. This is typically useful for extensions point that depends on more things from the context than the path and location.