[clang] force node creation in switch statements

Summary:
The translation of `switch` cases needs to insert nodes around the
translation of each `case` sub-statement, so we need to force node
creation in these sub-statements so the nodes around it can be connected
to the translation of the sub-statements.

Also added more logging I found useful when debugging that.

Reviewed By: da319

Differential Revision: D24991455

fbshipit-source-id: d3a622142
master
Jules Villard 4 years ago committed by Facebook GitHub Bot
parent f3f77fa0b4
commit 2efa22073c

@ -26,7 +26,7 @@ let add switch_case = current_cases := switch_case :: !current_cases
let pp_condition fmt = function let pp_condition fmt = function
| Case stmt -> | Case stmt ->
F.fprintf fmt "case %a:" (Pp.of_string ~f:Clang_ast_j.string_of_stmt) stmt F.fprintf fmt "case %a:" (Pp.of_string ~f:Clang_ast_proj.get_stmt_kind_string) stmt
| Default -> | Default ->
F.pp_print_string fmt "default:" F.pp_print_string fmt "default:"

@ -1938,9 +1938,12 @@ module CTrans_funct (F : CModule_type.CFrontend) : CModule_type.CTranslation = s
| _ -> | _ ->
assert false assert false
in in
let body_trans_result = instruction trans_state body in L.debug Capture Verbose "translating a caseStmt@\n" ;
(let open SwitchCase in let body_trans_result = exec_with_node_creation ~f:instruction trans_state body in
add {condition= Case condition; stmt_info; root_nodes= body_trans_result.control.root_nodes}) ; L.debug Capture Verbose "result of translating a caseStmt: %a@\n" pp_control
body_trans_result.control ;
SwitchCase.add
{condition= Case condition; stmt_info; root_nodes= body_trans_result.control.root_nodes} ;
body_trans_result body_trans_result
@ -2013,7 +2016,11 @@ module CTrans_funct (F : CModule_type.CFrontend) : CModule_type.CTranslation = s
let switch_cases, (_ : trans_result) = let switch_cases, (_ : trans_result) =
SwitchCase.in_switch_body ~f:(instruction inner_trans_state) body SwitchCase.in_switch_body ~f:(instruction inner_trans_state) body
in in
let link_up_switch_cases curr_succ_nodes = function let link_up_switch_cases curr_succ_nodes case =
L.debug Capture Verbose "switch: curr_succ_nodes=[%a], linking case %a@\n"
(Pp.semicolon_seq Procdesc.Node.pp)
curr_succ_nodes SwitchCase.pp case ;
match (case : SwitchCase.t) with
| {SwitchCase.condition= Case case_condition; stmt_info; root_nodes} -> | {SwitchCase.condition= Case case_condition; stmt_info; root_nodes} ->
(* create case prune nodes, link the then branch to [root_nodes], the else branch to (* create case prune nodes, link the then branch to [root_nodes], the else branch to
[curr_succ_nodes] *) [curr_succ_nodes] *)
@ -3894,7 +3901,10 @@ module CTrans_funct (F : CModule_type.CFrontend) : CModule_type.CTranslation = s
(Pp.of_string ~f:Clang_ast_proj.get_stmt_kind_string) (Pp.of_string ~f:Clang_ast_proj.get_stmt_kind_string)
instr ) ) instr ) )
in in
L.(debug Capture Verbose) "@]" ; L.debug Capture Verbose
"@]@\nResult of translating statement '%a' (pointer= '%a')@\ncontrol=%a@\n"
(Pp.of_string ~f:Clang_ast_proj.get_stmt_kind_string)
instr pp_pointer instr pp_control trans_result.control ;
(* don't forget to reset this so we output messages for future errors too *) (* don't forget to reset this so we output messages for future errors too *)
logged_error := false ; logged_error := false ;
trans_result trans_result

@ -599,4 +599,14 @@ void binaryConditional_bad() {
int j = 42; int j = 42;
} }
X getXFromInt(int x);
void switch_with_temporary_ok() {
int x = 44;
switch (42) {
case 0:
getXFromInt(x);
};
}
} // namespace dead_stores } // namespace dead_stores

Loading…
Cancel
Save