1Ast_iterator(3)                    OCamldoc                    Ast_iterator(3)
2
3
4

NAME

6       Ast_iterator - Ast_iterator.iterator allows to implement AST inspection
7       using open recursion.
8

Module

10       Module   Ast_iterator
11

Documentation

13       Module Ast_iterator
14        : sig end
15
16
17
18       Ast_iterator.iterator allows to implement  AST  inspection  using  open
19       recursion.    A   typical   mapper   would   be   based  on  Ast_itera‐
20       tor.default_iterator , a trivial iterator, and will fall back on it for
21       handling the syntax it does not modify.
22
23
24
25
26
27
28
29       === A generic Parsetree iterator ===
30
31
32       type iterator = {
33        attribute : iterator -> Parsetree.attribute -> unit ;
34        attributes : iterator -> Parsetree.attribute list -> unit ;
35        case : iterator -> Parsetree.case -> unit ;
36        cases : iterator -> Parsetree.case list -> unit ;
37        class_declaration : iterator -> Parsetree.class_declaration -> unit ;
38        class_description : iterator -> Parsetree.class_description -> unit ;
39        class_expr : iterator -> Parsetree.class_expr -> unit ;
40        class_field : iterator -> Parsetree.class_field -> unit ;
41        class_signature : iterator -> Parsetree.class_signature -> unit ;
42        class_structure : iterator -> Parsetree.class_structure -> unit ;
43        class_type : iterator -> Parsetree.class_type -> unit ;
44        class_type_declaration  : iterator -> Parsetree.class_type_declaration
45       -> unit ;
46        class_type_field : iterator -> Parsetree.class_type_field -> unit ;
47        constructor_declaration : iterator  ->  Parsetree.constructor_declara‐
48       tion -> unit ;
49        expr : iterator -> Parsetree.expression -> unit ;
50        extension : iterator -> Parsetree.extension -> unit ;
51        extension_constructor : iterator -> Parsetree.extension_constructor ->
52       unit ;
53        include_declaration :  iterator  ->  Parsetree.include_declaration  ->
54       unit ;
55        include_description  :  iterator  ->  Parsetree.include_description ->
56       unit ;
57        label_declaration : iterator -> Parsetree.label_declaration -> unit ;
58        location : iterator -> Location.t -> unit ;
59        module_binding : iterator -> Parsetree.module_binding -> unit ;
60        module_declaration : iterator -> Parsetree.module_declaration ->  unit
61       ;
62        module_expr : iterator -> Parsetree.module_expr -> unit ;
63        module_type : iterator -> Parsetree.module_type -> unit ;
64        module_type_declaration  :  iterator -> Parsetree.module_type_declara‐
65       tion -> unit ;
66        open_description : iterator -> Parsetree.open_description -> unit ;
67        pat : iterator -> Parsetree.pattern -> unit ;
68        payload : iterator -> Parsetree.payload -> unit ;
69        signature : iterator -> Parsetree.signature -> unit ;
70        signature_item : iterator -> Parsetree.signature_item -> unit ;
71        structure : iterator -> Parsetree.structure -> unit ;
72        structure_item : iterator -> Parsetree.structure_item -> unit ;
73        typ : iterator -> Parsetree.core_type -> unit ;
74        type_declaration : iterator -> Parsetree.type_declaration -> unit ;
75        type_extension : iterator -> Parsetree.type_extension -> unit ;
76        type_kind : iterator -> Parsetree.type_kind -> unit ;
77        value_binding : iterator -> Parsetree.value_binding -> unit ;
78        value_description : iterator -> Parsetree.value_description -> unit ;
79        with_constraint : iterator -> Parsetree.with_constraint -> unit ;
80        }
81
82
83       A iterator record implements one "method" per syntactic category, using
84       an  open  recursion  style: each method takes as its first argument the
85       iterator to be applied to children in the syntax tree.
86
87
88
89       val default_iterator : iterator
90
91       A default iterator, which implements a "do not do anything" mapping.
92
93
94
95
96
972018-04-14                          source:                    Ast_iterator(3)
Impressum