1erl_syntax_lib(3) Erlang Module Definition erl_syntax_lib(3)
2
3
4
6 erl_syntax_lib - Support library for abstract Erlang syntax trees.
7
9 Support library for abstract Erlang syntax trees.
10
11 This module contains utility functions for working with the abstract
12 data type defined in the module erl_syntax.
13
15 appFunName() = {atom(), arity()} | {atom(), {atom(), arity()}}:
16
17
18 field() = {atom(), {field_default(), field_type()}}:
19
20
21 field_default() = none | erl_syntax:syntaxTree():
22
23
24 field_type() = none | erl_syntax:syntaxTree():
25
26
27 fields() = [field()]:
28
29
30 functionN() = atom() | {atom(), arity()}:
31
32
33 functionName() = functionN() | {atom(), functionN()}:
34
35
36 info() = {atom(), [{atom(), erl_syntax:syntaxTree()}]} | {atom(),
37 atom()} | atom():
38
39
40 info_pair() = {key(), term()}:
41
42
43 key() = attributes | errors | exports | functions | imports | module
44 | records | warnings:
45
46
47 name() = shortname() | {atom(), shortname()}:
48
49
50 ordset(T) = ordsets:ordset(T):
51
52
53 set(T) = sets:set(T):
54
55
56 shortname() = atom() | {atom(), arity()}:
57
58
59 syntaxTree() = erl_syntax:syntaxTree():
60
61
62 An abstract syntax tree. See the erl_syntax module for details.
63
64 typeName() = atom() | {module(), {atom(), arity()}} | {atom(), ar‐
65 ity()}:
66
67
69 analyze_application(Node::erl_syntax:syntaxTree()) -> appFunName() |
70 arity()
71
72 Returns the name of a called function. The result is a represen‐
73 tation of the name of the applied function F/A, if Node repre‐
74 sents a function application "<em>F</em>(<em>X_1</em>, ...,
75 <em>X_A</em>)". If the function is not explicitly named (i.e., F
76 is given by some expression), only the arity A is returned.
77
78 The evaluation throws syntax_error if Node does not represent a
79 well-formed application expression.
80
81 See also: analyze_function_name/1.
82
83 analyze_attribute(Node::erl_syntax:syntaxTree()) -> preprocessor |
84 {atom(), term()}
85
86 Analyzes an attribute node. If Node represents a preprocessor
87 directive, the atom preprocessor is returned. Otherwise, if Node
88 represents a module attribute "-<em>Name</em>...", a tuple
89 {Name, Info} is returned, where Info depends on Name, as fol‐
90 lows:
91
92 {module, Info}:
93 where Info = analyze_module_attribute(Node).
94
95 {export, Info}:
96 where Info = analyze_export_attribute(Node).
97
98 {import, Info}:
99 where Info = analyze_import_attribute(Node).
100
101 {file, Info}:
102 where Info = analyze_file_attribute(Node).
103
104 {record, Info}:
105 where Info = analyze_record_attribute(Node).
106
107 {Name, Info}:
108 where {Name, Info} = analyze_wild_attribute(Node).
109
110 The evaluation throws syntax_error if Node does not represent a
111 well-formed module attribute.
112
113 See also: analyze_export_attribute/1, analyze_file_attribute/1,
114 analyze_import_attribute/1, analyze_module_attribute/1, ana‐
115 lyze_record_attribute/1, analyze_wild_attribute/1.
116
117 analyze_export_attribute(Node::erl_syntax:syntaxTree()) -> [function‐
118 Name()]
119
120 Returns the list of function names declared by an export attri‐
121 bute. We do not guarantee that each name occurs at most once in
122 the list. The order of listing is not defined.
123
124 The evaluation throws syntax_error if Node does not represent a
125 well-formed export attribute.
126
127 See also: analyze_attribute/1.
128
129 analyze_file_attribute(Node::erl_syntax:syntaxTree()) -> {string(), in‐
130 teger()}
131
132 Returns the file name and line number of a file attribute. The
133 result is the pair {File, Line} if Node represents "-file(File,
134 Line).".
135
136 The evaluation throws syntax_error if Node does not represent a
137 well-formed file attribute.
138
139 See also: analyze_attribute/1.
140
141 analyze_form(Node::erl_syntax:syntaxTree()) -> {atom(), term()} |
142 atom()
143
144 Analyzes a "source code form" node. If Node is a "form" type
145 (cf. erl_syntax:is_form/1), the returned value is a tuple {Type,
146 Info} where Type is the node type and Info depends on Type, as
147 follows:
148
149 {attribute, Info}:
150 where Info = analyze_attribute(Node).
151
152 {error_marker, Info}:
153 where Info = erl_syntax:error_marker_info(Node).
154
155 {function, Info}:
156 where Info = analyze_function(Node).
157
158 {warning_marker, Info}:
159 where Info = erl_syntax:warning_marker_info(Node).
160
161 For other types of forms, only the node type is returned.
162
163 The evaluation throws syntax_error if Node is not well-formed.
164
165 See also: analyze_attribute/1, analyze_function/1, erl_syn‐
166 tax:error_marker_info/1, erl_syntax:is_form/1, erl_syntax:warn‐
167 ing_marker_info/1.
168
169 analyze_forms(Forms::erl_syntax:forms()) -> [info_pair()]
170
171 Analyzes a sequence of "program forms". The given Forms may be a
172 single syntax tree of type form_list, or a list of "program
173 form" syntax trees. The returned value is a list of pairs {Key,
174 Info}, where each value of Key occurs at most once in the list;
175 the absence of a particular key indicates that there is no well-
176 defined value for that key.
177
178 Each entry in the resulting list contains the following corre‐
179 sponding information about the program forms:
180
181 {attributes, Attributes}:
182
183
184 * Attributes = [{atom(), term()}]
185
186 Attributes is a list of pairs representing the names and
187 corresponding values of all so-called "wild" attributes (as
188 e.g. "-compile(...)") occurring in Forms (cf. ana‐
189 lyze_wild_attribute/1). We do not guarantee that each name
190 occurs at most once in the list. The order of listing is not
191 defined.
192
193 {errors, Errors}:
194
195
196 * Errors = [term()]
197
198 Errors is the list of error descriptors of all error_marker
199 nodes that occur in Forms. The order of listing is not de‐
200 fined.
201
202 {exports, Exports}:
203
204
205 * Exports = [FunctionName]
206
207 * FunctionName = atom() | {atom(), integer()} | {ModuleName,
208 FunctionName}
209
210 * ModuleName = atom()
211
212 Exports is a list of representations of those function names
213 that are listed by export declaration attributes in Forms
214 (cf. analyze_export_attribute/1). We do not guarantee that
215 each name occurs at most once in the list. The order of
216 listing is not defined.
217
218 {functions, Functions}:
219
220
221 * Functions = [{atom(), integer()}]
222
223 Functions is a list of the names of the functions that are
224 defined in Forms (cf. analyze_function/1). We do not guaran‐
225 tee that each name occurs at most once in the list. The or‐
226 der of listing is not defined.
227
228 {imports, Imports}:
229
230
231 * Imports = [{Module, Names}]
232
233 * Module = atom()
234
235 * Names = [FunctionName]
236
237 * FunctionName = atom() | {atom(), integer()} | {ModuleName,
238 FunctionName}
239
240 * ModuleName = atom()
241
242 Imports is a list of pairs representing those module names
243 and corresponding function names that are listed by import
244 declaration attributes in Forms (cf. analyze_import_attri‐
245 bute/1), where each Module occurs at most once in Imports.
246 We do not guarantee that each name occurs at most once in
247 the lists of function names. The order of listing is not de‐
248 fined.
249
250 {module, ModuleName}:
251
252
253 * ModuleName = atom()
254
255 ModuleName is the name declared by a module attribute in
256 Forms. If no module name is defined in Forms, the result
257 will contain no entry for the module key. If multiple module
258 name declarations should occur, all but the first will be
259 ignored.
260
261 {records, Records}:
262
263
264 * Records = [{atom(), Fields}]
265
266 * Fields = [{atom(), {Default, Type}}]
267
268 * Default = none | syntaxTree()
269
270 * Type = none | syntaxTree()
271
272 Records is a list of pairs representing the names and corre‐
273 sponding field declarations of all record declaration at‐
274 tributes occurring in Forms. For fields declared without a
275 default value, the corresponding value for Default is the
276 atom none. Similarly, for fields declared without a type,
277 the corresponding value for Type is the atom none (cf. ana‐
278 lyze_record_attribute/1). We do not guarantee that each
279 record name occurs at most once in the list. The order of
280 listing is not defined.
281
282 {warnings, Warnings}:
283
284
285 * Warnings = [term()]
286
287 Warnings is the list of error descriptors of all warn‐
288 ing_marker nodes that occur in Forms. The order of listing
289 is not defined.
290
291 The evaluation throws syntax_error if an ill-formed Erlang con‐
292 struct is encountered.
293
294 See also: analyze_export_attribute/1, analyze_function/1, ana‐
295 lyze_import_attribute/1, analyze_record_attribute/1, ana‐
296 lyze_wild_attribute/1, erl_syntax:error_marker_info/1, erl_syn‐
297 tax:warning_marker_info/1.
298
299 analyze_function(Node::erl_syntax:syntaxTree()) -> {atom(), arity()}
300
301 Returns the name and arity of a function definition. The result
302 is a pair {Name, A} if Node represents a function definition
303 "Name(<em>P_1</em>, ..., <em>P_A</em>) -> ...".
304
305 The evaluation throws syntax_error if Node does not represent a
306 well-formed function definition.
307
308 analyze_function_name(Node::erl_syntax:syntaxTree()) -> functionName()
309
310 Returns the function name represented by a syntax tree. If Node
311 represents a function name, such as "foo/1" or "bloggs:fred/2",
312 a uniform representation of that name is returned. Different
313 nestings of arity and module name qualifiers in the syntax tree
314 does not affect the result.
315
316 The evaluation throws syntax_error if Node does not represent a
317 well-formed function name.
318
319 analyze_implicit_fun(Node::erl_syntax:syntaxTree()) -> functionName()
320
321 Returns the name of an implicit fun expression "fun <em>F</em>".
322 The result is a representation of the function name F. (Cf. ana‐
323 lyze_function_name/1.)
324
325 The evaluation throws syntax_error if Node does not represent a
326 well-formed implicit fun.
327
328 See also: analyze_function_name/1.
329
330 analyze_import_attribute(Node::erl_syntax:syntaxTree()) -> {atom(),
331 [functionName()]} | atom()
332
333 Returns the module name and (if present) list of function names
334 declared by an import attribute. The returned value is an atom
335 Module or a pair {Module, Names}, where Names is a list of func‐
336 tion names declared as imported from the module named by Module.
337 We do not guarantee that each name occurs at most once in Names.
338 The order of listing is not defined.
339
340 The evaluation throws syntax_error if Node does not represent a
341 well-formed import attribute.
342
343 See also: analyze_attribute/1.
344
345 analyze_module_attribute(Node::erl_syntax:syntaxTree()) -> atom() |
346 {atom(), [atom()]}
347
348 Returns the module name and possible parameters declared by a
349 module attribute. If the attribute is a plain module declaration
350 such as -module(name), the result is the module name. If the at‐
351 tribute is a parameterized module declaration, the result is a
352 tuple containing the module name and a list of the parameter
353 variable names.
354
355 The evaluation throws syntax_error if Node does not represent a
356 well-formed module attribute.
357
358 See also: analyze_attribute/1.
359
360 analyze_record_attribute(Node::erl_syntax:syntaxTree()) -> {atom(),
361 fields()}
362
363 Returns the name and the list of fields of a record declaration
364 attribute. The result is a pair {Name, Fields}, if Node repre‐
365 sents "-record(Name, {...}).", where Fields is a list of pairs
366 {Label, {Default, Type}} for each field "Label", "Label =
367 <em>Default</em>", "Label :: <em>Type</em>", or "Label = <em>De‐
368 fault</em> :: <em>Type</em>" in the declaration, listed in left-
369 to-right order. If the field has no default-value declaration,
370 the value for Default will be the atom none. If the field has no
371 type declaration, the value for Type will be the atom none. We
372 do not guarantee that each label occurs at most once in the
373 list.
374
375 The evaluation throws syntax_error if Node does not represent a
376 well-formed record declaration attribute.
377
378 See also: analyze_attribute/1, analyze_record_field/1.
379
380 analyze_record_expr(Node::erl_syntax:syntaxTree()) -> {atom(), info()}
381 | atom()
382
383 Returns the record name and field name/names of a record expres‐
384 sion. If Node has type record_expr, record_index_expr or
385 record_access, a pair {Type, Info} is returned, otherwise an
386 atom Type is returned. Type is the node type of Node, and Info
387 depends on Type, as follows:
388
389 record_expr::
390 {atom(), [{atom(), Value}]}
391
392 record_access::
393 {atom(), atom()}
394
395 record_index_expr::
396 {atom(), atom()}
397
398 For a record_expr node, Info represents the record name and the
399 list of descriptors for the involved fields, listed in the order
400 they appear. A field descriptor is a pair {Label, Value}, if
401 Node represents "Label = <em>Value</em>". For a record_access
402 node, Info represents the record name and the field name. For a
403 record_index_expr node, Info represents the record name and the
404 name field name.
405
406 The evaluation throws syntax_error if Node represents a record
407 expression that is not well-formed.
408
409 See also: analyze_record_attribute/1, analyze_record_field/1.
410
411 analyze_record_field(Node::erl_syntax:syntaxTree()) -> field()
412
413 Returns the label, value-expression, and type of a record field
414 specifier. The result is a pair {Label, {Default, Type}}, if
415 Node represents "Label", "Label = <em>Default</em>", "Label ::
416 <em>Type</em>", or "Label = <em>Default</em> :: <em>Type</em>".
417 If the field has no value-expression, the value for Default will
418 be the atom none. If the field has no type, the value for Type
419 will be the atom none.
420
421 The evaluation throws syntax_error if Node does not represent a
422 well-formed record field specifier.
423
424 See also: analyze_record_attribute/1, analyze_record_expr/1.
425
426 analyze_type_application(Node::erl_syntax:syntaxTree()) -> typeName()
427
428 Returns the name of a used type. The result is a representation
429 of the name of the used pre-defined or local type N/A, if Node
430 represents a local (user) type application
431 "<em>N</em>(<em>T_1</em>, ..., <em>T_A</em>)", or a representa‐
432 tion of the name of the used remote type M:N/A if Node repre‐
433 sents a remote user type application
434 "<em>M</em>:<em>N</em>(<em>T_1</em>, ..., <em>T_A</em>)".
435
436 The evaluation throws syntax_error if Node does not represent a
437 well-formed (user) type application expression.
438
439 See also: analyze_type_name/1.
440
441 analyze_type_name(Node::erl_syntax:syntaxTree()) -> typeName()
442
443 Returns the type name represented by a syntax tree. If Node rep‐
444 resents a type name, such as "foo/1" or "bloggs:fred/2", a uni‐
445 form representation of that name is returned.
446
447 The evaluation throws syntax_error if Node does not represent a
448 well-formed type name.
449
450 analyze_wild_attribute(Node::erl_syntax:syntaxTree()) -> {atom(),
451 term()}
452
453 Returns the name and value of a "wild" attribute. The result is
454 the pair {Name, Value}, if Node represents "-Name(Value)".
455
456 Note that no checking is done whether Name is a reserved attri‐
457 bute name such as module or export: it is assumed that the at‐
458 tribute is "wild".
459
460 The evaluation throws syntax_error if Node does not represent a
461 well-formed wild attribute.
462
463 See also: analyze_attribute/1.
464
465 annotate_bindings(Tree::erl_syntax:syntaxTree()) -> erl_syntax:syntax‐
466 Tree()
467
468 Adds or updates annotations on nodes in a syntax tree. Equiva‐
469 lent to annotate_bindings(Tree, Bindings) where the top-level
470 environment Bindings is taken from the annotation {env, Bind‐
471 ings} on the root node of Tree. An exception is thrown if no
472 such annotation should exist.
473
474 See also: annotate_bindings/2.
475
476 annotate_bindings(Tree::erl_syntax:syntaxTree(), Env::ordsets:ord‐
477 set(atom())) -> erl_syntax:syntaxTree()
478
479 Adds or updates annotations on nodes in a syntax tree. Bindings
480 specifies the set of bound variables in the environment of the
481 top level node. The following annotations are affected:
482
483 * {env, Vars}, representing the input environment of the sub‐
484 tree.
485
486 * {bound, Vars}, representing the variables that are bound in
487 the subtree.
488
489 * {free, Vars}, representing the free variables in the sub‐
490 tree.
491
492 Bindings and Vars are ordered-set lists (cf. module ordsets) of
493 atoms representing variable names.
494
495 See also: ordsets(3), annotate_bindings/1.
496
497 fold(F::(erl_syntax:syntaxTree(), term()) -> term(), S::term(),
498 Tree::erl_syntax:syntaxTree()) -> term()
499
500 Folds a function over all nodes of a syntax tree. The result is
501 the value of Function(X1, Function(X2, ... Function(Xn, Start)
502 ... )), where [X1, X2, ..., Xn] are the nodes of Tree in a post-
503 order traversal.
504
505 See also: fold_subtrees/3, foldl_listlist/3.
506
507 fold_subtrees(F::(erl_syntax:syntaxTree(), term()) -> term(),
508 S::term(), Tree::erl_syntax:syntaxTree()) -> term()
509
510 Folds a function over the immediate subtrees of a syntax tree.
511 This is similar to fold/3, but only on the immediate subtrees of
512 Tree, in left-to-right order; it does not include the root node
513 of Tree.
514
515 See also: fold/3.
516
517 foldl_listlist(F::(term(), term()) -> term(), S::term(),
518 Ls::[[term()]]) -> term()
519
520 Like lists:foldl/3, but over a list of lists.
521
522 See also: lists:foldl/3, fold/3.
523
524 function_name_expansions(Fs::[name()]) -> [{shortname(), name()}]
525
526 Creates a mapping from corresponding short names to full func‐
527 tion names. Names are represented by nested tuples of atoms and
528 integers (cf. analyze_function_name/1). The result is a list
529 containing a pair {ShortName, Name} for each element Name in the
530 given list, where the corresponding ShortName is the rightmost-
531 innermost part of Name. The list thus represents a finite map‐
532 ping from unqualified names to the corresponding qualified
533 names.
534
535 Note: the resulting list can contain more than one tuple {Short‐
536 Name, Name} for the same ShortName, possibly with different val‐
537 ues for Name, depending on the given list.
538
539 See also: analyze_function_name/1.
540
541 is_fail_expr(E::erl_syntax:syntaxTree()) -> boolean()
542
543 Returns true if Tree represents an expression which never termi‐
544 nates normally. Note that the reverse does not apply. Currently,
545 the detected cases are calls to exit/1, throw/1, erlang:error/1
546 and erlang:error/2.
547
548 See also: erlang:error/1, erlang:error/2, erlang:exit/1, er‐
549 lang:throw/1.
550
551 limit(Tree::erl_syntax:syntaxTree(), Depth::integer()) -> erl_syn‐
552 tax:syntaxTree()
553
554 Equivalent to limit(Tree, Depth, Text) using the text "..." as
555 default replacement.
556
557 See also: limit/3, erl_syntax:text/1.
558
559 limit(Tree::erl_syntax:syntaxTree(), Depth::integer(), Node::erl_syn‐
560 tax:syntaxTree()) -> erl_syntax:syntaxTree()
561
562 Limits a syntax tree to a specified depth. Replaces all non-leaf
563 subtrees in Tree at the given Depth by Node. If Depth is nega‐
564 tive, the result is always Node, even if Tree has no subtrees.
565
566 When a group of subtrees (as e.g., the argument list of an ap‐
567 plication node) is at the specified depth, and there are two or
568 more subtrees in the group, these will be collectively replaced
569 by Node even if they are leaf nodes. Groups of subtrees that are
570 above the specified depth will be limited in size, as if each
571 subsequent tree in the group were one level deeper than the pre‐
572 vious. E.g., if Tree represents a list of integers "[1, 2, 3, 4,
573 5, 6, 7, 8, 9, 10]", the result of limit(Tree, 5) will represent
574 [1, 2, 3, 4, ...].
575
576 The resulting syntax tree is typically only useful for pretty-
577 printing or similar visual formatting.
578
579 See also: limit/2.
580
581 map(F::(erl_syntax:syntaxTree()) -> erl_syntax:syntaxTree(),
582 Tree::erl_syntax:syntaxTree()) -> erl_syntax:syntaxTree()
583
584 Applies a function to each node of a syntax tree. The result of
585 each application replaces the corresponding original node. The
586 order of traversal is bottom-up.
587
588 See also: map_subtrees/2.
589
590 map_subtrees(F::(erl_syntax:syntaxTree()) -> erl_syntax:syntaxTree(),
591 Tree::erl_syntax:syntaxTree()) -> erl_syntax:syntaxTree()
592
593 Applies a function to each immediate subtree of a syntax tree.
594 The result of each application replaces the corresponding origi‐
595 nal node.
596
597 See also: map/2.
598
599 mapfold(F::(erl_syntax:syntaxTree(), term()) -> {erl_syntax:syntax‐
600 Tree(), term()}, S::term(), Tree::erl_syntax:syntaxTree()) -> {erl_syn‐
601 tax:syntaxTree(), term()}
602
603 Combines map and fold in a single operation. This is similar to
604 map/2, but also propagates an extra value from each application
605 of the Function to the next, while doing a post-order traversal
606 of the tree like fold/3. The value Start is passed to the first
607 function application, and the final result is the result of the
608 last application.
609
610 See also: fold/3, map/2.
611
612 mapfold_subtrees(F::(erl_syntax:syntaxTree(), term()) -> {erl_syn‐
613 tax:syntaxTree(), term()}, S::term(), Tree::erl_syntax:syntaxTree()) ->
614 {erl_syntax:syntaxTree(), term()}
615
616 Does a mapfold operation over the immediate subtrees of a syntax
617 tree. This is similar to mapfold/3, but only on the immediate
618 subtrees of Tree, in left-to-right order; it does not include
619 the root node of Tree.
620
621 See also: mapfold/3.
622
623 mapfoldl_listlist(F::(term(), term()) -> {term(), term()}, S::term(),
624 Ls::[[term()]]) -> {[[term()]], term()}
625
626 Like lists:mapfoldl/3, but over a list of lists. The list of
627 lists in the result has the same structure as the given list of
628 lists.
629
630 new_variable_name(S::sets:set(atom())) -> atom()
631
632 Returns an atom which is not already in the set Used. This is
633 equivalent to new_variable_name(Function, Used), where Function
634 maps a given integer N to the atom whose name consists of "V"
635 followed by the numeral for N.
636
637 See also: new_variable_name/2.
638
639 new_variable_name(F::(integer()) -> atom(), S::sets:set(atom())) ->
640 atom()
641
642 Returns a user-named atom which is not already in the set Used.
643 The atom is generated by applying the given Function to a gener‐
644 ated integer. Integers are generated using an algorithm which
645 tries to keep the names randomly distributed within a reasonably
646 small range relative to the number of elements in the set.
647
648 This function uses the module rand to generate new keys. The
649 seed it uses may be initialized by calling rand:seed/1 or
650 rand:seed/2 before this function is first called.
651
652 See also: random(3), sets(3), new_variable_name/1.
653
654 new_variable_names(N::integer(), S::sets:set(atom())) -> [atom()]
655
656 Like new_variable_name/1, but generates a list of N new names.
657
658 See also: new_variable_name/1.
659
660 new_variable_names(N::integer(), F::(integer()) -> atom(),
661 S::sets:set(atom())) -> [atom()]
662
663 Like new_variable_name/2, but generates a list of N new names.
664
665 See also: new_variable_name/2.
666
667 strip_comments(Tree::erl_syntax:syntaxTree()) -> erl_syntax:syntax‐
668 Tree()
669
670 Removes all comments from all nodes of a syntax tree. All other
671 attributes (such as position information) remain unchanged.
672 Standalone comments in form lists are removed; any other stand‐
673 alone comments are changed into null-comments (no text, no in‐
674 dentation).
675
676 to_comment(Tree::erl_syntax:syntaxTree()) -> erl_syntax:syntaxTree()
677
678 Equivalent to to_comment(Tree, "% ").
679
680 to_comment(Tree::erl_syntax:syntaxTree(), Prefix::string()) -> erl_syn‐
681 tax:syntaxTree()
682
683 Equivalent to to_comment(Tree, Prefix, F) for a default format‐
684 ting function F. The default F simply calls erl_prettypr:for‐
685 mat/1.
686
687 See also: to_comment/3, erl_prettypr:format/1.
688
689 to_comment(Tree::erl_syntax:syntaxTree(), Prefix::string(),
690 F::(erl_syntax:syntaxTree()) -> string()) -> erl_syntax:syntaxTree()
691
692 Transforms a syntax tree into an abstract comment. The lines of
693 the comment contain the text for Node, as produced by the given
694 Printer function. Each line of the comment is prefixed by the
695 string Prefix (this does not include the initial "%" character
696 of the comment line).
697
698 For example, the result of to_comment(erl_syntax:ab‐
699 stract([a,b,c])) represents
700
701 %% [a,b,c]
702
703 (cf. to_comment/1).
704
705 Note: the text returned by the formatting function will be split
706 automatically into separate comment lines at each line break. No
707 extra work is needed.
708
709 See also: to_comment/1, to_comment/2.
710
711 variables(Tree::erl_syntax:syntaxTree()) -> sets:set(atom())
712
713 Returns the names of variables occurring in a syntax tree, The
714 result is a set of variable names represented by atoms. Macro
715 names are not included.
716
717 See also: sets(3).
718
720 Richard Carlsson <carlsson.richard@gmail.com>
721
722
723
724 syntax_tools 3.0 erl_syntax_lib(3)