summaryrefslogtreecommitdiff
path: root/backend/PrintCminor.ml
diff options
context:
space:
mode:
Diffstat (limited to 'backend/PrintCminor.ml')
-rw-r--r--backend/PrintCminor.ml11
1 files changed, 11 insertions, 0 deletions
diff --git a/backend/PrintCminor.ml b/backend/PrintCminor.ml
index 30884b1..110e735 100644
--- a/backend/PrintCminor.ml
+++ b/backend/PrintCminor.ml
@@ -21,6 +21,7 @@ open Datatypes
open BinPos
open Integers
open AST
+open PrintAST
open Cminor
(* Precedences and associativity -- like those of C *)
@@ -57,6 +58,7 @@ let name_of_unop = function
| Ocast16unsigned -> "int16u"
| Ocast16signed -> "int16s"
| Onegint -> "-"
+ | Oboolval -> "(_Bool)"
| Onotbool -> "!"
| Onotint -> "~"
| Onegf -> "-f"
@@ -193,6 +195,15 @@ let rec print_stmt p s =
print_expr e1
print_expr_list (true, el)
print_sig sg
+ | Sbuiltin(None, ef, el) ->
+ fprintf p "@[<hv 2>builtin %s@,(@[<hov 0>%a@])@;@]"
+ (name_of_external ef)
+ print_expr_list (true, el)
+ | Sbuiltin(Some id, ef, el) ->
+ fprintf p "@[<hv 2>%s =@ builtin %s@,(@[<hov 0>%a@]);@]@]"
+ (ident_name id)
+ (name_of_external ef)
+ print_expr_list (true, el)
| Sseq(Sskip, s2) ->
print_stmt p s2
| Sseq(s1, Sskip) ->