aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniel Dunbar <daniel@zuster.org>2009-03-15 01:38:15 +0000
committerDaniel Dunbar <daniel@zuster.org>2009-03-15 01:38:15 +0000
commit8d2554a2c3201aa664cbf2108cf9d57aa0aa4b0a (patch)
treeaf1fc2ae701d972bc8034c22cf28e0ac4d73236a
parent8022fd46d45005de63306a7513aece20a1be16ed (diff)
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
-rw-r--r--include/clang/Basic/DiagnosticDriverKinds.def2
-rw-r--r--include/clang/Driver/Arg.h12
-rw-r--r--lib/Driver/Driver.cpp17
3 files changed, 24 insertions, 7 deletions
diff --git a/include/clang/Basic/DiagnosticDriverKinds.def b/include/clang/Basic/DiagnosticDriverKinds.def
index 006bd34eb6..d825f3c88a 100644
--- a/include/clang/Basic/DiagnosticDriverKinds.def
+++ b/include/clang/Basic/DiagnosticDriverKinds.def
@@ -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'")
diff --git a/include/clang/Driver/Arg.h b/include/clang/Driver/Arg.h
index a35739f298..a8c9bd2097 100644
--- a/include/clang/Driver/Arg.h
+++ b/include/clang/Driver/Arg.h
@@ -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;
diff --git a/lib/Driver/Driver.cpp b/lib/Driver/Driver.cpp
index 2aa50180bd..d3993589c3 100644
--- a/lib/Driver/Driver.cpp
+++ b/lib/Driver/Driver.cpp
@@ -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;
}