diff options
author | Bernhard Schommer <bernhardschommer@gmail.com> | 2018-01-05 16:51:32 +0100 |
---|---|---|
committer | Bernhard Schommer <bernhardschommer@gmail.com> | 2018-01-05 16:51:32 +0100 |
commit | 94c18ad233b9e16ee9263ba8b717630b4adbf91e (patch) | |
tree | f2e10ea75c79137c78021bc01dca112e9b430c7f /arm | |
parent | 91601d4bd435efdee12e08188573f0e9bd910a8a (diff) | |
download | compcert-kvx-94c18ad233b9e16ee9263ba8b717630b4adbf91e.tar.gz compcert-kvx-94c18ad233b9e16ee9263ba8b717630b4adbf91e.zip |
Change AsmToJson to be similar to other printers.
Diffstat (limited to 'arm')
-rw-r--r-- | arm/AsmToJSON.ml | 14 | ||||
-rw-r--r-- | arm/AsmToJSON.mli | 8 |
2 files changed, 17 insertions, 5 deletions
diff --git a/arm/AsmToJSON.ml b/arm/AsmToJSON.ml index 85ef0603..c11162d6 100644 --- a/arm/AsmToJSON.ml +++ b/arm/AsmToJSON.ml @@ -302,9 +302,17 @@ let pp_instructions pp ic = in pp_jarray instruction pp ic -let pp_program pp prog = - reset_id (); - JsonAST.pp_program pp pp_instructions prog +let destination : string option ref = ref None +let sdump_folder : string ref = ref "" + +let print_if prog sourcename = + match !destination with + | None -> () + | Some f -> + let f = Filename.concat !sdump_folder f in + let oc = open_out f in + JsonAST.pp_ast (Format.formatter_of_out_channel oc) pp_instructions prog sourcename; + close_out oc let pp_mnemonics pp = JsonAST.pp_mnemonics pp mnemonic_names diff --git a/arm/AsmToJSON.mli b/arm/AsmToJSON.mli index 058a4e83..52c055c4 100644 --- a/arm/AsmToJSON.mli +++ b/arm/AsmToJSON.mli @@ -10,6 +10,10 @@ (* *) (* *********************************************************************) -val pp_program: Format.formatter -> (Asm.coq_function AST.fundef, 'a) AST.program -> unit - val pp_mnemonics: Format.formatter -> unit + +val print_if: (Asm.coq_function AST.fundef, 'a) AST.program -> string -> unit + +val destination: string option ref + +val sdump_folder : string ref |