zig

fork of https://codeberg.org/ziglang/zig
Log | Files | Refs | README | LICENSE

commit 958f00f1c71f205ce738433d00e9da7dde060f14 (tree)
parent a795c36d7b299f8167fbeb8a650e7477b5390be8
Author: LemonBoy <thatlemon@gmail.com>
Date:   Sat,  1 Feb 2020 23:58:02 +0100

Don't generate any type info for void return types

Closely matches what the LLVM debug emitter expects, the generated DWARF
infos are now standard-compliant.

Diffstat:
Msrc/analyze.cpp | 8++++----
1 file changed, 4 insertions(+), 4 deletions(-)

diff --git a/src/analyze.cpp b/src/analyze.cpp @@ -8846,13 +8846,13 @@ static void resolve_llvm_types_fn_type(CodeGen *g, ZigType *fn_type) { ZigType *gen_return_type; if (is_async) { gen_return_type = g->builtin_types.entry_void; - param_di_types.append(get_llvm_di_type(g, gen_return_type)); + param_di_types.append(nullptr); } else if (!type_has_bits(fn_type_id->return_type)) { gen_return_type = g->builtin_types.entry_void; - param_di_types.append(get_llvm_di_type(g, gen_return_type)); + param_di_types.append(nullptr); } else if (first_arg_return) { gen_return_type = g->builtin_types.entry_void; - param_di_types.append(get_llvm_di_type(g, gen_return_type)); + param_di_types.append(nullptr); ZigType *gen_type = get_pointer_to_type(g, fn_type_id->return_type, false); gen_param_types.append(get_llvm_type(g, gen_type)); param_di_types.append(get_llvm_di_type(g, gen_type)); @@ -8955,7 +8955,7 @@ void resolve_llvm_types_fn(CodeGen *g, ZigFn *fn) { ZigList<ZigLLVMDIType *> param_di_types = {}; ZigList<LLVMTypeRef> gen_param_types = {}; // first "parameter" is return value - param_di_types.append(get_llvm_di_type(g, gen_return_type)); + param_di_types.append(nullptr); ZigType *frame_type = get_fn_frame_type(g, fn); ZigType *ptr_type = get_pointer_to_type(g, frame_type, false);