diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2011-07-17 15:40:56 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2011-07-17 15:40:56 +0000 | 
| commit | 180abc3db9ae3b4fc63cd65b15697e6ffcc8a657 (patch) | |
| tree | 2097d084eb235c0b12c0bff3445f4ec7bbaa8a12 /include/clang/Lex/PPCallbacks.h | |
| parent | 29cafa66ad3878dbb9f82615f19fa0bded2e443c (diff) | |
Diffstat (limited to 'include/clang/Lex/PPCallbacks.h')
| -rw-r--r-- | include/clang/Lex/PPCallbacks.h | 37 | 
1 files changed, 37 insertions, 0 deletions
| diff --git a/include/clang/Lex/PPCallbacks.h b/include/clang/Lex/PPCallbacks.h index fd07a29f8e9d..a7948153a728 100644 --- a/include/clang/Lex/PPCallbacks.h +++ b/include/clang/Lex/PPCallbacks.h @@ -16,6 +16,7 @@  #include "clang/Lex/DirectoryLookup.h"  #include "clang/Basic/SourceLocation.h" +#include "clang/Basic/DiagnosticIDs.h"  #include "llvm/ADT/StringRef.h"  #include <string> @@ -124,6 +125,24 @@ public:    virtual void PragmaMessage(SourceLocation Loc, llvm::StringRef Str) {    } +  /// PragmaDiagnosticPush - This callback is invoked when a +  /// #pragma gcc dianostic push directive is read. +  virtual void PragmaDiagnosticPush(SourceLocation Loc, +                                    llvm::StringRef Namespace) { +  } + +  /// PragmaDiagnosticPop - This callback is invoked when a +  /// #pragma gcc dianostic pop directive is read. +  virtual void PragmaDiagnosticPop(SourceLocation Loc, +                                   llvm::StringRef Namespace) { +  } + +  /// PragmaDiagnostic - This callback is invoked when a +  /// #pragma gcc dianostic directive is read. +  virtual void PragmaDiagnostic(SourceLocation Loc, llvm::StringRef Namespace, +                                diag::Mapping mapping, llvm::StringRef Str) { +  } +    /// MacroExpands - This is called by    /// Preprocessor::HandleMacroExpandedIdentifier when a macro invocation is    /// found. @@ -232,6 +251,24 @@ public:      Second->PragmaMessage(Loc, Str);    } +  virtual void PragmaDiagnosticPush(SourceLocation Loc, +                                    llvm::StringRef Namespace) { +    First->PragmaDiagnosticPush(Loc, Namespace); +    Second->PragmaDiagnosticPush(Loc, Namespace); +  } + +  virtual void PragmaDiagnosticPop(SourceLocation Loc, +                                    llvm::StringRef Namespace) { +    First->PragmaDiagnosticPop(Loc, Namespace); +    Second->PragmaDiagnosticPop(Loc, Namespace); +  } + +  virtual void PragmaDiagnostic(SourceLocation Loc, llvm::StringRef Namespace, +                                diag::Mapping mapping, llvm::StringRef Str) { +    First->PragmaDiagnostic(Loc, Namespace, mapping, Str); +    Second->PragmaDiagnostic(Loc, Namespace, mapping, Str); +  } +    virtual void MacroExpands(const Token &MacroNameTok, const MacroInfo* MI) {      First->MacroExpands(MacroNameTok, MI);      Second->MacroExpands(MacroNameTok, MI); | 
