summaryrefslogtreecommitdiffstats
path: root/clang/lib/Driver/Tools.cpp
diff options
context:
space:
mode:
authorDaniel Dunbar <daniel@zuster.org>2009-05-22 00:38:15 +0000
committerDaniel Dunbar <daniel@zuster.org>2009-05-22 00:38:15 +0000
commit58f345ceb1920725566860552b8bbbbaa92e3138 (patch)
treef065388d4b7b28f248511d035620638ed9d9fc44 /clang/lib/Driver/Tools.cpp
parent4871c4739db4a71fdbe0641ed4de5363034072ac (diff)
downloadbcm5719-llvm-58f345ceb1920725566860552b8bbbbaa92e3138.tar.gz
bcm5719-llvm-58f345ceb1920725566860552b8bbbbaa92e3138.zip
Add --analyzer-no-default-checks and --analyzer-output options.
llvm-svn: 72238
Diffstat (limited to 'clang/lib/Driver/Tools.cpp')
-rw-r--r--clang/lib/Driver/Tools.cpp32
1 files changed, 19 insertions, 13 deletions
diff --git a/clang/lib/Driver/Tools.cpp b/clang/lib/Driver/Tools.cpp
index ee6bfdaddf7..add3117a18f 100644
--- a/clang/lib/Driver/Tools.cpp
+++ b/clang/lib/Driver/Tools.cpp
@@ -230,17 +230,23 @@ void Clang::ConstructJob(Compilation &C, const JobAction &JA,
if (isa<AnalyzeJobAction>(JA)) {
// Add default argument set.
- //
- // FIXME: Move into clang?
- CmdArgs.push_back("-warn-dead-stores");
- CmdArgs.push_back("-checker-cfref");
- CmdArgs.push_back("-analyzer-eagerly-assume");
- CmdArgs.push_back("-warn-objc-methodsigs");
- // Do not enable the missing -dealloc check.
- // '-warn-objc-missing-dealloc',
- CmdArgs.push_back("-warn-objc-unused-ivars");
-
- CmdArgs.push_back("-analyzer-output=plist");
+ if (!Args.hasArg(options::OPT__analyzer_no_default_checks)) {
+ CmdArgs.push_back("-warn-dead-stores");
+ CmdArgs.push_back("-checker-cfref");
+ CmdArgs.push_back("-analyzer-eagerly-assume");
+ CmdArgs.push_back("-warn-objc-methodsigs");
+ // Do not enable the missing -dealloc check.
+ // '-warn-objc-missing-dealloc',
+ CmdArgs.push_back("-warn-objc-unused-ivars");
+ }
+
+ // Set the output format. The default is plist, for (lame) historical
+ // reasons.
+ CmdArgs.push_back("-analyzer-output");
+ if (Arg *A = Args.getLastArg(options::OPT__analyzer_output))
+ CmdArgs.push_back(A->getValue(Args));
+ else
+ CmdArgs.push_back("plist");
// Add -Xanalyzer arguments when running as analyzer.
Args.AddAllArgValues(CmdArgs, options::OPT_Xanalyzer);
@@ -329,8 +335,8 @@ void Clang::ConstructJob(Compilation &C, const JobAction &JA,
(void) Args.hasArg(options::OPT_mtune_EQ);
if (const Arg *A = Args.getLastArg(options::OPT_march_EQ)) {
- // FIXME: We made need some translation here from the options gcc
- // takes to names the LLVM backend understand?
+ // FIXME: We may need some translation here from the options gcc takes to
+ // names the LLVM backend understand?
CmdArgs.push_back("-mcpu");
CmdArgs.push_back(A->getValue(Args));
} else {
OpenPOWER on IntegriCloud