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 | 2fe0997427d92388e66e7573f4b043e7ba285ef0 (patch) | |
tree | 4bd997baeb9b15f973a2b4e5b0a43e675a209697 | |
parent | f1d80f12bb49a42098dfb1966a032c0951da30f4 (diff) |
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).
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@56163 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | Driver/clang.cpp | 8 | ||||
-rw-r--r-- | include/clang/Basic/Diagnostic.h | 6 | ||||
-rw-r--r-- | lib/Basic/Diagnostic.cpp | 4 | ||||
-rw-r--r-- | lib/Sema/SemaDecl.cpp | 12 |
4 files changed, 24 insertions, 6 deletions
diff --git a/Driver/clang.cpp b/Driver/clang.cpp index ef12eaf2c2..0efe56a350 100644 --- a/Driver/clang.cpp +++ b/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/include/clang/Basic/Diagnostic.h b/include/clang/Basic/Diagnostic.h index c23abdcd0f..8b0637f59e 100644 --- a/include/clang/Basic/Diagnostic.h +++ b/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/lib/Basic/Diagnostic.cpp b/lib/Basic/Diagnostic.cpp index f9e1d2bda3..0f8f314f15 100644 --- a/lib/Basic/Diagnostic.cpp +++ b/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/lib/Sema/SemaDecl.cpp b/lib/Sema/SemaDecl.cpp index 726372356e..2f4350766a 100644 --- a/lib/Sema/SemaDecl.cpp +++ b/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); |