diff options
author | Daniel Dunbar <daniel@zuster.org> | 2008-09-12 18:10:20 +0000 |
---|---|---|
committer | Daniel Dunbar <daniel@zuster.org> | 2008-09-12 18:10:20 +0000 |
commit | 84b70f7f0f6d4c07695177620743d51075592586 (patch) | |
tree | 1d3a3a152c7783c0d5b6e4c141771327d3d2c4f8 | |
parent | ec270fb6406316c7afa6e3a1684e21b1bce4b61f (diff) | |
download | bcm5719-llvm-84b70f7f0f6d4c07695177620743d51075592586.tar.gz bcm5719-llvm-84b70f7f0f6d4c07695177620743d51075592586.zip |
Add --suppress-system-warnings (on by default, use =0 to disable)
- For investigating warnings in system headers / builtins.
- Currently also enables the behavior that allows silent redefinition
of types in system headers. Conceptually these are separate but I
didn't feel it was worth two options (or changing LangOptions).
llvm-svn: 56163
-rw-r--r-- | clang/Driver/clang.cpp | 8 | ||||
-rw-r--r-- | clang/include/clang/Basic/Diagnostic.h | 6 | ||||
-rw-r--r-- | clang/lib/Basic/Diagnostic.cpp | 4 | ||||
-rw-r--r-- | clang/lib/Sema/SemaDecl.cpp | 12 |
4 files changed, 24 insertions, 6 deletions
diff --git a/clang/Driver/clang.cpp b/clang/Driver/clang.cpp index ef12eaf2c26..0efe56a3507 100644 --- a/clang/Driver/clang.cpp +++ b/clang/Driver/clang.cpp @@ -520,6 +520,11 @@ ErrorOnExtensions("pedantic-errors", llvm::cl::desc("Issue an error on uses of GCC extensions")); static llvm::cl::opt<bool> +SuppressSystemWarnings("suppress-system-warnings", + llvm::cl::desc("Issue an error on uses of GCC extensions"), + llvm::cl::init(true)); + +static llvm::cl::opt<bool> WarnUnusedMacros("Wunused_macros", llvm::cl::desc("Warn for unused macros in the main translation unit")); @@ -547,6 +552,9 @@ static void InitializeDiagnostics(Diagnostic &Diags) { Diags.setWarnOnExtensions(WarnOnExtensions); Diags.setErrorOnExtensions(ErrorOnExtensions); + // Suppress warnings in system headers unless requested not to. + Diags.setSuppressSystemWarnings(SuppressSystemWarnings); + // Silence the "macro is not used" warning unless requested. if (!WarnUnusedMacros) Diags.setDiagnosticMapping(diag::pp_macro_not_used, diag::MAP_IGNORE); diff --git a/clang/include/clang/Basic/Diagnostic.h b/clang/include/clang/Basic/Diagnostic.h index c23abdcd0fe..8b0637f59ee 100644 --- a/clang/include/clang/Basic/Diagnostic.h +++ b/clang/include/clang/Basic/Diagnostic.h @@ -61,6 +61,7 @@ private: bool WarningsAsErrors; // Treat warnings like errors: bool WarnOnExtensions; // Enables warnings for gcc extensions: -pedantic. bool ErrorOnExtensions; // Error on extensions: -pedantic-errors. + bool SuppressSystemWarnings;// Suppress warnings in system headers. DiagnosticClient *Client; /// DiagMappings - Mapping information for diagnostics. Mapping info is @@ -110,6 +111,11 @@ public: void setErrorOnExtensions(bool Val) { ErrorOnExtensions = Val; } bool getErrorOnExtensions() const { return ErrorOnExtensions; } + /// setSuppressSystemWarnings - When set to true mask warnings that + /// come from system headers. + void setSuppressSystemWarnings(bool Val) { SuppressSystemWarnings = Val; } + bool getSuppressSystemWarnings() const { return SuppressSystemWarnings; } + /// setDiagnosticMapping - This allows the client to specify that certain /// warnings are ignored. Only NOTEs, WARNINGs, and EXTENSIONs can be mapped. void setDiagnosticMapping(diag::kind Diag, diag::Mapping Map) { diff --git a/clang/lib/Basic/Diagnostic.cpp b/clang/lib/Basic/Diagnostic.cpp index f9e1d2bda3e..0f8f314f15c 100644 --- a/clang/lib/Basic/Diagnostic.cpp +++ b/clang/lib/Basic/Diagnostic.cpp @@ -113,6 +113,7 @@ Diagnostic::Diagnostic(DiagnosticClient *client) : Client(client) { WarningsAsErrors = false; WarnOnExtensions = false; ErrorOnExtensions = false; + SuppressSystemWarnings = false; // Clear all mappings, setting them to MAP_DEFAULT. memset(DiagMappings, 0, sizeof(DiagMappings)); @@ -224,7 +225,8 @@ void Diagnostic::Report(DiagnosticClient* C, // have to check on the original DiagID here, because we also want to // ignore extensions and warnings in -Werror and -pedantic-errors modes, // which *map* warnings/extensions to errors. - if (DiagID < diag::NUM_BUILTIN_DIAGNOSTICS && + if (SuppressSystemWarnings && + DiagID < diag::NUM_BUILTIN_DIAGNOSTICS && getBuiltinDiagClass(DiagID) != ERROR && Loc.isValid() && Loc.isFileID() && Loc.isInSystemHeader()) return; diff --git a/clang/lib/Sema/SemaDecl.cpp b/clang/lib/Sema/SemaDecl.cpp index 726372356e5..2f4350766ac 100644 --- a/clang/lib/Sema/SemaDecl.cpp +++ b/clang/lib/Sema/SemaDecl.cpp @@ -276,11 +276,13 @@ TypedefDecl *Sema::MergeTypeDefDecl(TypedefDecl *New, Decl *OldD) { // *either* declaration is in a system header. The code below implements // this adhoc compatibility rule. FIXME: The following code will not // work properly when compiling ".i" files (containing preprocessed output). - SourceManager &SrcMgr = Context.getSourceManager(); - if (SrcMgr.isInSystemHeader(Old->getLocation())) - return New; - if (SrcMgr.isInSystemHeader(New->getLocation())) - return New; + if (PP.getDiagnostics().getSuppressSystemWarnings()) { + SourceManager &SrcMgr = Context.getSourceManager(); + if (SrcMgr.isInSystemHeader(Old->getLocation())) + return New; + if (SrcMgr.isInSystemHeader(New->getLocation())) + return New; + } Diag(New->getLocation(), diag::err_redefinition, New->getName()); Diag(Old->getLocation(), diag::err_previous_definition); |