diff --git a/lld/MinGW/Driver.cpp b/lld/MinGW/Driver.cpp --- a/lld/MinGW/Driver.cpp +++ b/lld/MinGW/Driver.cpp @@ -103,9 +103,9 @@ opt::InputArgList args = this->ParseArgs(vec, missingIndex, missingCount); if (missingCount) - fatal(StringRef(args.getArgString(missingIndex)) + ": missing argument"); + error(StringRef(args.getArgString(missingIndex)) + ": missing argument"); for (auto *arg : args.filtered(OPT_UNKNOWN)) - fatal("unknown argument: " + arg->getAsString(args)); + error("unknown argument: " + arg->getAsString(args)); return args; } @@ -160,9 +160,14 @@ // Convert Unix-ish command line arguments to Windows-ish ones and // then call coff::link. bool mingw::link(ArrayRef argsArr, raw_ostream &diag) { + enableColors(diag.has_colors()); + MinGWOptTable parser; opt::InputArgList args = parser.parse(argsArr.slice(1)); + if (errorCount()) + return false; + if (args.hasArg(OPT_help)) { printHelp(argsArr[0]); return true; @@ -183,8 +188,10 @@ if (args.hasArg(OPT_version)) return true; - if (!args.hasArg(OPT_INPUT) && !args.hasArg(OPT_l)) - fatal("no input files"); + if (!args.hasArg(OPT_INPUT) && !args.hasArg(OPT_l)) { + error("no input files"); + return false; + } std::vector linkArgs; auto add = [&](const Twine &s) { linkArgs.push_back(s.str()); }; @@ -290,7 +297,7 @@ else if (s == "safe" || s == "none") add("-opt:noicf"); else - fatal("unknown parameter: --icf=" + s); + error("unknown parameter: --icf=" + s); } else { add("-opt:noicf"); } @@ -306,7 +313,7 @@ else if (s == "arm64pe") add("-machine:arm64"); else - fatal("unknown parameter: -m" + s); + error("unknown parameter: -m" + s); } for (auto *a : args.filtered(OPT_mllvm)) diff --git a/lld/test/MinGW/driver.test b/lld/test/MinGW/driver.test --- a/lld/test/MinGW/driver.test +++ b/lld/test/MinGW/driver.test @@ -214,3 +214,16 @@ RUN: ld.lld -### -m i386pep foo.o -delayload user32.dll --delayload shell32.dll | FileCheck -check-prefix DELAYLOAD %s RUN: ld.lld -### -m i386pep foo.o -delayload=user32.dll --delayload=shell32.dll | FileCheck -check-prefix DELAYLOAD %s DELAYLOAD: -delayload:user32.dll -delayload:shell32.dll + + +RUN: not ld.lld -m i386pep -entry 2>&1 | FileCheck -check-prefix MISSING_ARG %s +MISSING_ARG: error: -entry: missing argument + +RUN: not ld.lld -m i386pep --foo 2>&1 | FileCheck -check-prefix UNKNOWN_ARG %s +UNKNOWN_ARG: error: unknown argument: --foo + +RUN: not ld.lld -m i386pep 2>&1 | FileCheck -check-prefix NO_INPUT_FILES %s +NO_INPUT_FILES: error: no input files + +RUN: not ld.lld -m i386pep -lno-such-library 2>&1 | FileCheck -check-prefix MISSING_LIB %s +MISSING_LIB: error: unable to find library -lno-such-library