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 | b0c4df5c4df69a003f26b378eb95961bc7c486e5 (patch) | |
tree | 2366feb7fa7499a78e8a7244b6670a36077068f7 /lib/Driver/OptTable.cpp | |
parent | 5fdeae17da443c50c62f602733d06193a71b170f (diff) |
Driver: Implement 'missing argument' error.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@67490 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Driver/OptTable.cpp')
-rw-r--r-- | lib/Driver/OptTable.cpp | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/lib/Driver/OptTable.cpp b/lib/Driver/OptTable.cpp index 7b7e2a7bbc..07e3511719 100644 --- a/lib/Driver/OptTable.cpp +++ b/lib/Driver/OptTable.cpp @@ -128,21 +128,28 @@ Option *OptTable::constructOption(options::ID id) const { return Opt; } -Arg *OptTable::ParseOneArg(const ArgList &Args, unsigned &Index, - unsigned IndexEnd) const { +Arg *OptTable::ParseOneArg(const ArgList &Args, unsigned &Index) const { + unsigned Prev = Index; const char *Str = Args.getArgString(Index); // Anything that doesn't start with '-' is an input, as is '-' itself. if (Str[0] != '-' || Str[1] == '\0') return new PositionalArg(getOption(OPT_INPUT), Index++); + // FIXME: Make this fast, and avoid looking through option + // groups. Maybe we should declare them separately? for (unsigned j = OPT_UNKNOWN + 1; j < LastOption; ++j) { const char *OptName = getOptionName((options::ID) j); // Arguments are only accepted by options which prefix them. - if (memcmp(Str, OptName, strlen(OptName)) == 0) + if (memcmp(Str, OptName, strlen(OptName)) == 0) { if (Arg *A = getOption((options::ID) j)->accept(Args, Index)) return A; + + // Otherwise, see if this argument was missing values. + if (Prev != Index) + return 0; + } } return new PositionalArg(getOption(OPT_UNKNOWN), Index++); |