diff options
author | Daniel Dunbar <daniel@zuster.org> | 2011-04-21 17:32:21 +0000 |
---|---|---|
committer | Daniel Dunbar <daniel@zuster.org> | 2011-04-21 17:32:21 +0000 |
commit | 7e9293b8be1716149f2150f96e76876719f14e45 (patch) | |
tree | c1a2bbb54ace4e37dfdf930f0cb6eb2c899af68c /lib/Driver/ToolChains.cpp | |
parent | b8a9d3b8016c0b8cc58e8523de0f4766cf3fa6bf (diff) |
Driver: Improve -Xarch argument diagnostics a bit.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@129918 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Driver/ToolChains.cpp')
-rw-r--r-- | lib/Driver/ToolChains.cpp | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/lib/Driver/ToolChains.cpp b/lib/Driver/ToolChains.cpp index 02105ac184..75cb9353aa 100644 --- a/lib/Driver/ToolChains.cpp +++ b/lib/Driver/ToolChains.cpp @@ -555,9 +555,16 @@ DerivedArgList *Darwin::TranslateArgs(const DerivedArgList &Args, // driver behavior; that isn't going to work in our model. We // use isDriverOption() as an approximation, although things // like -O4 are going to slip through. - if (!XarchArg || Index > Prev + 1 || - XarchArg->getOption().isDriverOption()) { - getDriver().Diag(clang::diag::err_drv_invalid_Xarch_argument) + if (!XarchArg) { + getDriver().Diag(clang::diag::err_drv_invalid_Xarch_argument_unknown) + << A->getAsString(Args); + continue; + } else if (Index > Prev + 1) { + getDriver().Diag(clang::diag::err_drv_invalid_Xarch_argument_with_args) + << A->getAsString(Args); + continue; + } else if (XarchArg->getOption().isDriverOption()) { + getDriver().Diag(clang::diag::err_drv_invalid_Xarch_argument_isdriver) << A->getAsString(Args); continue; } |