commit f313ab18aecea1ade0b6a90d671352a641ad351a (tree)
parent 6cbe589b51c9404a0f485733cbc4e3b46499d480
Author: Andrew Kelley <andrew@ziglang.org>
Date: Wed, 25 Mar 2020 12:28:41 -0400
zig cc: freestanding target implies -nostdlib
Diffstat:
1 file changed, 8 insertions(+), 6 deletions(-)
diff --git a/src/main.cpp b/src/main.cpp
@@ -455,6 +455,7 @@ static int main0(int argc, char **argv) {
CodeModel code_model = CodeModelDefault;
const char *override_soname = nullptr;
bool only_preprocess = false;
+ bool ensure_libc_on_non_freestanding = false;
ZigList<const char *> llvm_argv = {0};
llvm_argv.append("zig (LLVM option parsing)");
@@ -582,11 +583,11 @@ static int main0(int argc, char **argv) {
} else if (argc >= 2 && strcmp(argv[1], "cc") == 0) {
emit_h = false;
strip = true;
+ ensure_libc_on_non_freestanding = true;
bool c_arg = false;
Stage2ClangArgIterator it;
stage2_clang_arg_iterator(&it, argc, argv);
- bool nostdlib = false;
bool is_shared_lib = false;
ZigList<Buf *> linker_args = {};
while (it.has_next) {
@@ -645,7 +646,7 @@ static int main0(int argc, char **argv) {
want_pic = WantPICDisabled;
break;
case Stage2ClangArgNoStdLib:
- nostdlib = true;
+ ensure_libc_on_non_freestanding = false;
break;
case Stage2ClangArgShared:
is_dynamic = true;
@@ -772,10 +773,6 @@ static int main0(int argc, char **argv) {
build_mode = BuildModeSafeRelease;
}
- if (!nostdlib && !have_libc) {
- have_libc = true;
- link_libs.append("c");
- }
if (only_preprocess) {
cmd = CmdBuild;
out_type = OutTypeObj;
@@ -1216,6 +1213,11 @@ static int main0(int argc, char **argv) {
return print_error_usage(arg0);
}
+ if (!have_libc && ensure_libc_on_non_freestanding && target.os != OsFreestanding) {
+ have_libc = true;
+ link_libs.append("c");
+ }
+
Buf zig_triple_buf = BUF_INIT;
target_triple_zig(&zig_triple_buf, &target);