diff options
author | Daniel Dunbar <daniel@zuster.org> | 2009-03-22 23:26:43 +0000 |
---|---|---|
committer | Daniel Dunbar <daniel@zuster.org> | 2009-03-22 23:26:43 +0000 |
commit | d8500f3b0f54c6b29640e524c6b660f20fc7cf3f (patch) | |
tree | 40c42be72c976d91e2086592094a37f2461372ee /clang/lib/Driver/Driver.cpp | |
parent | 7fa3faa4176915b068301be677c983cc5cc80cad (diff) | |
download | bcm5719-llvm-d8500f3b0f54c6b29640e524c6b660f20fc7cf3f.tar.gz bcm5719-llvm-d8500f3b0f54c6b29640e524c6b660f20fc7cf3f.zip |
Driver: Implement 'missing argument' error.
llvm-svn: 67490
Diffstat (limited to 'clang/lib/Driver/Driver.cpp')
-rw-r--r-- | clang/lib/Driver/Driver.cpp | 23 |
1 files changed, 14 insertions, 9 deletions
diff --git a/clang/lib/Driver/Driver.cpp b/clang/lib/Driver/Driver.cpp index 40c6e500636..db084262e9c 100644 --- a/clang/lib/Driver/Driver.cpp +++ b/clang/lib/Driver/Driver.cpp @@ -72,18 +72,23 @@ ArgList *Driver::ParseArgStrings(const char **ArgBegin, const char **ArgEnd) { } unsigned Prev = Index; - Arg *A = getOpts().ParseOneArg(*Args, Index, End); - if (A) { - if (A->getOption().isUnsupported()) { - Diag(clang::diag::err_drv_unsupported_opt) << A->getAsString(*Args); - continue; - } + Arg *A = getOpts().ParseOneArg(*Args, Index); + assert(Index > Prev && "Parser failed to consume argument."); - Args->append(A); + // Check for missing argument error. + if (!A) { + assert(Index >= End && "Unexpected parser error."); + Diag(clang::diag::err_drv_missing_argument) + << Args->getArgString(Prev) + << (Index - Prev - 1); + break; } - assert(Index > Prev && "Parser failed to consume argument."); - (void) Prev; + if (A->getOption().isUnsupported()) { + Diag(clang::diag::err_drv_unsupported_opt) << A->getAsString(*Args); + continue; + } + Args->append(A); } return Args; |