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
|
(****************************************************************************)
(* the diy toolsuite *)
(* *)
(* Jade Alglave, University College London, UK. *)
(* Luc Maranget, INRIA Paris-Rocquencourt, France. *)
(* *)
(* Copyright 2014-present Institut National de Recherche en Informatique et *)
(* en Automatique and the authors. All rights reserved. *)
(* *)
(* This software is governed by the CeCILL-B license under French law and *)
(* abiding by the rules of distribution of free software. You can use, *)
(* modify and/ or redistribute the software under the terms of the CeCILL-B *)
(* license as circulated by CEA, CNRS and INRIA at the following URL *)
(* "http://www.cecill.info". We also give a copy in LICENSE.txt. *)
(****************************************************************************)
type code = string CAst.t
let dump_prog preserve_hashes cfun =
let f = function
| CAst.Test { CAst.params; body; proc = i } ->
let string_of_ty ty = CType.dump ty ^ "*" in
let f {CAst.param_ty; param_name} =
Printf.sprintf "%s %s" (string_of_ty param_ty) param_name
in
let params = String.concat ", " (List.map f params) in
if preserve_hashes then
Printf.sprintf "P%i(%s) {\n%s\n}\n" i params body
else
(* void return type make this valid C, the parser accepts it*)
Printf.sprintf "void P%i(%s) {\n%s\n}\n" i params body
| CAst.Global x -> Printf.sprintf "{%s}\n\n" x
in
[f cfun]
let dump_prog_lines prog =
let pp = List.map (dump_prog true) prog in
let pp = List.concat pp in
List.map (Printf.sprintf "%s\n") pp
let print_prog chan prog =
let pp = dump_prog_lines prog in
List.iter (Printf.fprintf chan "%s") pp
|