Driver: Add OptTable::ParseOneArg.

llvm-svn: 66090
This commit is contained in:
Daniel Dunbar 2009-03-04 22:41:37 +00:00
parent 16b9fd447a
commit d9621da5ae
2 changed files with 37 additions and 0 deletions

View File

@ -24,6 +24,8 @@ namespace options {
};
}
class Arg;
class ArgList;
class Option;
/// OptTable - Provide access to the Option info table.
@ -50,6 +52,18 @@ namespace options {
/// getOption - Get the given \arg id's Option instance, lazily
/// creating it if necessary.
const Option *getOption(options::ID id) const;
/// parseOneArg - Parse a single argument; returning the new
/// argument and updating Index.
///
/// \param [in] [out] Index - The current parsing position in the
/// argument string list; on return this will be the index of the
/// next option to parse.
///
/// \param IndexEnd - The last argument string index to consider
/// when parsing.
Arg *ParseOneArg(const ArgList &Args, unsigned &Index,
unsigned IndexEnd) const;
};
}
}

View File

@ -9,6 +9,8 @@
#include "clang/Driver/Options.h"
#include "clang/Driver/Arg.h"
#include "clang/Driver/ArgList.h"
#include "clang/Driver/Option.h"
#include <cassert>
@ -115,3 +117,24 @@ Option *OptTable::constructOption(options::ID id) const {
return Opt;
}
Arg *OptTable::ParseOneArg(const ArgList &Args, unsigned &Index,
unsigned IndexEnd) const {
const char *Str = Args.getArgString(Index);
// Anything that doesn't start with '-' is an input.
if (Str[0] != '-')
return new PositionalArg(getOption(InputOpt), Index++);
for (unsigned j = UnknownOpt + 1; j < getNumOptions(); ++j) {
const char *OptName = getOptionName((options::ID) (j + 1));
// Arguments are only accepted by options which prefix them.
if (memcmp(Str, OptName, strlen(OptName)) == 0)
if (Arg *A = getOption((options::ID) (j + 1))->accept(Args, Index))
return A;
}
return new PositionalArg(getOption(UnknownOpt), Index++);
}