1cerl(3)                    Erlang Module Definition                    cerl(3)
2
3
4

NAME

6       cerl - Core Erlang abstract syntax trees.
7

DESCRIPTION

9       Core Erlang abstract syntax trees.
10
11       This  module defines an abstract data type for representing Core Erlang
12       source code as syntax trees.
13
14       A recommended starting point for the first-time user is the  documenta‐
15       tion of the function type/1.
16
17       NOTES:
18
19       This  module  deals with the composition and decomposition of syntactic
20       entities (as opposed to semantic ones); its purpose is to hide all  di‐
21       rect  references  to  the data structures used to represent these enti‐
22       ties. With few exceptions, the functions in this module perform no  se‐
23       mantic  interpretation of their inputs, and in general, the user is as‐
24       sumed to pass type-correct arguments - if this is not done, the effects
25       are not defined.
26
27       Currently,  the internal data structure used is the same as the record-
28       based data structures used traditionally in the Beam compiler.
29
30       The internal representations of abstract syntax trees  are  subject  to
31       change  without  notice, and should not be documented outside this mod‐
32       ule. Furthermore, we do not give any guarantees on how an abstract syn‐
33       tax  tree may or may not be represented, with the following exceptions:
34       no syntax tree is represented by a single atom, such as none, by a list
35       constructor  [X  |  Y],  or by the empty list []. This can be relied on
36       when writing functions that operate on syntax trees.
37

DATA TYPES

39         c_alias() = #c_alias{}:
40
41
42         c_apply() = #c_apply{}:
43
44
45         c_binary() = #c_binary{}:
46
47
48         c_bitstr() = #c_bitstr{}:
49
50
51         c_call() = #c_call{}:
52
53
54         c_case() = #c_case{}:
55
56
57         c_catch() = #c_catch{}:
58
59
60         c_clause() = #c_clause{}:
61
62
63         c_cons() = #c_cons{}:
64
65
66         c_fun() = #c_fun{}:
67
68
69         c_lct() = c_literal() | c_cons() | c_tuple():
70
71
72         c_let() = #c_let{}:
73
74
75         c_letrec() = #c_letrec{}:
76
77
78         c_literal() = #c_literal{}:
79
80
81         c_map() = #c_map{}:
82
83
84         c_map_pair() = #c_map_pair{}:
85
86
87         c_module() = #c_module{}:
88
89
90         c_primop() = #c_primop{}:
91
92
93         c_receive() = #c_receive{}:
94
95
96         c_seq() = #c_seq{}:
97
98
99         c_try() = #c_try{}:
100
101
102         c_tuple() = #c_tuple{}:
103
104
105         c_values() = #c_values{}:
106
107
108         c_var() = #c_var{}:
109
110
111         cerl() = c_alias() | c_apply() | c_binary() | c_bitstr() | c_call() |
112         c_case()  |  c_catch()  | c_clause() | c_cons() | c_fun() | c_let() |
113         c_letrec() | c_literal() | c_map()  |  c_map_pair()  |  c_module()  |
114         c_primop() | c_receive() | c_seq() | c_try() | c_tuple() | c_values()
115         | c_var():
116
117
118         ctype() = alias | apply | binary | bitstr | call |  case  |  catch  |
119         clause  | cons | fun | let | letrec | literal | map | map_pair | mod‐
120         ule | primop | receive | seq | try | tuple | values | var:
121
122
123         dtype() = cons | tuple | {atomic, value()}:
124
125
126         map_op() = #c_literal{val=assoc} | #c_literal{val=exact}:
127
128
129         value() = integer() | float() | atom() | []:
130
131
132         var_name() = integer() | atom() | {atom(), integer()}:
133
134

EXPORTS

136       abstract(T::term()) -> c_literal()
137
138              Creates a syntax tree corresponding to an Erlang term. Term must
139              be a literal term, i.e., one that can be represented as a source
140              code literal. Thus, it may not  contain  a  process  identifier,
141              port, reference, binary or function value as a subterm.
142
143              Note: This is a constant time operation.
144
145              See  also:  ann_abstract/2,  concrete/1,  is_literal/1,  is_lit‐
146              eral_term/1.
147
148       add_ann(Terms::[term()], Node::cerl()) -> cerl()
149
150              Appends Annotations to the list of user annotations of Node.
151
152              Note:  this  is  equivalent  to  set_ann(Node,  Annotations   ++
153              get_ann(Node)), but potentially more efficient.
154
155              See also: get_ann/1, set_ann/2.
156
157       alias_pat(Node::c_alias()) -> cerl()
158
159              Returns the pattern subtree of an abstract pattern alias.
160
161              See also: c_alias/2.
162
163       alias_var(Node::c_alias()) -> c_var()
164
165              Returns the variable subtree of an abstract pattern alias.
166
167              See also: c_alias/2.
168
169       ann_abstract(As::[term()], T::term()) -> c_literal()
170
171              See also: abstract/1.
172
173       ann_c_alias(As::[term()], Var::c_var(), Pattern::cerl()) -> c_alias()
174
175              See also: c_alias/2.
176
177       ann_c_apply(As::[term()],   Operator::cerl(),  Arguments::[cerl()])  ->
178       c_apply()
179
180              See also: c_apply/2.
181
182       ann_c_atom(As::[term()], Name::atom() | string()) -> c_literal()
183
184              See also: c_atom/1.
185
186       ann_c_binary(As::[term()], Segments::[cerl()]) -> c_binary()
187
188              See also: c_binary/1.
189
190       ann_c_bitstr(As::[term()], Value::cerl(),  Size::cerl(),  Type::cerl(),
191       Flags::cerl()) -> c_bitstr()
192
193              Equivalent  to  ann_c_bitstr(As, Value, Size, abstract(1), Type,
194              Flags).
195
196       ann_c_bitstr(As::[term()],  Val::cerl(),  Size::cerl(),   Unit::cerl(),
197       Type::cerl(), Flags::cerl()) -> c_bitstr()
198
199              See also: ann_c_bitstr/5, c_bitstr/5.
200
201       ann_c_call(As::[term()],     Module::cerl(),     Name::cerl(),    Argu‐
202       ments::[cerl()]) -> c_call()
203
204              See also: c_call/3.
205
206       ann_c_case(As::[term()], Expr::cerl(), Clauses::[cerl()]) -> c_case()
207
208              See also: c_case/2.
209
210       ann_c_catch(As::[term()], Body::cerl()) -> c_catch()
211
212              See also: c_catch/1.
213
214       ann_c_char(As::[term()], Value::char()) -> c_literal()
215
216              See also: c_char/1.
217
218       ann_c_clause(As::[term()],   Patterns::[cerl()],    Body::cerl())    ->
219       c_clause()
220
221              Equivalent to ann_c_clause(As, Patterns, c_atom(true), Body).
222
223              See also: c_clause/3.
224
225       ann_c_clause(As::[term()],      Patterns::[cerl()],      Guard::cerl(),
226       Body::cerl()) -> c_clause()
227
228              See also: ann_c_clause/3, c_clause/3.
229
230       ann_c_cons(As::[term()],  C_literal::cerl(),  Tail::cerl())  ->  c_lit‐
231       eral() | c_cons()
232
233              See also: c_cons/2.
234
235       ann_c_cons_skel(As::[term()], Head::cerl(), Tail::cerl()) -> c_cons()
236
237              See also: c_cons_skel/2.
238
239       ann_c_float(As::[term()], Value::float()) -> c_literal()
240
241              See also: c_float/1.
242
243       ann_c_fname(As::[term()], Atom::atom(), Arity::arity()) -> c_var()
244
245              Equivalent to ann_c_var(As, {Atom, Arity}).
246
247              See also: c_fname/2.
248
249       ann_c_fun(As::[term()], Variables::[cerl()], Body::cerl()) -> c_fun()
250
251              See also: c_fun/2.
252
253       ann_c_int(As::[term()], Value::integer()) -> c_literal()
254
255              See also: c_int/1.
256
257       ann_c_let(As::[term()],      Variables::[cerl()],     Argument::cerl(),
258       Body::cerl()) -> c_let()
259
260              See also: c_let/3.
261
262       ann_c_letrec(As::[term()], Defs::[{cerl(), cerl()}],  Body::cerl())  ->
263       c_letrec()
264
265              See also: c_letrec/2.
266
267       ann_c_map(As::[term()], Es::[c_map_pair()]) -> c_map() | c_literal()
268
269       ann_c_map(As::[term()],      C_literal::c_map()      |     c_literal(),
270       Es::[c_map_pair()]) -> c_map() | c_literal()
271
272       ann_c_map_pair(As::[term()],  Op::cerl(),  K::cerl(),   V::cerl())   ->
273       c_map_pair()
274
275       ann_c_map_pattern(As::[term()], Pairs::[c_map_pair()]) -> c_map()
276
277       ann_c_module(As::[term()],       Name::cerl(),       Exports::[cerl()],
278       Es::[{cerl(), cerl()}]) -> c_module()
279
280              See also: ann_c_module/5, c_module/3.
281
282       ann_c_module(As::[term()],   Name::cerl(),    Exports::[cerl()],    At‐
283       trs::[{cerl(), cerl()}], Es::[{cerl(), cerl()}]) -> c_module()
284
285              See also: ann_c_module/4, c_module/4.
286
287       ann_c_nil(As::[term()]) -> c_literal()
288
289              See also: c_nil/0.
290
291       ann_c_primop(As::[term()], Name::cerl(), Arguments::[cerl()]) -> c_pri‐
292       mop()
293
294              See also: c_primop/2.
295
296       ann_c_receive(As::[term()], Clauses::[cerl()]) -> c_receive()
297
298              Equivalent  to  ann_c_receive(As,   Clauses,   c_atom(infinity),
299              c_atom(true)).
300
301              See also: c_atom/1, c_receive/3.
302
303       ann_c_receive(As::[term()],   Clauses::[cerl()],  Timeout::cerl(),  Ac‐
304       tion::cerl()) -> c_receive()
305
306              See also: ann_c_receive/2, c_receive/3.
307
308       ann_c_seq(As::[term()], Argument::cerl(), Body::cerl()) -> c_seq()
309
310              See also: c_seq/2.
311
312       ann_c_string(As::[term()], Value::string()) -> c_literal()
313
314              See also: c_string/1.
315
316       ann_c_try(As::[term()],   Expr::cerl(),   Vs::[cerl()],   Body::cerl(),
317       Evs::[cerl()], Handler::cerl()) -> c_try()
318
319              See also: c_try/5.
320
321       ann_c_tuple(As::[term()], Es::[cerl()]) -> c_tuple() | c_literal()
322
323              See also: c_tuple/1.
324
325       ann_c_tuple_skel(As::[term()], Es::[cerl()]) -> c_tuple()
326
327              See also: c_tuple_skel/1.
328
329       ann_c_values(As::[term()], Es::[cerl()]) -> c_values()
330
331              See also: c_values/1.
332
333       ann_c_var(As::[term()], Name::var_name()) -> c_var()
334
335              See also: c_var/1.
336
337       ann_make_data(As::[term()], X2::dtype(), Es::[cerl()]) -> c_lct()
338
339              See also: make_data/2.
340
341       ann_make_data_skel(As::[term()], X2::dtype(), Es::[cerl()]) -> c_lct()
342
343              See also: make_data_skel/2.
344
345       ann_make_list(As::[term()], List::[cerl()]) -> cerl()
346
347              Equivalent to ann_make_list(As, List, none).
348
349       ann_make_list(As::[term()], T::[cerl()], Tail::cerl() | none) -> cerl()
350
351              See also: ann_make_list/2, make_list/2.
352
353       ann_make_tree(As::[term()], X2::ctype(), X3::[[cerl()], ...]) -> cerl()
354
355              Creates  a syntax tree with the given annotations, type and sub‐
356              trees. See make_tree/2 for details.
357
358              See also: make_tree/2.
359
360       apply_args(Node::c_apply()) -> [cerl()]
361
362              Returns the list of argument subtrees of  an  abstract  function
363              application.
364
365              See also: apply_arity/1, c_apply/2.
366
367       apply_arity(Node::c_apply()) -> arity()
368
369              Returns  the number of argument subtrees of an abstract function
370              application.
371
372              Note: this is equivalent to length(apply_args(Node)), but poten‐
373              tially more efficient.
374
375              See also: apply_args/1, c_apply/2.
376
377       apply_op(Node::c_apply()) -> cerl()
378
379              Returns  the  operator  subtree of an abstract function applica‐
380              tion.
381
382              See also: c_apply/2.
383
384       atom_lit(Node::cerl()) -> nonempty_string()
385
386              Returns the literal string represented by an abstract atom. This
387              always includes surrounding single-quote characters.
388
389              Note  that an abstract atom may have several literal representa‐
390              tions, and that the representation yielded by this  function  is
391              not  fixed;  e.g.,  atom_lit(c_atom("a\012b"))  could  yield the
392              string "\'a\\nb\'".
393
394              See also: c_atom/1.
395
396       atom_name(Node::c_literal()) -> string()
397
398              Returns the printname of an abstract atom.
399
400              See also: c_atom/1.
401
402       atom_val(Node::c_literal()) -> atom()
403
404              Returns the value represented by an abstract atom.
405
406              See also: c_atom/1.
407
408       binary_segments(Node::c_binary()) -> [cerl()]
409
410              Returns the list of segment subtrees of an abstract  binary-tem‐
411              plate.
412
413              See also: c_binary/1, c_bitstr/5.
414
415       bitstr_bitsize(Node::c_bitstr()) -> all | any | utf | non_neg_integer()
416
417              Returns  the  total  size in bits of an abstract bit-string tem‐
418              plate. If the size field is an integer literal,  the  result  is
419              the  product  of  the size and unit values; if the size field is
420              the atom literal all, the atom all is returned. If the  size  is
421              not a literal, the atom any is returned.
422
423              See also: c_bitstr/5.
424
425       bitstr_flags(Node::c_bitstr()) -> cerl()
426
427              Returns the flags subtree of an abstract bit-string template.
428
429              See also: c_bitstr/5.
430
431       bitstr_size(Node::c_bitstr()) -> cerl()
432
433              Returns the size subtree of an abstract bit-string template.
434
435              See also: c_bitstr/5.
436
437       bitstr_type(Node::c_bitstr()) -> cerl()
438
439              Returns the type subtree of an abstract bit-string template.
440
441              See also: c_bitstr/5.
442
443       bitstr_unit(Node::c_bitstr()) -> cerl()
444
445              Returns the unit subtree of an abstract bit-string template.
446
447              See also: c_bitstr/5.
448
449       bitstr_val(Node::c_bitstr()) -> cerl()
450
451              Returns the value subtree of an abstract bit-string template.
452
453              See also: c_bitstr/5.
454
455       c_alias(Var::c_var(), Pattern::cerl()) -> c_alias()
456
457              Creates  an abstract pattern alias. The result represents "Vari‐
458              able = Pattern".
459
460              See also: alias_pat/1, alias_var/1,  ann_c_alias/3,  c_clause/3,
461              is_c_alias/1, update_c_alias/3.
462
463       c_apply(Operator::cerl(), Arguments::[cerl()]) -> c_apply()
464
465              Creates  an  abstract function application. If Arguments is [A1,
466              ..., An], the result represents "apply Operator(A1, ..., An)".
467
468              See  also:  ann_c_apply/3,  apply_args/1,   apply_arity/1,   ap‐
469              ply_op/1, c_call/3, c_primop/2, is_c_apply/1, update_c_apply/3.
470
471       c_atom(Name::atom() | string()) -> c_literal()
472
473              Creates  an abstract atom literal. The print name of the atom is
474              the character sequence represented by Name.
475
476              Note: passing a string as argument to  this  function  causes  a
477              corresponding  atom  to  be created for the internal representa‐
478              tion.
479
480              See also:  ann_c_atom/2,  atom_lit/1,  atom_name/1,  atom_val/1,
481              is_c_atom/1.
482
483       c_binary(Segments::[cerl()]) -> c_binary()
484
485              Creates  an abstract binary-template. A binary object is in this
486              context a sequence of an arbitrary number of bits.  (The  number
487              of  bits  used to be evenly divisible by 8, but after the intro‐
488              duction of bit strings in the Erlang language,  the  choice  was
489              made  to  use  the  binary  template for all bit strings.) It is
490              specified by zero or more bit-string template segments of  arbi‐
491              trary lengths (in number of bits). If Segments is [S1, ..., Sn],
492              the result represents "#{S1, ..., Sn}#". All the  Si  must  have
493              type bitstr.
494
495              See   also:   ann_c_binary/2,   binary_segments/1,   c_bitstr/5,
496              is_c_binary/1, update_c_binary/2.
497
498       c_bitstr(Val::cerl(), Type::cerl(), Flags::cerl()) -> c_bitstr()
499
500              Equivalent to c_bitstr(Value, abstract(all), abstract(1),  Type,
501              Flags).
502
503       c_bitstr(Val::cerl(),  Size::cerl(),  Type::cerl(),  Flags::cerl())  ->
504       c_bitstr()
505
506              Equivalent to c_bitstr(Value, Size, abstract(1), Type, Flags).
507
508       c_bitstr(Val::cerl(),   Size::cerl(),    Unit::cerl(),    Type::cerl(),
509       Flags::cerl()) -> c_bitstr()
510
511              Creates an abstract bit-string template. These can only occur as
512              components of an abstract binary-template (see c_binary/1).  The
513              result  represents  "#<Value>(Size,  Unit,  Type, Flags)", where
514              Unit must represent a positive integer constant, Type must  rep‐
515              resent a constant atom (one of 'integer', 'float', or 'binary'),
516              and Flags must represent a constant list "[F1, ...,  Fn]"  where
517              all the Fi are atoms.
518
519              See  also:  ann_c_bitstr/6,  bitstr_flags/1, bitstr_size/1, bit‐
520              str_type/1, bitstr_unit/1, bitstr_val/1,  c_binary/1,  is_c_bit‐
521              str/1, update_c_bitstr/6.
522
523       c_call(Module::cerl(), Name::cerl(), Arguments::[cerl()]) -> c_call()
524
525              Creates an abstract inter-module call. If Arguments is [A1, ...,
526              An], the result represents "call Module:Name(A1, ..., An)".
527
528              See  also:  ann_c_call/4,  c_apply/2,  c_primop/2,  call_args/1,
529              call_arity/1,   call_module/1,   call_name/1,  is_c_call/1,  up‐
530              date_c_call/4.
531
532       c_case(Expr::cerl(), Clauses::[cerl()]) -> c_case()
533
534              Creates an abstract case-expression. If  Clauses  is  [C1,  ...,
535              Cn],  the  result  represents  "case Argument of C1 ... Cn end".
536              Clauses must not be empty.
537
538              See also: ann_c_case/3,  c_clause/3,  case_arg/1,  case_arity/1,
539              case_clauses/1, is_c_case/1, update_c_case/3.
540
541       c_catch(Body::cerl()) -> c_catch()
542
543              Creates  an  abstract  catch-expression.  The  result represents
544              "catch Body".
545
546              Note: catch-expressions can be rewritten as try-expressions, and
547              will eventually be removed from Core Erlang.
548
549              See  also:  ann_c_catch/2,  c_try/5, catch_body/1, is_c_catch/1,
550              update_c_catch/2.
551
552       c_char(Value::non_neg_integer()) -> c_literal()
553
554              Creates an abstract character literal. If the local  implementa‐
555              tion  of  Erlang  defines  char() as a subset of integer(), this
556              function is equivalent to c_int/1. Otherwise, if the given value
557              is  an  integer,  it will be converted to the character with the
558              corresponding code. The lexical representation of a character is
559              "$Char",  where Char is a single printing character or an escape
560              sequence.
561
562              See  also:  ann_c_char/2,   c_int/1,   c_string/1,   char_lit/1,
563              char_val/1, is_c_char/1, is_print_char/1.
564
565       c_clause(Patterns::[cerl()], Body::cerl()) -> c_clause()
566
567              Equivalent to c_clause(Patterns, c_atom(true), Body).
568
569              See also: c_atom/1.
570
571       c_clause(Patterns::[cerl()], Guard::cerl(), Body::cerl()) -> c_clause()
572
573              Creates an an abstract clause. If Patterns is [P1, ..., Pn], the
574              result represents "<P1, ..., Pn> when Guard -> Body".
575
576              See also:  ann_c_clause/4,  c_case/2,  c_clause/2,  c_receive/3,
577              clause_arity/1,  clause_body/1,  clause_guard/1,  clause_pats/1,
578              clause_vars/1, is_c_clause/1, update_c_clause/4.
579
580       c_cons(C_literal::cerl(), Tail::cerl()) -> c_literal() | c_cons()
581
582              Creates an abstract  list  constructor.  The  result  represents
583              "[Head  | Tail]". Note that if both Head and Tail have type lit‐
584              eral, then the result will also have type literal,  and  annota‐
585              tions on Head and Tail are lost.
586
587              Recall that in Erlang, the tail element of a list constructor is
588              not necessarily a list.
589
590              See  also:  ann_c_cons/3,  c_cons_skel/2,  c_nil/0,   cons_hd/1,
591              cons_tl/1,     is_c_cons/1,     is_c_list/1,    list_elements/1,
592              list_length/1, make_list/2, update_c_cons/3.
593
594       c_cons_skel(Head::cerl(), Tail::cerl()) -> c_cons()
595
596              Creates an abstract list constructor  skeleton.  Does  not  fold
597              constant literals, i.e., the result always has type cons, repre‐
598              senting "[Head | Tail]".
599
600              This function is occasionally useful when  it  is  necessary  to
601              have  annotations  on  the  subnodes of a list constructor node,
602              even when the subnodes are constant literals. Note however  that
603              is_literal/1 will yield false and concrete/1 will fail if passed
604              the result from this function.
605
606              fold_literal/1 can be used to revert a node to  the  normal-form
607              representation.
608
609              See  also:  ann_c_cons_skel/3,  c_cons/2,  c_nil/0,  concrete/1,
610              fold_literal/1,  is_c_cons/1,  is_c_list/1,  is_literal/1,   up‐
611              date_c_cons_skel/3.
612
613       c_float(Value::float()) -> c_literal()
614
615              Creates  an  abstract floating-point literal. The lexical repre‐
616              sentation is the decimal floating-point numeral of Value.
617
618              See also: ann_c_float/2, float_lit/1, float_val/1, is_c_float/1.
619
620       c_fname(Atom::atom(), Arity::arity()) -> c_var()
621
622              Equivalent to c_var({Name, Arity}).
623
624              See    also:    ann_c_fname/3,    fname_arity/1,     fname_id/1,
625              is_c_fname/1, update_c_fname/3.
626
627       c_fun(Variables::[cerl()], Body::cerl()) -> c_fun()
628
629              Creates  an  abstract  fun-expression. If Variables is [V1, ...,
630              Vn], the result represents "fun (V1, ..., Vn) -> Body". All  the
631              Vi must have type var.
632
633              See  also:  ann_c_fun/3,  fun_arity/1,  fun_body/1,  fun_vars/1,
634              is_c_fun/1, update_c_fun/3.
635
636       c_int(Value::integer()) -> c_literal()
637
638              Creates an abstract integer literal. The lexical  representation
639              is the canonical decimal numeral of Value.
640
641              See   also:   ann_c_int/2,   c_char/1,   int_lit/1,   int_val/1,
642              is_c_int/1.
643
644       c_let(Variables::[cerl()], Argument::cerl(), Body::cerl()) -> c_let()
645
646              Creates an abstract let-expression. If Variables  is  [V1,  ...,
647              Vn],  the  result  represents  "let  <V1, ..., Vn> = Argument in
648              Body". All the Vi must have type var.
649
650              See  also:  ann_c_let/4,  is_c_let/1,  let_arg/1,   let_arity/1,
651              let_body/1, let_vars/1, update_c_let/4.
652
653       c_letrec(Defs::[{cerl(), cerl()}], Body::cerl()) -> c_letrec()
654
655              Creates  an  abstract letrec-expression. If Definitions is [{V1,
656              F1}, ..., {Vn, Fn}], the result represents "letrec V1 =  F1  ...
657              Vn  =  Fn  in  Body. All the Vi must have type var and represent
658              function names. All the Fi must have type 'fun'.
659
660              See  also:  ann_c_letrec/3,  is_c_letrec/1,  letrec_body/1,  le‐
661              trec_defs/1, letrec_vars/1, update_c_letrec/3.
662
663       c_map(Pairs::[c_map_pair()]) -> c_map()
664
665       c_map_pair(Key::cerl(), Val::cerl()) -> c_map_pair()
666
667       c_map_pair_exact(Key::cerl(), Val::cerl()) -> c_map_pair()
668
669       c_map_pattern(Pairs::[c_map_pair()]) -> c_map()
670
671       c_module(Name::cerl(),  Exports::[cerl()],  Es::[{cerl(),  cerl()}]) ->
672       c_module()
673
674              Equivalent to c_module(Name, Exports, [], Definitions).
675
676       c_module(Name::cerl(),  Exports::[cerl()],  Attrs::[{cerl(),  cerl()}],
677       Es::[{cerl(), cerl()}]) -> c_module()
678
679              Creates an abstract module definition. The result represents
680
681                  module Name [E1, ..., Ek]
682                    attributes [K1 = T1, ...,
683                                Km = Tm]
684                    V1 = F1
685                    ...
686                    Vn = Fn
687                  end
688
689              if  Exports  =  [E1, ..., Ek], Attributes = [{K1, T1}, ..., {Km,
690              Tm}], and Definitions = [{V1, F1}, ..., {Vn, Fn}].
691
692              Name and all the Ki must be atom literals, and all the  Ti  must
693              be  constant  literals. All the Vi and Ei must have type var and
694              represent function names. All the Fi must have type 'fun'.
695
696              See also:  ann_c_module/4,  ann_c_module/5,  c_atom/1,  c_fun/2,
697              c_module/3,    c_var/1,   is_literal/1,   module_attrs/1,   mod‐
698              ule_defs/1, module_exports/1, module_name/1, module_vars/1,  up‐
699              date_c_module/5.
700
701       c_nil() -> c_literal()
702
703              Creates  an abstract empty list. The result represents "[]". The
704              empty list is traditionally called "nil".
705
706              See also: ann_c_nil/1, c_cons/2, is_c_list/1.
707
708       c_primop(Name::cerl(), Arguments::[cerl()]) -> c_primop()
709
710              Creates an abstract primitive operation call.  If  Arguments  is
711              [A1, ..., An], the result represents "primop Name(A1, ..., An)".
712              Name must be an atom literal.
713
714              See also: ann_c_primop/3,  c_apply/2,  c_call/3,  is_c_primop/1,
715              primop_args/1, primop_arity/1, primop_name/1, update_c_primop/3.
716
717       c_receive(Clauses::[cerl()]) -> c_receive()
718
719              Equivalent      to      c_receive(Clauses,     c_atom(infinity),
720              c_atom(true)).
721
722              See also: c_atom/1.
723
724       c_receive(Clauses::[cerl()], Timeout::cerl(), Action::cerl()) ->  c_re‐
725       ceive()
726
727              Creates  an abstract receive-expression. If Clauses is [C1, ...,
728              Cn], the result represents "receive C1 ... Cn after  Timeout  ->
729              Action end".
730
731              See  also:  ann_c_receive/4,  c_receive/1,  is_c_receive/1,  re‐
732              ceive_action/1,   receive_clauses/1,   receive_timeout/1,    up‐
733              date_c_receive/4.
734
735       c_seq(Argument::cerl(), Body::cerl()) -> c_seq()
736
737              Creates an abstract sequencing expression. The result represents
738              "do Argument Body".
739
740              See also: ann_c_seq/3, is_c_seq/1,  seq_arg/1,  seq_body/1,  up‐
741              date_c_seq/3.
742
743       c_string(Value::string()) -> c_literal()
744
745              Creates  an  abstract  string literal. Equivalent to creating an
746              abstract list  of  the  corresponding  character  literals  (cf.
747              is_c_string/1),  but  is  typically  more efficient. The lexical
748              representation of a string is ""Chars"", where Chars  is  a  se‐
749              quence of printing characters or spaces.
750
751              See     also:     ann_c_string/2,    c_char/1,    is_c_string/1,
752              is_print_string/1, string_lit/1, string_val/1.
753
754       c_try(Expr::cerl(),  Vs::[cerl()],  Body::cerl(),  Evs::[cerl()],  Han‐
755       dler::cerl()) -> c_try()
756
757              Creates  an  abstract  try-expression. If Variables is [V1, ...,
758              Vn] and ExceptionVars is [X1, ..., Xm],  the  result  represents
759              "try  Argument  of  <V1, ..., Vn> -> Body catch <X1, ..., Xm> ->
760              Handler". All the Vi and Xi must have type var.
761
762              See  also:  ann_c_try/6,   c_catch/1,   is_c_try/1,   try_arg/1,
763              try_body/1, try_vars/1, update_c_try/6.
764
765       c_tuple(Es::[cerl()]) -> c_tuple() | c_literal()
766
767              Creates an abstract tuple. If Elements is [E1, ..., En], the re‐
768              sult represents "{E1, ..., En}". Note that if all nodes in  Ele‐
769              ments  have  type literal, or if Elements is empty, then the re‐
770              sult will also have type literal and annotations on nodes in El‐
771              ements are lost.
772
773              Recall  that  Erlang  has distinct 1-tuples, i.e., {X} is always
774              distinct from X itself.
775
776              See also: ann_c_tuple/2, c_tuple_skel/1, is_c_tuple/1, tuple_ar‐
777              ity/1, tuple_es/1, update_c_tuple/2.
778
779       c_tuple_skel(Es::[cerl()]) -> c_tuple()
780
781              Creates  an abstract tuple skeleton. Does not fold constant lit‐
782              erals, i.e., the result  always  has  type  tuple,  representing
783              "{E1, ..., En}", if Elements is [E1, ..., En].
784
785              This  function  is  occasionally  useful when it is necessary to
786              have annotations on the subnodes of a tuple node, even when  all
787              the  subnodes  are  constant literals. Note however that is_lit‐
788              eral/1 will yield false and concrete/1 will fail if  passed  the
789              result from this function.
790
791              fold_literal/1  can  be used to revert a node to the normal-form
792              representation.
793
794              See also: ann_c_tuple_skel/2, c_tuple/1,  concrete/1,  fold_lit‐
795              eral/1,  is_c_tuple/1,  is_literal/1,  tuple_es/1,  update_c_tu‐
796              ple_skel/2.
797
798       c_values(Es::[cerl()]) -> c_values()
799
800              Creates an abstract value list. If Elements is  [E1,  ...,  En],
801              the result represents "<E1, ..., En>".
802
803              See also: ann_c_values/2, is_c_values/1, update_c_values/2, val‐
804              ues_arity/1, values_es/1.
805
806       c_var(Name::var_name()) -> c_var()
807
808              Creates an abstract variable. A variable is  identified  by  its
809              name, given by the Name parameter.
810
811              If a name is given by a single atom, it should either be a "sim‐
812              ple" atom which does not need to be single-quoted in Erlang,  or
813              otherwise  its  print  name should correspond to a proper Erlang
814              variable, i.e., begin with an uppercase character or  an  under‐
815              score.  Names  on  the form {A, N} represent function name vari‐
816              ables "A/N"; these are special variables which may be bound only
817              in  the  function  definitions of a module or a letrec. They may
818              not be bound in let expressions and cannot occur in clause  pat‐
819              terns.  The atom A in a function name may be any atom; the inte‐
820              ger N must be nonnegative.  The  functions  c_fname/2  etc.  are
821              utilities for handling function name variables.
822
823              When  printing variable names, they must have the form of proper
824              Core Erlang variables and function names. E.g.,  a  name  repre‐
825              sented  by an integer such as 42 could be formatted as "_42", an
826              atom 'Xxx' simply as "Xxx", and an atom foo as "_foo".  However,
827              one  must  assure  that  any  two valid distinct names are never
828              mapped to the same strings. Tuples such as {foo, 2} representing
829              function  names  can  simply  by formatted as "'foo'/2", with no
830              risk of conflicts.
831
832              See  also:  ann_c_var/2,  c_fname/2,   c_letrec/2,   c_module/4,
833              is_c_var/1, update_c_var/2, var_name/1.
834
835       call_args(Node::c_call()) -> [cerl()]
836
837              Returns  the list of argument subtrees of an abstract inter-mod‐
838              ule call.
839
840              See also: c_call/3, call_arity/1.
841
842       call_arity(Node::c_call()) -> arity()
843
844              Returns the number of argument subtrees of  an  abstract  inter-
845              module call.
846
847              Note:  this is equivalent to length(call_args(Node)), but poten‐
848              tially more efficient.
849
850              See also: c_call/3, call_args/1.
851
852       call_module(Node::c_call()) -> cerl()
853
854              Returns the module subtree of an abstract inter-module call.
855
856              See also: c_call/3.
857
858       call_name(Node::c_call()) -> cerl()
859
860              Returns the name subtree of an abstract inter-module call.
861
862              See also: c_call/3.
863
864       case_arg(Node::c_case()) -> cerl()
865
866              Returns the argument subtree of an abstract case-expression.
867
868              See also: c_case/2.
869
870       case_arity(Node::c_case()) -> non_neg_integer()
871
872              Equivalent to clause_arity(hd(case_clauses(Node))),  but  poten‐
873              tially more efficient.
874
875              See also: c_case/2, case_clauses/1, clause_arity/1.
876
877       case_clauses(Node::c_case()) -> [cerl()]
878
879              Returns  the list of clause subtrees of an abstract case-expres‐
880              sion.
881
882              See also: c_case/2, case_arity/1.
883
884       catch_body(Node::c_catch()) -> cerl()
885
886              Returns the body subtree of an abstract catch-expression.
887
888              See also: c_catch/1.
889
890       char_lit(Node::c_literal()) -> nonempty_string()
891
892              Returns the literal string represented by an abstract character.
893              This  includes  a leading $ character. Currently, all characters
894              that are not in the set of ISO 8859-1 (Latin-1) "printing" char‐
895              acters will be escaped.
896
897              See also: c_char/1.
898
899       char_val(Node::c_literal()) -> char()
900
901              Returns the value represented by an abstract character literal.
902
903              See also: c_char/1.
904
905       clause_arity(Node::c_clause()) -> non_neg_integer()
906
907              Returns the number of pattern subtrees of an abstract clause.
908
909              Note:  this  is equivalent to length(clause_pats(Node)), but po‐
910              tentially more efficient.
911
912              See also: c_clause/3, clause_pats/1.
913
914       clause_body(Node::c_clause()) -> cerl()
915
916              Returns the body subtree of an abstract clause.
917
918              See also: c_clause/3.
919
920       clause_guard(Node::c_clause()) -> cerl()
921
922              Returns the guard subtree of an abstract clause.
923
924              See also: c_clause/3.
925
926       clause_pats(Node::c_clause()) -> [cerl()]
927
928              Returns the list of pattern subtrees of an abstract clause.
929
930              See also: c_clause/3, clause_arity/1.
931
932       clause_vars(Clause::c_clause()) -> [cerl()]
933
934              Returns the list of all abstract variables in the patterns of an
935              abstract clause. The order of listing is not defined.
936
937              See also: c_clause/3, pat_list_vars/1.
938
939       concrete(C_literal::c_literal()) -> term()
940
941              Returns  the Erlang term represented by a syntax tree. An excep‐
942              tion is thrown if Node does not represent a literal term.
943
944              Note: This is a constant time operation.
945
946              See also: abstract/1, is_literal/1.
947
948       cons_hd(C_cons::c_cons() | c_literal()) -> cerl()
949
950              Returns the head subtree of an abstract list constructor.
951
952              See also: c_cons/2.
953
954       cons_tl(C_cons::c_cons() | c_literal()) -> cerl()
955
956              Returns the tail subtree of an abstract list constructor.
957
958              Recall that the tail does not  necessarily  represent  a  proper
959              list.
960
961              See also: c_cons/2.
962
963       copy_ann(Source::cerl(), Target::cerl()) -> cerl()
964
965              Copies the list of user annotations from Source to Target.
966
967              Note:  this  is  equivalent to set_ann(Target, get_ann(Source)),
968              but potentially more efficient.
969
970              See also: get_ann/1, set_ann/2.
971
972       data_arity(C_literal::c_lct()) -> non_neg_integer()
973
974              Returns the number of subtrees of a data constructor node.  This
975              is equivalent to length(data_es(Node)), but potentially more ef‐
976              ficient.
977
978              See also: data_es/1, is_data/1.
979
980       data_es(C_literal::c_lct()) -> [cerl()]
981
982              Returns the list of subtrees of a data constructor node. If  the
983              arity of the constructor is zero, the result is the empty list.
984
985              Note:  if data_type(Node) is cons, the number of subtrees is ex‐
986              actly two. If data_type(Node) is {atomic, Value}, the number  of
987              subtrees is zero.
988
989              See also: data_arity/1, data_type/1, is_data/1, make_data/2.
990
991       data_type(C_literal::c_lct()) -> dtype()
992
993              Returns  a  type  descriptor  for  a data constructor node. (Cf.
994              is_data/1.) This is mainly useful for comparing  types  and  for
995              constructing  new  nodes  of the same type (cf. make_data/2). If
996              Node represents an integer, floating-point number, atom or empty
997              list, the result is {atomic, Value}, where Value is the value of
998              concrete(Node), otherwise the result is either cons or tuple.
999
1000              Type descriptors can be compared for equality or order  (in  the
1001              Erlang  term  order),  but  remember  that floating-point values
1002              should in general never be tested for equality.
1003
1004              See also: concrete/1, is_data/1, make_data/2, type/1.
1005
1006       float_lit(Node::c_literal()) -> string()
1007
1008              Returns the numeral string represented by a floating-point  lit‐
1009              eral node.
1010
1011              See also: c_float/1.
1012
1013       float_val(Node::c_literal()) -> float()
1014
1015              Returns the value represented by a floating-point literal node.
1016
1017              See also: c_float/1.
1018
1019       fname_arity(C_var::c_var()) -> arity()
1020
1021              Returns the arity part of an abstract function name variable.
1022
1023              See also: c_fname/2, fname_id/1.
1024
1025       fname_id(C_var::c_var()) -> atom()
1026
1027              Returns  the  identifier part of an abstract function name vari‐
1028              able.
1029
1030              See also: c_fname/2, fname_arity/1.
1031
1032       fold_literal(Node::cerl()) -> cerl()
1033
1034              Assures that literals have a compact representation. This is oc‐
1035              casionally   useful  if  c_cons_skel/2,  c_tuple_skel/1  or  un‐
1036              fold_literal/1 were used in the construction of  Node,  and  you
1037              want  to  revert to the normal "folded" representation of liter‐
1038              als. If Node represents a tuple or list  constructor,  its  ele‐
1039              ments  are  rewritten recursively, and the node is reconstructed
1040              using c_cons/2 or c_tuple/1, respectively;  otherwise,  Node  is
1041              not changed.
1042
1043              See  also:  c_cons/2,  c_cons_skel/2, c_tuple/1, c_tuple_skel/1,
1044              is_literal/1, unfold_literal/1.
1045
1046       from_records(Node::cerl()) -> cerl()
1047
1048              Translates an explicit record representation to a  corresponding
1049              abstract  syntax  tree.  The  records  are  defined  in the file
1050              "core_parse.hrl".
1051
1052              See also: to_records/1, type/1.
1053
1054       fun_arity(Node::c_fun()) -> arity()
1055
1056              Returns the number of parameter subtrees of an abstract  fun-ex‐
1057              pression.
1058
1059              Note:  this  is equivalent to length(fun_vars(Node)), but poten‐
1060              tially more efficient.
1061
1062              See also: c_fun/2, fun_vars/1.
1063
1064       fun_body(Node::c_fun()) -> cerl()
1065
1066              Returns the body subtree of an abstract fun-expression.
1067
1068              See also: c_fun/2.
1069
1070       fun_vars(Node::c_fun()) -> [cerl()]
1071
1072              Returns the list of parameter subtrees of  an  abstract  fun-ex‐
1073              pression.
1074
1075              See also: c_fun/2, fun_arity/1.
1076
1077       get_ann(Node::cerl()) -> [term()]
1078
1079              Returns  the  list  of user annotations associated with a syntax
1080              tree node. For a newly created node, this is the empty list. The
1081              annotations may be any terms.
1082
1083              See also: set_ann/2.
1084
1085       int_lit(Node::c_literal()) -> string()
1086
1087              Returns  the  numeral  string  represented by an integer literal
1088              node.
1089
1090              See also: c_int/1.
1091
1092       int_val(Node::c_literal()) -> integer()
1093
1094              Returns the value represented by an integer literal node.
1095
1096              See also: c_int/1.
1097
1098       is_c_alias(C_alias::cerl()) -> boolean()
1099
1100              Returns true if Node is an  abstract  pattern  alias,  otherwise
1101              false.
1102
1103              See also: c_alias/2.
1104
1105       is_c_apply(C_apply::cerl()) -> boolean()
1106
1107              Returns true if Node is an abstract function application, other‐
1108              wise false.
1109
1110              See also: c_apply/2.
1111
1112       is_c_atom(C_literal::cerl()) -> boolean()
1113
1114              Returns true if  Node  represents  an  atom  literal,  otherwise
1115              false.
1116
1117              See also: c_atom/1.
1118
1119       is_c_binary(C_binary::cerl()) -> boolean()
1120
1121              Returns  true  if Node is an abstract binary-template; otherwise
1122              false.
1123
1124              See also: c_binary/1.
1125
1126       is_c_bitstr(C_bitstr::cerl()) -> boolean()
1127
1128              Returns true if Node is an abstract bit-string template;  other‐
1129              wise false.
1130
1131              See also: c_bitstr/5.
1132
1133       is_c_call(C_call::cerl()) -> boolean()
1134
1135              Returns  true  if  Node is an abstract inter-module call expres‐
1136              sion; otherwise false.
1137
1138              See also: c_call/3.
1139
1140       is_c_case(C_case::cerl()) -> boolean()
1141
1142              Returns true if Node is an abstract  case-expression;  otherwise
1143              false.
1144
1145              See also: c_case/2.
1146
1147       is_c_catch(C_catch::cerl()) -> boolean()
1148
1149              Returns  true if Node is an abstract catch-expression, otherwise
1150              false.
1151
1152              See also: c_catch/1.
1153
1154       is_c_char(C_literal::c_literal()) -> boolean()
1155
1156              Returns true if Node may represent a character  literal,  other‐
1157              wise false.
1158
1159              If the local implementation of Erlang defines char() as a subset
1160              of integer(), then is_c_int(Node) will also yield true.
1161
1162              See also: c_char/1, is_print_char/1.
1163
1164       is_c_clause(C_clause::cerl()) -> boolean()
1165
1166              Returns true if Node is an abstract clause, otherwise false.
1167
1168              See also: c_clause/3.
1169
1170       is_c_cons(C_cons::cerl()) -> boolean()
1171
1172              Returns true if Node is an abstract list constructor,  otherwise
1173              false.
1174
1175       is_c_float(C_literal::cerl()) -> boolean()
1176
1177              Returns true if Node represents a floating-point literal, other‐
1178              wise false.
1179
1180              See also: c_float/1.
1181
1182       is_c_fname(C_var::cerl()) -> boolean()
1183
1184              Returns true if Node is an abstract function name variable, oth‐
1185              erwise false.
1186
1187              See also: c_fname/2, c_var/1, var_name/1.
1188
1189       is_c_fun(C_fun::cerl()) -> boolean()
1190
1191              Returns  true  if  Node is an abstract fun-expression, otherwise
1192              false.
1193
1194              See also: c_fun/2.
1195
1196       is_c_int(C_literal::cerl()) -> boolean()
1197
1198              Returns true if Node represents an  integer  literal,  otherwise
1199              false.
1200
1201              See also: c_int/1.
1202
1203       is_c_let(C_let::cerl()) -> boolean()
1204
1205              Returns  true  if  Node is an abstract let-expression, otherwise
1206              false.
1207
1208              See also: c_let/3.
1209
1210       is_c_letrec(C_letrec::cerl()) -> boolean()
1211
1212              Returns true if Node is an abstract letrec-expression, otherwise
1213              false.
1214
1215              See also: c_letrec/2.
1216
1217       is_c_list(C_cons::cerl()) -> boolean()
1218
1219              Returns  true if Node represents a proper list, otherwise false.
1220              A proper list is either the empty list [], or a cons cell  [Head
1221              | Tail], where recursively Tail is a proper list.
1222
1223              Note:  Because Node is a syntax tree, the actual run-time values
1224              corresponding to its subtrees may often  be  partially  or  com‐
1225              pletely  unknown.  Thus,  if  Node  represents e.g. "[... | Ns]"
1226              (where Ns is a variable), then the function will  return  false,
1227              because  it  is  not known whether Ns will be bound to a list at
1228              run-time. If Node instead represents e.g. "[1, 2, 3]" or  "[A  |
1229              []]", then the function will return true.
1230
1231              See also: c_cons/2, c_nil/0, list_elements/1, list_length/1.
1232
1233       is_c_map(C_map::cerl()) -> boolean()
1234
1235              Returns  true  if Node is an abstract map constructor, otherwise
1236              false.
1237
1238       is_c_map_empty(C_map::c_map() | c_literal()) -> boolean()
1239
1240       is_c_map_pattern(C_map::c_map()) -> boolean()
1241
1242       is_c_module(C_module::cerl()) -> boolean()
1243
1244              Returns true if Node is an abstract module definition, otherwise
1245              false.
1246
1247              See also: type/1.
1248
1249       is_c_nil(C_literal::cerl()) -> boolean()
1250
1251              Returns true if Node is an abstract empty list, otherwise false.
1252
1253       is_c_primop(C_primop::cerl()) -> boolean()
1254
1255              Returns  true  if  Node is an abstract primitive operation call,
1256              otherwise false.
1257
1258              See also: c_primop/2.
1259
1260       is_c_receive(C_receive::cerl()) -> boolean()
1261
1262              Returns true if Node is an abstract  receive-expression,  other‐
1263              wise false.
1264
1265              See also: c_receive/3.
1266
1267       is_c_seq(C_seq::cerl()) -> boolean()
1268
1269              Returns  true if Node is an abstract sequencing expression, oth‐
1270              erwise false.
1271
1272              See also: c_seq/2.
1273
1274       is_c_string(C_literal::cerl()) -> boolean()
1275
1276              Returns true if Node may represent a string  literal,  otherwise
1277              false.   Strings   are  defined  as  lists  of  characters;  see
1278              is_c_char/1 for details.
1279
1280              See also: c_string/1, is_c_char/1, is_print_string/1.
1281
1282       is_c_try(C_try::cerl()) -> boolean()
1283
1284              Returns true if Node is an  abstract  try-expression,  otherwise
1285              false.
1286
1287              See also: c_try/5.
1288
1289       is_c_tuple(C_tuple::cerl()) -> boolean()
1290
1291              Returns true if Node is an abstract tuple, otherwise false.
1292
1293              See also: c_tuple/1.
1294
1295       is_c_values(C_values::cerl()) -> boolean()
1296
1297              Returns true if Node is an abstract value list; otherwise false.
1298
1299              See also: c_values/1.
1300
1301       is_c_var(C_var::cerl()) -> boolean()
1302
1303              Returns true if Node is an abstract variable, otherwise false.
1304
1305              See also: c_var/1.
1306
1307       is_data(C_literal::cerl()) -> boolean()
1308
1309              Returns  true  if  Node represents a data constructor, otherwise
1310              false. Data constructors are cons cells, tuples, and atomic lit‐
1311              erals.
1312
1313              See also: data_arity/1, data_es/1, data_type/1.
1314
1315       is_leaf(Node::cerl()) -> boolean()
1316
1317              Returns  true  if Node is a leaf node, otherwise false. The cur‐
1318              rent leaf node types are literal and var.
1319
1320              Note: all literals (cf. is_literal/1) are leaf  nodes,  even  if
1321              they  represent structured (constant) values such as {foo, [bar,
1322              baz]}. Also note that variables are leaf nodes but not literals.
1323
1324              See also: is_literal/1, type/1.
1325
1326       is_literal(C_literal::cerl()) -> boolean()
1327
1328              Returns true if Node represents a literal term, otherwise false.
1329              This  function  returns  true  if  and only if the value of con‐
1330              crete(Node) is defined.
1331
1332              Note: This is a constant time operation.
1333
1334              See also: abstract/1, concrete/1, fold_literal/1.
1335
1336       is_literal_term(T::term()) -> boolean()
1337
1338              Returns true if Term can be represented as a literal,  otherwise
1339              false.  This  function  takes  time  proportional to the size of
1340              Term.
1341
1342              See also: abstract/1.
1343
1344       is_print_char(C_literal::cerl()) -> boolean()
1345
1346              Returns true if Node may represent a "printing" character,  oth‐
1347              erwise  false. (Cf. is_c_char/1.) A "printing" character has ei‐
1348              ther a given graphical representation, or a "named"  escape  se‐
1349              quence  such as "\n". Currently, only ISO 8859-1 (Latin-1) char‐
1350              acter values are recognized.
1351
1352              See also: c_char/1, is_c_char/1.
1353
1354       is_print_string(C_literal::cerl()) -> boolean()
1355
1356              Returns true if Node may represent a string  literal  containing
1357              only  "printing"  characters, otherwise false. See is_c_string/1
1358              and is_print_char/1 for  details.  Currently,  only  ISO  8859-1
1359              (Latin-1) character values are recognized.
1360
1361              See also: c_string/1, is_c_string/1, is_print_char/1.
1362
1363       let_arg(Node::c_let()) -> cerl()
1364
1365              Returns the argument subtree of an abstract let-expression.
1366
1367              See also: c_let/3.
1368
1369       let_arity(Node::c_let()) -> non_neg_integer()
1370
1371              Returns  the  number  of left-hand side variables of an abstract
1372              let-expression.
1373
1374              Note: this is equivalent to length(let_vars(Node)),  but  poten‐
1375              tially more efficient.
1376
1377              See also: c_let/3, let_vars/1.
1378
1379       let_body(Node::c_let()) -> cerl()
1380
1381              Returns the body subtree of an abstract let-expression.
1382
1383              See also: c_let/3.
1384
1385       let_vars(Node::c_let()) -> [cerl()]
1386
1387              Returns the list of left-hand side variables of an abstract let-
1388              expression.
1389
1390              See also: c_let/3, let_arity/1.
1391
1392       letrec_body(Node::c_letrec()) -> cerl()
1393
1394              Returns the body subtree of an abstract letrec-expression.
1395
1396              See also: c_letrec/2.
1397
1398       letrec_defs(Node::c_letrec()) -> [{cerl(), cerl()}]
1399
1400              Returns the list of definitions of  an  abstract  letrec-expres‐
1401              sion.  If  Node represents "letrec V1 = F1 ... Vn = Fn in Body",
1402              the returned value is [{V1, F1}, ..., {Vn, Fn}].
1403
1404              See also: c_letrec/2.
1405
1406       letrec_vars(Node::c_letrec()) -> [cerl()]
1407
1408              Returns the list of left-hand side function variable subtrees of
1409              a letrec-expression. If Node represents "letrec V1 = F1 ... Vn =
1410              Fn in Body", the returned value is [V1, ..., Vn].
1411
1412              See also: c_letrec/2.
1413
1414       list_elements(C_cons::c_cons() | c_literal()) -> [cerl()]
1415
1416              Returns the list of element subtrees of an abstract  list.  Node
1417              must  represent a proper list. E.g., if Node represents "[X1, X2
1418              | [X3, X4 | []]", then list_elements(Node) yields the list  [X1,
1419              X2, X3, X4].
1420
1421              See   also:   c_cons/2,   c_nil/0,  is_c_list/1,  list_length/1,
1422              make_list/2.
1423
1424       list_length(L::c_cons() | c_literal()) -> non_neg_integer()
1425
1426              Returns the number of element subtrees of an abstract list. Node
1427              must  represent  a  proper list. E.g., if Node represents "[X1 |
1428              [X2, X3 | [X4, X5, X6]]]", then  list_length(Node)  returns  the
1429              integer 6.
1430
1431              Note: this is equivalent to length(list_elements(Node)), but po‐
1432              tentially more efficient.
1433
1434              See also: c_cons/2, c_nil/0, is_c_list/1, list_elements/1.
1435
1436       make_data(CType::dtype(), Es::[cerl()]) -> c_lct()
1437
1438              Creates a data constructor node with the specified type and sub‐
1439              trees.  (Cf.  data_type/1.) An exception is thrown if the length
1440              of Elements is invalid for the given Type; see data_es/1 for ar‐
1441              ity constraints on constructor types.
1442
1443              See     also:     ann_make_data/3,    data_es/1,    data_type/1,
1444              make_data_skel/2, update_data/3.
1445
1446       make_data_skel(CType::dtype(), Es::[cerl()]) -> c_lct()
1447
1448              Like  make_data/2,   but   analogous   to   c_tuple_skel/1   and
1449              c_cons_skel/2.
1450
1451              See  also:  ann_make_data_skel/3, c_cons_skel/2, c_tuple_skel/1,
1452              make_data/2, update_data_skel/3.
1453
1454       make_list(List::[cerl()]) -> cerl()
1455
1456              Equivalent to make_list(List, none).
1457
1458       make_list(List::[cerl()], Tail::cerl() | none) -> cerl()
1459
1460              Creates an abstract list from the elements in List and  the  op‐
1461              tional  Tail.  If Tail is none, the result will represent a nil-
1462              terminated list, otherwise it represents "[... | Tail]".
1463
1464              See also: ann_make_list/3, c_cons/2,  c_nil/0,  list_elements/1,
1465              update_list/3.
1466
1467       make_tree(Type::ctype(), Gs::[[cerl()], ...]) -> cerl()
1468
1469              Creates  a  syntax  tree  with the given type and subtrees. Type
1470              must be a node type name (cf. type/1) that  does  not  denote  a
1471              leaf  node  type (cf. is_leaf/1). Groups must be a nonempty list
1472              of groups of syntax trees, representing the subtrees of  a  node
1473              of the given type, in left-to-right order as they would occur in
1474              the printed program text, grouped by category as  done  by  sub‐
1475              trees/1.
1476
1477              The  result  of  ann_make_tree(get_ann(Node),  type(Node),  sub‐
1478              trees(Node)) (cf. update_tree/2) represents the same source code
1479              text as the original Node, assuming that subtrees(Node) yields a
1480              nonempty list. However, it does not necessarily have  the  exact
1481              same data representation as Node.
1482
1483              See  also:  ann_make_tree/3,  is_leaf/1, subtrees/1, type/1, up‐
1484              date_tree/2.
1485
1486       map_arg(C_literal::c_map() | c_literal()) -> c_map() | c_literal()
1487
1488       map_es(C_literal::c_map() | c_literal()) -> [c_map_pair()]
1489
1490       map_pair_key(C_map_pair::c_map_pair()) -> cerl()
1491
1492       map_pair_op(C_map_pair::c_map_pair()) -> map_op()
1493
1494       map_pair_val(C_map_pair::c_map_pair()) -> cerl()
1495
1496       meta(Node::cerl()) -> cerl()
1497
1498              Creates a meta-representation of a syntax tree. The result  rep‐
1499              resents  an  Erlang  expression  "MetaTree" which, if evaluated,
1500              will yield a new syntax tree representing the same  source  code
1501              text  as  Tree  (although  the actual data representation may be
1502              different). The expression represented by MetaTree is  implemen‐
1503              tation  independent  with  regard to the data structures used by
1504              the abstract syntax tree implementation.
1505
1506              Any node in Tree whose node type is var (cf. type/1), and  whose
1507              list  of annotations (cf. get_ann/1) contains the atom meta_var,
1508              will remain unchanged in the resulting tree, except that exactly
1509              one occurrence of meta_var is removed from its annotation list.
1510
1511              The  main  use  of  the  function  meta/1 is to transform a data
1512              structure Tree, which represents a piece of program code, into a
1513              form that is representation independent when printed. E.g., sup‐
1514              pose Tree represents a variable  named  "V".  Then  (assuming  a
1515              function   print/1   for   printing  syntax  trees),  evaluating
1516              print(abstract(Tree)) - simply using abstract/1 to map  the  ac‐
1517              tual  data  structure  onto a syntax tree representation - would
1518              output a string that  might  look  something  like  "{var,  ...,
1519              'V'}", which is obviously dependent on the implementation of the
1520              abstract syntax trees. This could e.g. be useful for  caching  a
1521              syntax  tree  in  a  file. However, in some situations like in a
1522              program generator generator (with two "generator"),  it  may  be
1523              unacceptable.  Using  print(meta(Tree))  instead  would output a
1524              representation independent syntax tree generating expression; in
1525              the above case, something like "cerl:c_var('V')".
1526
1527              The  implementation  tries to generate compact code with respect
1528              to literals and lists.
1529
1530              See also: abstract/1, get_ann/1, type/1.
1531
1532       module_attrs(Node::c_module()) -> [{cerl(), cerl()}]
1533
1534              Returns the list of pairs of attribute key/value subtrees of  an
1535              abstract module definition.
1536
1537              See also: c_module/4.
1538
1539       module_defs(Node::c_module()) -> [{cerl(), cerl()}]
1540
1541              Returns  the  list of function definitions of an abstract module
1542              definition.
1543
1544              See also: c_module/4.
1545
1546       module_exports(Node::c_module()) -> [cerl()]
1547
1548              Returns the list of exports subtrees of an abstract module defi‐
1549              nition.
1550
1551              See also: c_module/4.
1552
1553       module_name(Node::c_module()) -> cerl()
1554
1555              Returns the name subtree of an abstract module definition.
1556
1557              See also: c_module/4.
1558
1559       module_vars(Node::c_module()) -> [cerl()]
1560
1561              Returns the list of left-hand side function variable subtrees of
1562              an abstract module definition.
1563
1564              See also: c_module/4.
1565
1566       pat_list_vars(Ps::[cerl()]) -> [cerl()]
1567
1568              Returns the list of all abstract variables  in  the  given  pat‐
1569              terns.  An  exception is thrown if some element in Patterns does
1570              not represent a well-formed Core Erlang clause pattern. The  or‐
1571              der of listing is not defined.
1572
1573              See also: clause_vars/1, pat_vars/1.
1574
1575       pat_vars(Node::cerl()) -> [cerl()]
1576
1577              Returns  the list of all abstract variables in a pattern. An ex‐
1578              ception is thrown if Node does not represent a well-formed  Core
1579              Erlang clause pattern. The order of listing is not defined.
1580
1581              See also: clause_vars/1, pat_list_vars/1.
1582
1583       primop_args(Node::c_primop()) -> [cerl()]
1584
1585              Returns  the  list of argument subtrees of an abstract primitive
1586              operation call.
1587
1588              See also: c_primop/2, primop_arity/1.
1589
1590       primop_arity(Node::c_primop()) -> arity()
1591
1592              Returns the number of argument subtrees of an abstract primitive
1593              operation call.
1594
1595              Note:  this  is equivalent to length(primop_args(Node)), but po‐
1596              tentially more efficient.
1597
1598              See also: c_primop/2, primop_args/1.
1599
1600       primop_name(Node::c_primop()) -> cerl()
1601
1602              Returns the name subtree  of  an  abstract  primitive  operation
1603              call.
1604
1605              See also: c_primop/2.
1606
1607       receive_action(Node::c_receive()) -> cerl()
1608
1609              Returns the action subtree of an abstract receive-expression.
1610
1611              See also: c_receive/3.
1612
1613       receive_clauses(Node::c_receive()) -> [cerl()]
1614
1615              Returns  the  list of clause subtrees of an abstract receive-ex‐
1616              pression.
1617
1618              See also: c_receive/3.
1619
1620       receive_timeout(Node::c_receive()) -> cerl()
1621
1622              Returns the timeout subtree of an abstract receive-expression.
1623
1624              See also: c_receive/3.
1625
1626       seq_arg(Node::c_seq()) -> cerl()
1627
1628              Returns the argument subtree of an abstract  sequencing  expres‐
1629              sion.
1630
1631              See also: c_seq/2.
1632
1633       seq_body(Node::c_seq()) -> cerl()
1634
1635              Returns the body subtree of an abstract sequencing expression.
1636
1637              See also: c_seq/2.
1638
1639       set_ann(Node::cerl(), List::[term()]) -> cerl()
1640
1641              Sets the list of user annotations of Node to Annotations.
1642
1643              See also: add_ann/2, copy_ann/2, get_ann/1.
1644
1645       string_lit(Node::c_literal()) -> nonempty_string()
1646
1647              Returns  the  literal  string represented by an abstract string.
1648              This includes surrounding double-quote  characters  "...".  Cur‐
1649              rently,  characters  that  are  not  in  the  set  of ISO 8859-1
1650              (Latin-1) "printing" characters will be escaped, except for spa‐
1651              ces.
1652
1653              See also: c_string/1.
1654
1655       string_val(Node::c_literal()) -> string()
1656
1657              Returns the value represented by an abstract string literal.
1658
1659              See also: c_string/1.
1660
1661       subtrees(T::cerl()) -> [[cerl()]]
1662
1663              Returns the grouped list of all subtrees of a node. If Node is a
1664              leaf node (cf. is_leaf/1), this is the empty list, otherwise the
1665              result  is  always a nonempty list, containing the lists of sub‐
1666              trees of Node, in left-to-right  order  as  they  occur  in  the
1667              printed program text, and grouped by category. Often, each group
1668              contains only a single subtree.
1669
1670              Depending on the type of Node, the size of some  groups  may  be
1671              variable  (e.g.,  the  group consisting of all the elements of a
1672              tuple), while others always contain the same number of  elements
1673              -  usually  exactly one (e.g., the group containing the argument
1674              expression of a case-expression). Note, however, that the  exact
1675              structure of the returned list (for a given node type) should in
1676              general not be depended upon,  since  it  might  be  subject  to
1677              change without notice.
1678
1679              The   function   subtrees/1   and   the   constructor  functions
1680              make_tree/2 and update_tree/2 can be a great help if  one  wants
1681              to  traverse a syntax tree, visiting all its subtrees, but treat
1682              nodes of the tree in a uniform way in most or all  cases.  Using
1683              these  functions  makes  this simple, and also assures that your
1684              code is not overly sensitive to extensions of  the  syntax  tree
1685              data type, because any node types not explicitly handled by your
1686              code can be left to a default case.
1687
1688              For example:
1689
1690                  postorder(F, Tree) ->
1691                      F(case subtrees(Tree) of
1692                          [] -> Tree;
1693                          List -> update_tree(Tree,
1694                                              [[postorder(F, Subtree)
1695                                                || Subtree <- Group]
1696                                               || Group <- List])
1697                        end).
1698
1699
1700              maps the function F on Tree and all its subtrees, doing a  post-
1701              order  traversal  of  the  syntax  tree.  (Note  the  use of up‐
1702              date_tree/2 to preserve  annotations.)  For  a  simple  function
1703              like:
1704
1705                  f(Node) ->
1706                      case type(Node) of
1707                          atom -> atom("a_" ++ atom_name(Node));
1708                          _ -> Node
1709                      end.
1710
1711
1712              the  call  postorder(fun f/1, Tree) will yield a new representa‐
1713              tion of Tree in which all atom names have been extended with the
1714              prefix  "a_",  but nothing else (including annotations) has been
1715              changed.
1716
1717              See also: is_leaf/1, make_tree/2, update_tree/2.
1718
1719       to_records(Node::cerl()) -> cerl()
1720
1721              Translates an abstract syntax tree to a  corresponding  explicit
1722              record  representation.  The  records  are  defined  in the file
1723              "cerl.hrl".
1724
1725              See also: from_records/1, type/1.
1726
1727       try_arg(Node::c_try()) -> cerl()
1728
1729              Returns the expression subtree of an abstract try-expression.
1730
1731              See also: c_try/5.
1732
1733       try_body(Node::c_try()) -> cerl()
1734
1735              Returns the success body subtree of an abstract try-expression.
1736
1737              See also: c_try/5.
1738
1739       try_evars(Node::c_try()) -> [cerl()]
1740
1741              Returns the list of exception variable subtrees of  an  abstract
1742              try-expression.
1743
1744              See also: c_try/5.
1745
1746       try_handler(Node::c_try()) -> cerl()
1747
1748              Returns  the  exception  body subtree of an abstract try-expres‐
1749              sion.
1750
1751              See also: c_try/5.
1752
1753       try_vars(Node::c_try()) -> [cerl()]
1754
1755              Returns the list of success variable  subtrees  of  an  abstract
1756              try-expression.
1757
1758              See also: c_try/5.
1759
1760       tuple_arity(C_tuple::c_tuple() | c_literal()) -> non_neg_integer()
1761
1762              Returns the number of element subtrees of an abstract tuple.
1763
1764              Note:  this  is equivalent to length(tuple_es(Node)), but poten‐
1765              tially more efficient.
1766
1767              See also: c_tuple/1, tuple_es/1.
1768
1769       tuple_es(C_tuple::c_tuple() | c_literal()) -> [cerl()]
1770
1771              Returns the list of element subtrees of an abstract tuple.
1772
1773              See also: c_tuple/1.
1774
1775       type(C_alias::cerl()) -> ctype()
1776
1777              Returns the type tag of Node. Current node types are:
1778
1779              alias apply binary bitstr call case catch clause
1780              cons fun let letrec literal map map_pair module
1781              primop receive seq try tuple values var
1782
1783
1784              Note: The name of the primary constructor function  for  a  node
1785              type  is  always  the name of the type itself, prefixed by "c_";
1786              recognizer predicates are correspondingly prefixed  by  "is_c_".
1787              Furthermore,   to  simplify  preservation  of  annotations  (cf.
1788              get_ann/1), there are analogous constructor  functions  prefixed
1789              by  "ann_c_" and "update_c_", for setting the annotation list of
1790              the new node to either a specific value or to the annotations of
1791              an existing node, respectively.
1792
1793              See  also:  abstract/1, c_alias/2, c_apply/2, c_binary/1, c_bit‐
1794              str/5,  c_call/3,  c_case/2,  c_catch/1,  c_clause/3,  c_cons/2,
1795              c_fun/2,  c_let/3,  c_letrec/2,  c_module/3,  c_primop/2,  c_re‐
1796              ceive/1,  c_seq/2,  c_try/5,  c_tuple/1,  c_values/1,   c_var/1,
1797              data_type/1,   from_records/1,  get_ann/1,  meta/1,  subtrees/1,
1798              to_records/1.
1799
1800       unfold_literal(Node::cerl()) -> cerl()
1801
1802              Assures that literals have a fully expanded  representation.  If
1803              Node  represents  a  literal tuple or list constructor, its ele‐
1804              ments are rewritten recursively, and the node  is  reconstructed
1805              using  c_cons_skel/2 or c_tuple_skel/1, respectively; otherwise,
1806              Node is not changed. The fold_literal/1 can be used to revert to
1807              the normal compact representation.
1808
1809              See  also:  c_cons/2,  c_cons_skel/2, c_tuple/1, c_tuple_skel/1,
1810              fold_literal/1, is_literal/1.
1811
1812       update_c_alias(Node::c_alias(),   Var::cerl(),   Pattern::cerl())    ->
1813       c_alias()
1814
1815              See also: c_alias/2.
1816
1817       update_c_apply(Node::c_apply(),  Operator::cerl(), Arguments::[cerl()])
1818       -> c_apply()
1819
1820              See also: c_apply/2.
1821
1822       update_c_binary(Node::c_binary(), Segments::[cerl()]) -> c_binary()
1823
1824              See also: c_binary/1.
1825
1826       update_c_bitstr(Node::c_bitstr(),     Value::cerl(),      Size::cerl(),
1827       Type::cerl(), Flags::cerl()) -> c_bitstr()
1828
1829              Equivalent  to  update_c_bitstr(Node,  Value, Size, abstract(1),
1830              Type, Flags).
1831
1832       update_c_bitstr(Node::c_bitstr(),      Val::cerl(),       Size::cerl(),
1833       Unit::cerl(), Type::cerl(), Flags::cerl()) -> c_bitstr()
1834
1835              See also: c_bitstr/5, update_c_bitstr/5.
1836
1837       update_c_call(Node::cerl(),    Module::cerl(),    Name::cerl(),   Argu‐
1838       ments::[cerl()]) -> c_call()
1839
1840              See also: c_call/3.
1841
1842       update_c_case(Node::c_case(),   Expr::cerl(),   Clauses::[cerl()])   ->
1843       c_case()
1844
1845              See also: c_case/2.
1846
1847       update_c_catch(Node::c_catch(), Body::cerl()) -> c_catch()
1848
1849              See also: c_catch/1.
1850
1851       update_c_clause(Node::c_clause(),   Patterns::[cerl()],  Guard::cerl(),
1852       Body::cerl()) -> c_clause()
1853
1854              See also: c_clause/3.
1855
1856       update_c_cons(Node::c_literal()    |    c_cons(),    C_literal::cerl(),
1857       Tail::cerl()) -> c_literal() | c_cons()
1858
1859              See also: c_cons/2.
1860
1861       update_c_cons_skel(Node::c_cons()    |    c_literal(),    Head::cerl(),
1862       Tail::cerl()) -> c_cons()
1863
1864              See also: c_cons_skel/2.
1865
1866       update_c_fname(C_var::c_var(), Atom::atom()) -> c_var()
1867
1868              Like update_c_fname/3, but takes the arity from Node.
1869
1870              See also: c_fname/2, update_c_fname/3.
1871
1872       update_c_fname(Node::c_var(), Atom::atom(), Arity::arity()) -> c_var()
1873
1874              Equivalent to update_c_var(Old, {Atom, Arity}).
1875
1876              See also: c_fname/2, update_c_fname/2.
1877
1878       update_c_fun(Node::c_fun(),   Variables::[cerl()],   Body::cerl())   ->
1879       c_fun()
1880
1881              See also: c_fun/2.
1882
1883       update_c_let(Node::c_let(),    Variables::[cerl()],   Argument::cerl(),
1884       Body::cerl()) -> c_let()
1885
1886              See also: c_let/3.
1887
1888       update_c_letrec(Node::c_letrec(),       Defs::[{cerl(),       cerl()}],
1889       Body::cerl()) -> c_letrec()
1890
1891              See also: c_letrec/2.
1892
1893       update_c_map(C_map::c_map(),  M::cerl(),  Es::[cerl()])  ->  c_map()  |
1894       c_literal()
1895
1896       update_c_map_pair(Old::c_map_pair(),      Op::map_op(),      K::cerl(),
1897       V::cerl()) -> c_map_pair()
1898
1899       update_c_module(Node::c_module(),  Name::cerl(), Exports::[cerl()], At‐
1900       trs::[{cerl(), cerl()}], Es::[{cerl(), cerl()}]) -> c_module()
1901
1902              See also: c_module/4.
1903
1904       update_c_primop(Node::cerl(),  Name::cerl(),  Arguments::[cerl()])   ->
1905       c_primop()
1906
1907              See also: c_primop/2.
1908
1909       update_c_receive(Node::c_receive(), Clauses::[cerl()], Timeout::cerl(),
1910       Action::cerl()) -> c_receive()
1911
1912              See also: c_receive/3.
1913
1914       update_c_seq(Node::c_seq(), Argument::cerl(), Body::cerl()) -> c_seq()
1915
1916              See also: c_seq/2.
1917
1918       update_c_try(Node::c_try(), Expr::cerl(),  Vs::[cerl()],  Body::cerl(),
1919       Evs::[cerl()], Handler::cerl()) -> c_try()
1920
1921              See also: c_try/5.
1922
1923       update_c_tuple(Node::c_tuple()  |  c_literal(),  Es::[cerl()]) -> c_tu‐
1924       ple() | c_literal()
1925
1926              See also: c_tuple/1.
1927
1928       update_c_tuple_skel(Old::c_tuple(), Es::[cerl()]) -> c_tuple()
1929
1930              See also: c_tuple_skel/1.
1931
1932       update_c_values(Node::c_values(), Es::[cerl()]) -> c_values()
1933
1934              See also: c_values/1.
1935
1936       update_c_var(Node::c_var(), Name::var_name()) -> c_var()
1937
1938              See also: c_var/1.
1939
1940       update_data(Node::cerl(), CType::dtype(), Es::[cerl()]) -> c_lct()
1941
1942              See also: make_data/2.
1943
1944       update_data_skel(Node::cerl(), CType::dtype(), Es::[cerl()]) -> c_lct()
1945
1946              See also: make_data_skel/2.
1947
1948       update_list(Node::cerl(), List::[cerl()]) -> cerl()
1949
1950              Equivalent to update_list(Old, List, none).
1951
1952       update_list(Node::cerl(),  List::[cerl()],  Tail::cerl()  |  none)   ->
1953       cerl()
1954
1955              See also: make_list/2, update_list/2.
1956
1957       update_tree(Node::cerl(), Gs::[[cerl()], ...]) -> cerl()
1958
1959              Creates a syntax tree with the given subtrees, and the same type
1960              and  annotations  as  the  Old  node.  This  is  equivalent   to
1961              ann_make_tree(get_ann(Node),  type(Node),  Groups),  but  poten‐
1962              tially more efficient.
1963
1964              See also: ann_make_tree/3, get_ann/1, type/1, update_tree/3.
1965
1966       update_tree(Node::cerl(), Type::ctype(), Gs::[[cerl()], ...]) -> cerl()
1967
1968              Creates a syntax tree with the given type and subtrees, and  the
1969              same  annotations  as  the  Old  node.  This  is  equivalent  to
1970              ann_make_tree(get_ann(Node), Type, Groups), but potentially more
1971              efficient.
1972
1973              See also: ann_make_tree/3, get_ann/1, update_tree/2.
1974
1975       values_arity(Node::c_values()) -> non_neg_integer()
1976
1977              Returns  the  number  of  element  subtrees of an abstract value
1978              list.
1979
1980              Note: This is equivalent to length(values_es(Node)), but  poten‐
1981              tially more efficient.
1982
1983              See also: c_values/1, values_es/1.
1984
1985       values_es(Node::c_values()) -> [cerl()]
1986
1987              Returns the list of element subtrees of an abstract value list.
1988
1989              See also: c_values/1, values_arity/1.
1990
1991       var_name(Node::c_var()) -> var_name()
1992
1993              Returns the name of an abstract variable.
1994
1995              See also: c_var/1.
1996

AUTHORS

1998       Richard Carlsson <carlsson.richard@gmail.com>
1999
2000
2001
2002                               compiler 8.2.6.3                        cerl(3)
Impressum