Skip to content

Commit

Permalink
Change strategy to avoid ambiguity after a return statement
Browse files Browse the repository at this point in the history
When pretty-printing, there is no ambiguity since we always have a space
after the return statement. In compact mode, use a newline instead.
  • Loading branch information
vouillon committed Oct 22, 2024
1 parent a6a78b7 commit 1b05598
Showing 1 changed file with 8 additions and 2 deletions.
10 changes: 8 additions & 2 deletions compiler/lib/js_output.ml
Original file line number Diff line number Diff line change
Expand Up @@ -1407,8 +1407,14 @@ struct
let last_semi ?(ret = false) () =
if can_omit_semi
then ()
else if ret && source_map_enabled
then PP.string f "; "
else if ret && source_map_enabled && PP.compact f
then
(* In Chrome, the debugger will stop right after a return
statement. We want a whitespace between this statement and
the next one to avoid confusing this location and the
location of the next statement. When pretty-printing, this
is already the case. In compact mode, we add a newline. *)
PP.string f ";\n"
else PP.string f ";"
in
if stop_on_statement s then output_debug_info f loc;
Expand Down

0 comments on commit 1b05598

Please sign in to comment.