summaryrefslogtreecommitdiff
path: root/cparser/Transform.mli
blob: 718a2f9c11cba547d4637e12363d533edcffc3a1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
(* *********************************************************************)
(*                                                                     *)
(*              The Compcert verified compiler                         *)
(*                                                                     *)
(*          Xavier Leroy, INRIA Paris-Rocquencourt                     *)
(*                                                                     *)
(*  Copyright Institut National de Recherche en Informatique et en     *)
(*  Automatique.  All rights reserved.  This file is distributed       *)
(*  under the terms of the GNU General Public License as published by  *)
(*  the Free Software Foundation, either version 2 of the License, or  *)
(*  (at your option) any later version.  This file is also distributed *)
(*  under the terms of the INRIA Non-Commercial License Agreement.     *)
(*                                                                     *)
(* *********************************************************************)

(** Creation of fresh temporary variables. *)
val reset_temps : unit -> unit
val get_temps : unit -> C.decl list
val new_temp_var : ?name:string -> C.typ -> C.ident
val new_temp : ?name:string -> C.typ -> C.exp
val mk_temp : Env.t -> ?name:string -> C.typ -> C.exp

(** Avoiding repeated evaluation of a l-value *)

val bind_lvalue: Env.t -> C.exp -> (C.exp -> C.exp) -> C.exp

(* Most transformations over expressions can be optimized if the
   value of the expression is not needed and it is evaluated only
   for its side-effects.  The type [context] records whether
   we are in a side-effects-only position ([Effects]) or not ([Val]). *)

type context = Val | Effects

(** Expansion of assignment expressions *)
val op_for_assignop : C.binary_operator -> C.binary_operator
val op_for_incr_decr : C.unary_operator -> C.binary_operator
val assignop_for_incr_decr : C.unary_operator -> C.binary_operator
val expand_assign :
  write:(C.exp -> C.exp -> C.exp) ->
  Env.t -> context -> C.exp -> C.exp -> C.exp
val expand_assignop :
  read:(C.exp -> C.exp) -> write:(C.exp -> C.exp -> C.exp) ->
  Env.t -> context -> C.binary_operator -> C.exp -> C.exp -> C.typ -> C.exp
val expand_preincrdecr :
  read:(C.exp -> C.exp) -> write:(C.exp -> C.exp -> C.exp) ->
  Env.t -> context -> C.unary_operator -> C.exp -> C.exp
val expand_postincrdecr :
  read:(C.exp -> C.exp) -> write:(C.exp -> C.exp -> C.exp) ->
  Env.t -> context -> C.unary_operator -> C.exp -> C.exp

(** Generic transformation of a statement *)

val stmt : (C.location -> Env.t -> context -> C.exp -> C.exp) ->
           Env.t -> C.stmt -> C.stmt

(** Generic transformation of a function definition *)

val fundef : (Env.t -> C.stmt -> C.stmt) -> Env.t -> C.fundef -> C.fundef

(** Generic transformation of a program *)

val program :
  ?decl:(Env.t -> C.decl -> C.decl) ->
  ?fundef:(Env.t -> C.fundef -> C.fundef) ->
  ?composite:(Env.t -> C.struct_or_union -> 
                C.ident -> C.attributes -> C.field list -> 
                  C.attributes * C.field list) ->
  ?typedef:(Env.t -> C.ident -> C.typ -> C.typ) ->
  ?enum:(Env.t -> C.ident -> C.attributes -> C.enumerator list -> 
                  C.attributes * C.enumerator list) ->
  ?pragma:(Env.t -> string -> string) ->
  C.program ->
  C.program