зеркало из https://github.com/microsoft/clang-1.git
Driver: Start warning about unused arguments.
- This has a number of current flaws, enabling now to flush out problems while bringing up other parts. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@67015 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Родитель
8022fd46d4
Коммит
8d2554a2c3
|
@ -31,3 +31,5 @@ DIAG(err_drv_use_of_Z_option, ERROR,
|
|||
|
||||
DIAG(warn_drv_input_file_unused, WARNING,
|
||||
"%0: '%1' input file unused when '%2' is present")
|
||||
DIAG(warn_drv_unused_argument, WARNING,
|
||||
"argument unused during compilatin: '%0'")
|
||||
|
|
|
@ -72,11 +72,7 @@ namespace driver {
|
|||
|
||||
unsigned getIndex() const { return Index; }
|
||||
|
||||
virtual unsigned getNumValues() const = 0;
|
||||
virtual const char *getValue(const ArgList &Args, unsigned N=0) const = 0;
|
||||
|
||||
/// render - Append the argument onto the given array as strings.
|
||||
virtual void render(const ArgList &Args, ArgStringList &Output) const = 0;
|
||||
bool isClaimed() const { return Claimed; }
|
||||
|
||||
/// claim - Set the Arg claimed bit.
|
||||
|
||||
|
@ -84,6 +80,12 @@ namespace driver {
|
|||
// in the original argument; not the derived one.
|
||||
void claim() { Claimed = true; }
|
||||
|
||||
virtual unsigned getNumValues() const = 0;
|
||||
virtual const char *getValue(const ArgList &Args, unsigned N=0) const = 0;
|
||||
|
||||
/// render - Append the argument onto the given array as strings.
|
||||
virtual void render(const ArgList &Args, ArgStringList &Output) const = 0;
|
||||
|
||||
static bool classof(const Arg *) { return true; }
|
||||
|
||||
void dump() const;
|
||||
|
|
|
@ -171,7 +171,21 @@ Compilation *Driver::BuildCompilation(int argc, const char **argv) {
|
|||
return 0;
|
||||
}
|
||||
|
||||
return BuildJobs(*Args, Actions);
|
||||
Compilation *C = BuildJobs(*Args, Actions);
|
||||
|
||||
// If there were no errors, warn about any unused arguments.
|
||||
for (ArgList::iterator it = Args->begin(), ie = Args->end(); it != ie; ++it) {
|
||||
Arg *A = *it;
|
||||
|
||||
// FIXME: It would be nice to be able to send the argument to the
|
||||
// Diagnostic, so that extra values, position, and so on could be
|
||||
// printed.
|
||||
if (!A->isClaimed())
|
||||
Diag(clang::diag::warn_drv_unused_argument)
|
||||
<< A->getOption().getName();
|
||||
}
|
||||
|
||||
return C;
|
||||
}
|
||||
|
||||
void Driver::PrintOptions(const ArgList &Args) const {
|
||||
|
@ -563,7 +577,6 @@ Action *Driver::ConstructPhaseAction(const ArgList &Args, phases::ID Phase,
|
|||
|
||||
Compilation *Driver::BuildJobs(const ArgList &Args,
|
||||
const ActionList &Actions) const {
|
||||
assert(0 && "FIXME: Implement");
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
|
Загрузка…
Ссылка в новой задаче