cTrans: simplify assign_captured_var

Reviewed By: da319

Differential Revision: D8095795

fbshipit-source-id: 1b0e2cb
master
Mehdi Bouaziz 7 years ago committed by Facebook Github Bot
parent 342af52dce
commit c9b79039f9

@ -293,7 +293,7 @@ module CTrans_funct (F : CModule_type.CFrontend) : CModule_type.CTranslation = s
let assign_captured_var loc (cvar, typ) = let assign_captured_var loc (cvar, typ) =
let id = Ident.create_fresh Ident.knormal in let id = Ident.create_fresh Ident.knormal in
let instr = Sil.Load (id, Exp.Lvar cvar, typ, loc) in let instr = Sil.Load (id, Exp.Lvar cvar, typ, loc) in
(id, instr) ((Exp.Var id, cvar, typ), instr)
let closure_trans closure_pname captured_vars context stmt_info expr_info = let closure_trans closure_pname captured_vars context stmt_info expr_info =
@ -304,10 +304,7 @@ module CTrans_funct (F : CModule_type.CFrontend) : CModule_type.CTranslation = s
let qual_type = expr_info.Clang_ast_t.ei_qual_type in let qual_type = expr_info.Clang_ast_t.ei_qual_type in
let typ = CType_decl.qual_type_to_sil_type context.tenv qual_type in let typ = CType_decl.qual_type_to_sil_type context.tenv qual_type in
let ids_instrs = List.map ~f:(assign_captured_var loc) captured_vars in let ids_instrs = List.map ~f:(assign_captured_var loc) captured_vars in
let ids, instrs = List.unzip ids_instrs in let captured_vars, instrs = List.unzip ids_instrs in
let captured_vars =
List.map2_exn ~f:(fun id (pvar, typ) -> (Exp.Var id, pvar, typ)) ids captured_vars
in
let closure = Exp.Closure {name= closure_pname; captured_vars} in let closure = Exp.Closure {name= closure_pname; captured_vars} in
mk_trans_result (closure, typ) {empty_control with instrs} mk_trans_result (closure, typ) {empty_control with instrs}
@ -2688,11 +2685,9 @@ module CTrans_funct (F : CModule_type.CFrontend) : CModule_type.CTranslation = s
in in
if is_by_ref then (trans_results_acc, (Exp.Lvar pvar, pvar, typ) :: captured_vars_acc) if is_by_ref then (trans_results_acc, (Exp.Lvar pvar, pvar, typ) :: captured_vars_acc)
else else
let id, instr = assign_captured_var loc pvar_typ in let ((exp, _, typ) as exp_pvar_typ), instr = assign_captured_var loc pvar_typ in
let trans_results = let trans_results = mk_trans_result (exp, typ) {empty_control with instrs= [instr]} in
mk_trans_result (Exp.Var id, typ) {empty_control with instrs= [instr]} (trans_results :: trans_results_acc, exp_pvar_typ :: captured_vars_acc)
in
(trans_results :: trans_results_acc, (Exp.Var id, pvar, typ) :: captured_vars_acc)
in in
let translate_captured let translate_captured
{ Clang_ast_t.lci_captured_var { Clang_ast_t.lci_captured_var

Loading…
Cancel
Save