Skip to content

Commit

Permalink
Emit try_table instruction
Browse files Browse the repository at this point in the history
  • Loading branch information
vouillon committed Jan 13, 2025
1 parent bb3b65c commit 2cbb817
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 15 deletions.
11 changes: 6 additions & 5 deletions compiler/lib-wasm/wasm_output.ml
Original file line number Diff line number Diff line change
Expand Up @@ -648,15 +648,16 @@ end = struct
output_byte ch 0x0B
| Try (typ, l, catches) ->
Feature.require exception_handling;
output_byte ch 0x06;
output_byte ch 0x1f;
output_blocktype st.type_names ch typ;
List.iter ~f:(fun i' -> output_instruction st ch i') l;
output_uint ch (List.length catches);
List.iter
~f:(fun (tag, l, ty) ->
output_byte ch 0x07;
~f:(fun (tag, l, _) ->
output_byte ch 0x00;
output_uint ch (Hashtbl.find st.tag_names tag);
output_instruction st ch (Br (l + 1, Some (Pop ty))))
output_uint ch l)
catches;
List.iter ~f:(fun i' -> output_instruction st ch i') l;
output_byte ch 0X0B

and output_instruction st ch i =
Expand Down
16 changes: 6 additions & 10 deletions compiler/lib-wasm/wat_output.ml
Original file line number Diff line number Diff line change
Expand Up @@ -445,17 +445,13 @@ let expression_or_instructions ctx st in_function =
]
| Try (ty, body, catches) ->
[ List
(Atom "try"
(Atom "try_table"
:: (block_type st ty
@ List (Atom "do" :: instructions body)
:: List.map
~f:(fun (tag, i, ty) ->
List
(Atom "catch"
:: index st.tag_names tag
:: (instruction (Wasm_ast.Event Code_generation.hidden_location)
@ instruction (Wasm_ast.Br (i + 1, Some (Pop ty))))))
catches))
@ List.map
~f:(fun (tag, i, _ty) ->
List [ Atom "catch"; index st.tag_names tag; Atom (string_of_int i) ])
catches
@ instructions body))
]
and instruction i =
match i with
Expand Down

0 comments on commit 2cbb817

Please sign in to comment.