- //===--- PPCallbacks.h - Callbacks for Preprocessor actions -----*- C++ -*-===// 
- // 
- // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 
- // See https://llvm.org/LICENSE.txt for license information. 
- // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 
- // 
- //===----------------------------------------------------------------------===// 
- /// 
- /// \file 
- /// Defines the PPCallbacks interface. 
- /// 
- //===----------------------------------------------------------------------===// 
-   
- #ifndef LLVM_CLANG_LEX_PPCALLBACKS_H 
- #define LLVM_CLANG_LEX_PPCALLBACKS_H 
-   
- #include "clang/Basic/DiagnosticIDs.h" 
- #include "clang/Basic/SourceLocation.h" 
- #include "clang/Basic/SourceManager.h" 
- #include "clang/Lex/ModuleLoader.h" 
- #include "clang/Lex/Pragma.h" 
- #include "llvm/ADT/StringRef.h" 
-   
- namespace clang { 
-   class Token; 
-   class IdentifierInfo; 
-   class MacroDefinition; 
-   class MacroDirective; 
-   class MacroArgs; 
-   
- /// This interface provides a way to observe the actions of the 
- /// preprocessor as it does its thing. 
- /// 
- /// Clients can define their hooks here to implement preprocessor level tools. 
- class PPCallbacks { 
- public: 
-   virtual ~PPCallbacks(); 
-   
-   enum FileChangeReason { 
-     EnterFile, ExitFile, SystemHeaderPragma, RenameFile 
-   }; 
-   
-   /// Callback invoked whenever a source file is entered or exited. 
-   /// 
-   /// \param Loc Indicates the new location. 
-   /// \param PrevFID the file that was exited if \p Reason is ExitFile or the 
-   /// the file before the new one entered for \p Reason EnterFile. 
-   virtual void FileChanged(SourceLocation Loc, FileChangeReason Reason, 
-                            SrcMgr::CharacteristicKind FileType, 
-                            FileID PrevFID = FileID()) { 
-   } 
-   
-   enum class LexedFileChangeReason { EnterFile, ExitFile }; 
-   
-   /// Callback invoked whenever the \p Lexer moves to a different file for 
-   /// lexing. Unlike \p FileChanged line number directives and other related 
-   /// pragmas do not trigger callbacks to \p LexedFileChanged. 
-   /// 
-   /// \param FID The \p FileID that the \p Lexer moved to. 
-   /// 
-   /// \param Reason Whether the \p Lexer entered a new file or exited one. 
-   /// 
-   /// \param FileType The \p CharacteristicKind of the file the \p Lexer moved 
-   /// to. 
-   /// 
-   /// \param PrevFID The \p FileID the \p Lexer was using before the change. 
-   /// 
-   /// \param Loc The location where the \p Lexer entered a new file from or the 
-   /// location that the \p Lexer moved into after exiting a file. 
-   virtual void LexedFileChanged(FileID FID, LexedFileChangeReason Reason, 
-                                 SrcMgr::CharacteristicKind FileType, 
-                                 FileID PrevFID, SourceLocation Loc) {} 
-   
-   /// Callback invoked whenever a source file is skipped as the result 
-   /// of header guard optimization. 
-   /// 
-   /// \param SkippedFile The file that is skipped instead of entering \#include 
-   /// 
-   /// \param FilenameTok The file name token in \#include "FileName" directive 
-   /// or macro expanded file name token from \#include MACRO(PARAMS) directive. 
-   /// Note that FilenameTok contains corresponding quotes/angles symbols. 
-   virtual void FileSkipped(const FileEntryRef &SkippedFile, 
-                            const Token &FilenameTok, 
-                            SrcMgr::CharacteristicKind FileType) {} 
-   
-   /// Callback invoked whenever the preprocessor cannot find a file for an 
-   /// inclusion directive. 
-   /// 
-   /// \param FileName The name of the file being included, as written in the 
-   /// source code. 
-   /// 
-   /// \returns true to indicate that the preprocessor should skip this file 
-   /// and not issue any diagnostic. 
-   virtual bool FileNotFound(StringRef FileName) { return false; } 
-   
-   /// Callback invoked whenever an inclusion directive of 
-   /// any kind (\c \#include, \c \#import, etc.) has been processed, regardless 
-   /// of whether the inclusion will actually result in an inclusion. 
-   /// 
-   /// \param HashLoc The location of the '#' that starts the inclusion 
-   /// directive. 
-   /// 
-   /// \param IncludeTok The token that indicates the kind of inclusion 
-   /// directive, e.g., 'include' or 'import'. 
-   /// 
-   /// \param FileName The name of the file being included, as written in the 
-   /// source code. 
-   /// 
-   /// \param IsAngled Whether the file name was enclosed in angle brackets; 
-   /// otherwise, it was enclosed in quotes. 
-   /// 
-   /// \param FilenameRange The character range of the quotes or angle brackets 
-   /// for the written file name. 
-   /// 
-   /// \param File The actual file that may be included by this inclusion 
-   /// directive. 
-   /// 
-   /// \param SearchPath Contains the search path which was used to find the file 
-   /// in the file system. If the file was found via an absolute include path, 
-   /// SearchPath will be empty. For framework includes, the SearchPath and 
-   /// RelativePath will be split up. For example, if an include of "Some/Some.h" 
-   /// is found via the framework path 
-   /// "path/to/Frameworks/Some.framework/Headers/Some.h", SearchPath will be 
-   /// "path/to/Frameworks/Some.framework/Headers" and RelativePath will be 
-   /// "Some.h". 
-   /// 
-   /// \param RelativePath The path relative to SearchPath, at which the include 
-   /// file was found. This is equal to FileName except for framework includes. 
-   /// 
-   /// \param Imported The module, whenever an inclusion directive was 
-   /// automatically turned into a module import or null otherwise. 
-   /// 
-   /// \param FileType The characteristic kind, indicates whether a file or 
-   /// directory holds normal user code, system code, or system code which is 
-   /// implicitly 'extern "C"' in C++ mode. 
-   /// 
-   virtual void InclusionDirective(SourceLocation HashLoc, 
-                                   const Token &IncludeTok, StringRef FileName, 
-                                   bool IsAngled, CharSourceRange FilenameRange, 
-                                   OptionalFileEntryRef File, 
-                                   StringRef SearchPath, StringRef RelativePath, 
-                                   const Module *Imported, 
-                                   SrcMgr::CharacteristicKind FileType) {} 
-   
-   /// Callback invoked whenever a submodule was entered. 
-   /// 
-   /// \param M The submodule we have entered. 
-   /// 
-   /// \param ImportLoc The location of import directive token. 
-   /// 
-   /// \param ForPragma If entering from pragma directive. 
-   /// 
-   virtual void EnteredSubmodule(Module *M, SourceLocation ImportLoc, 
-                                 bool ForPragma) { } 
-   
-   /// Callback invoked whenever a submodule was left. 
-   /// 
-   /// \param M The submodule we have left. 
-   /// 
-   /// \param ImportLoc The location of import directive token. 
-   /// 
-   /// \param ForPragma If entering from pragma directive. 
-   /// 
-   virtual void LeftSubmodule(Module *M, SourceLocation ImportLoc, 
-                              bool ForPragma) { } 
-   
-   /// Callback invoked whenever there was an explicit module-import 
-   /// syntax. 
-   /// 
-   /// \param ImportLoc The location of import directive token. 
-   /// 
-   /// \param Path The identifiers (and their locations) of the module 
-   /// "path", e.g., "std.vector" would be split into "std" and "vector". 
-   /// 
-   /// \param Imported The imported module; can be null if importing failed. 
-   /// 
-   virtual void moduleImport(SourceLocation ImportLoc, 
-                             ModuleIdPath Path, 
-                             const Module *Imported) { 
-   } 
-   
-   /// Callback invoked when the end of the main file is reached. 
-   /// 
-   /// No subsequent callbacks will be made. 
-   virtual void EndOfMainFile() { 
-   } 
-   
-   /// Callback invoked when a \#ident or \#sccs directive is read. 
-   /// \param Loc The location of the directive. 
-   /// \param str The text of the directive. 
-   /// 
-   virtual void Ident(SourceLocation Loc, StringRef str) { 
-   } 
-   
-   /// Callback invoked when start reading any pragma directive. 
-   virtual void PragmaDirective(SourceLocation Loc, 
-                                PragmaIntroducerKind Introducer) { 
-   } 
-   
-   /// Callback invoked when a \#pragma comment directive is read. 
-   virtual void PragmaComment(SourceLocation Loc, const IdentifierInfo *Kind, 
-                              StringRef Str) { 
-   } 
-   
-   /// Callback invoked when a \#pragma mark comment is read. 
-   virtual void PragmaMark(SourceLocation Loc, StringRef Trivia) { 
-   } 
-   
-   /// Callback invoked when a \#pragma detect_mismatch directive is 
-   /// read. 
-   virtual void PragmaDetectMismatch(SourceLocation Loc, StringRef Name, 
-                                     StringRef Value) { 
-   } 
-   
-   /// Callback invoked when a \#pragma clang __debug directive is read. 
-   /// \param Loc The location of the debug directive. 
-   /// \param DebugType The identifier following __debug. 
-   virtual void PragmaDebug(SourceLocation Loc, StringRef DebugType) { 
-   } 
-   
-   /// Determines the kind of \#pragma invoking a call to PragmaMessage. 
-   enum PragmaMessageKind { 
-     /// \#pragma message has been invoked. 
-     PMK_Message, 
-   
-     /// \#pragma GCC warning has been invoked. 
-     PMK_Warning, 
-   
-     /// \#pragma GCC error has been invoked. 
-     PMK_Error 
-   }; 
-   
-   /// Callback invoked when a \#pragma message directive is read. 
-   /// \param Loc The location of the message directive. 
-   /// \param Namespace The namespace of the message directive. 
-   /// \param Kind The type of the message directive. 
-   /// \param Str The text of the message directive. 
-   virtual void PragmaMessage(SourceLocation Loc, StringRef Namespace, 
-                              PragmaMessageKind Kind, StringRef Str) { 
-   } 
-   
-   /// Callback invoked when a \#pragma gcc diagnostic push directive 
-   /// is read. 
-   virtual void PragmaDiagnosticPush(SourceLocation Loc, 
-                                     StringRef Namespace) { 
-   } 
-   
-   /// Callback invoked when a \#pragma gcc diagnostic pop directive 
-   /// is read. 
-   virtual void PragmaDiagnosticPop(SourceLocation Loc, 
-                                    StringRef Namespace) { 
-   } 
-   
-   /// Callback invoked when a \#pragma gcc diagnostic directive is read. 
-   virtual void PragmaDiagnostic(SourceLocation Loc, StringRef Namespace, 
-                                 diag::Severity mapping, StringRef Str) {} 
-   
-   /// Called when an OpenCL extension is either disabled or 
-   /// enabled with a pragma. 
-   virtual void PragmaOpenCLExtension(SourceLocation NameLoc, 
-                                      const IdentifierInfo *Name, 
-                                      SourceLocation StateLoc, unsigned State) { 
-   } 
-   
-   /// Callback invoked when a \#pragma warning directive is read. 
-   enum PragmaWarningSpecifier { 
-     PWS_Default, 
-     PWS_Disable, 
-     PWS_Error, 
-     PWS_Once, 
-     PWS_Suppress, 
-     PWS_Level1, 
-     PWS_Level2, 
-     PWS_Level3, 
-     PWS_Level4, 
-   }; 
-   virtual void PragmaWarning(SourceLocation Loc, 
-                              PragmaWarningSpecifier WarningSpec, 
-                              ArrayRef<int> Ids) {} 
-   
-   /// Callback invoked when a \#pragma warning(push) directive is read. 
-   virtual void PragmaWarningPush(SourceLocation Loc, int Level) { 
-   } 
-   
-   /// Callback invoked when a \#pragma warning(pop) directive is read. 
-   virtual void PragmaWarningPop(SourceLocation Loc) { 
-   } 
-   
-   /// Callback invoked when a \#pragma execution_character_set(push) directive 
-   /// is read. 
-   virtual void PragmaExecCharsetPush(SourceLocation Loc, StringRef Str) {} 
-   
-   /// Callback invoked when a \#pragma execution_character_set(pop) directive 
-   /// is read. 
-   virtual void PragmaExecCharsetPop(SourceLocation Loc) {} 
-   
-   /// Callback invoked when a \#pragma clang assume_nonnull begin directive 
-   /// is read. 
-   virtual void PragmaAssumeNonNullBegin(SourceLocation Loc) {} 
-   
-   /// Callback invoked when a \#pragma clang assume_nonnull end directive 
-   /// is read. 
-   virtual void PragmaAssumeNonNullEnd(SourceLocation Loc) {} 
-   
-   /// Called by Preprocessor::HandleMacroExpandedIdentifier when a 
-   /// macro invocation is found. 
-   virtual void MacroExpands(const Token &MacroNameTok, 
-                             const MacroDefinition &MD, SourceRange Range, 
-                             const MacroArgs *Args) {} 
-   
-   /// Hook called whenever a macro definition is seen. 
-   virtual void MacroDefined(const Token &MacroNameTok, 
-                             const MacroDirective *MD) { 
-   } 
-   
-   /// Hook called whenever a macro \#undef is seen. 
-   /// \param MacroNameTok The active Token 
-   /// \param MD A MacroDefinition for the named macro. 
-   /// \param Undef New MacroDirective if the macro was defined, null otherwise. 
-   /// 
-   /// MD is released immediately following this callback. 
-   virtual void MacroUndefined(const Token &MacroNameTok, 
-                               const MacroDefinition &MD, 
-                               const MacroDirective *Undef) { 
-   } 
-   
-   /// Hook called whenever the 'defined' operator is seen. 
-   /// \param MD The MacroDirective if the name was a macro, null otherwise. 
-   virtual void Defined(const Token &MacroNameTok, const MacroDefinition &MD, 
-                        SourceRange Range) { 
-   } 
-   
-   /// Hook called when a '__has_include' or '__has_include_next' directive is 
-   /// read. 
-   virtual void HasInclude(SourceLocation Loc, StringRef FileName, bool IsAngled, 
-                           OptionalFileEntryRef File, 
-                           SrcMgr::CharacteristicKind FileType); 
-   
-   /// Hook called when a source range is skipped. 
-   /// \param Range The SourceRange that was skipped. The range begins at the 
-   /// \#if/\#else directive and ends after the \#endif/\#else directive. 
-   /// \param EndifLoc The end location of the 'endif' token, which may precede 
-   /// the range skipped by the directive (e.g excluding comments after an 
-   /// 'endif'). 
-   virtual void SourceRangeSkipped(SourceRange Range, SourceLocation EndifLoc) { 
-   } 
-   
-   enum ConditionValueKind { 
-     CVK_NotEvaluated, CVK_False, CVK_True 
-   }; 
-   
-   /// Hook called whenever an \#if is seen. 
-   /// \param Loc the source location of the directive. 
-   /// \param ConditionRange The SourceRange of the expression being tested. 
-   /// \param ConditionValue The evaluated value of the condition. 
-   /// 
-   // FIXME: better to pass in a list (or tree!) of Tokens. 
-   virtual void If(SourceLocation Loc, SourceRange ConditionRange, 
-                   ConditionValueKind ConditionValue) { 
-   } 
-   
-   /// Hook called whenever an \#elif is seen. 
-   /// \param Loc the source location of the directive. 
-   /// \param ConditionRange The SourceRange of the expression being tested. 
-   /// \param ConditionValue The evaluated value of the condition. 
-   /// \param IfLoc the source location of the \#if/\#ifdef/\#ifndef directive. 
-   // FIXME: better to pass in a list (or tree!) of Tokens. 
-   virtual void Elif(SourceLocation Loc, SourceRange ConditionRange, 
-                     ConditionValueKind ConditionValue, SourceLocation IfLoc) { 
-   } 
-   
-   /// Hook called whenever an \#ifdef is seen. 
-   /// \param Loc the source location of the directive. 
-   /// \param MacroNameTok Information on the token being tested. 
-   /// \param MD The MacroDefinition if the name was a macro, null otherwise. 
-   virtual void Ifdef(SourceLocation Loc, const Token &MacroNameTok, 
-                      const MacroDefinition &MD) { 
-   } 
-   
-   /// Hook called whenever an \#elifdef branch is taken. 
-   /// \param Loc the source location of the directive. 
-   /// \param MacroNameTok Information on the token being tested. 
-   /// \param MD The MacroDefinition if the name was a macro, null otherwise. 
-   virtual void Elifdef(SourceLocation Loc, const Token &MacroNameTok, 
-                        const MacroDefinition &MD) { 
-   } 
-   /// Hook called whenever an \#elifdef is skipped. 
-   /// \param Loc the source location of the directive. 
-   /// \param ConditionRange The SourceRange of the expression being tested. 
-   /// \param IfLoc the source location of the \#if/\#ifdef/\#ifndef directive. 
-   // FIXME: better to pass in a list (or tree!) of Tokens. 
-   virtual void Elifdef(SourceLocation Loc, SourceRange ConditionRange, 
-                        SourceLocation IfLoc) { 
-   } 
-   
-   /// Hook called whenever an \#ifndef is seen. 
-   /// \param Loc the source location of the directive. 
-   /// \param MacroNameTok Information on the token being tested. 
-   /// \param MD The MacroDefiniton if the name was a macro, null otherwise. 
-   virtual void Ifndef(SourceLocation Loc, const Token &MacroNameTok, 
-                       const MacroDefinition &MD) { 
-   } 
-   
-   /// Hook called whenever an \#elifndef branch is taken. 
-   /// \param Loc the source location of the directive. 
-   /// \param MacroNameTok Information on the token being tested. 
-   /// \param MD The MacroDefinition if the name was a macro, null otherwise. 
-   virtual void Elifndef(SourceLocation Loc, const Token &MacroNameTok, 
-                         const MacroDefinition &MD) { 
-   } 
-   /// Hook called whenever an \#elifndef is skipped. 
-   /// \param Loc the source location of the directive. 
-   /// \param ConditionRange The SourceRange of the expression being tested. 
-   /// \param IfLoc the source location of the \#if/\#ifdef/\#ifndef directive. 
-   // FIXME: better to pass in a list (or tree!) of Tokens. 
-   virtual void Elifndef(SourceLocation Loc, SourceRange ConditionRange, 
-                         SourceLocation IfLoc) { 
-   } 
-   
-   /// Hook called whenever an \#else is seen. 
-   /// \param Loc the source location of the directive. 
-   /// \param IfLoc the source location of the \#if/\#ifdef/\#ifndef directive. 
-   virtual void Else(SourceLocation Loc, SourceLocation IfLoc) { 
-   } 
-   
-   /// Hook called whenever an \#endif is seen. 
-   /// \param Loc the source location of the directive. 
-   /// \param IfLoc the source location of the \#if/\#ifdef/\#ifndef directive. 
-   virtual void Endif(SourceLocation Loc, SourceLocation IfLoc) { 
-   } 
- }; 
-   
- /// Simple wrapper class for chaining callbacks. 
- class PPChainedCallbacks : public PPCallbacks { 
-   std::unique_ptr<PPCallbacks> First, Second; 
-   
- public: 
-   PPChainedCallbacks(std::unique_ptr<PPCallbacks> _First, 
-                      std::unique_ptr<PPCallbacks> _Second) 
-     : First(std::move(_First)), Second(std::move(_Second)) {} 
-   
-   ~PPChainedCallbacks() override; 
-   
-   void FileChanged(SourceLocation Loc, FileChangeReason Reason, 
-                    SrcMgr::CharacteristicKind FileType, 
-                    FileID PrevFID) override { 
-     First->FileChanged(Loc, Reason, FileType, PrevFID); 
-     Second->FileChanged(Loc, Reason, FileType, PrevFID); 
-   } 
-   
-   void LexedFileChanged(FileID FID, LexedFileChangeReason Reason, 
-                         SrcMgr::CharacteristicKind FileType, FileID PrevFID, 
-                         SourceLocation Loc) override { 
-     First->LexedFileChanged(FID, Reason, FileType, PrevFID, Loc); 
-     Second->LexedFileChanged(FID, Reason, FileType, PrevFID, Loc); 
-   } 
-   
-   void FileSkipped(const FileEntryRef &SkippedFile, const Token &FilenameTok, 
-                    SrcMgr::CharacteristicKind FileType) override { 
-     First->FileSkipped(SkippedFile, FilenameTok, FileType); 
-     Second->FileSkipped(SkippedFile, FilenameTok, FileType); 
-   } 
-   
-   bool FileNotFound(StringRef FileName) override { 
-     bool Skip = First->FileNotFound(FileName); 
-     // Make sure to invoke the second callback, no matter if the first already 
-     // returned true to skip the file. 
-     Skip |= Second->FileNotFound(FileName); 
-     return Skip; 
-   } 
-   
-   void InclusionDirective(SourceLocation HashLoc, const Token &IncludeTok, 
-                           StringRef FileName, bool IsAngled, 
-                           CharSourceRange FilenameRange, 
-                           OptionalFileEntryRef File, StringRef SearchPath, 
-                           StringRef RelativePath, const Module *Imported, 
-                           SrcMgr::CharacteristicKind FileType) override { 
-     First->InclusionDirective(HashLoc, IncludeTok, FileName, IsAngled, 
-                               FilenameRange, File, SearchPath, RelativePath, 
-                               Imported, FileType); 
-     Second->InclusionDirective(HashLoc, IncludeTok, FileName, IsAngled, 
-                                FilenameRange, File, SearchPath, RelativePath, 
-                                Imported, FileType); 
-   } 
-   
-   void EnteredSubmodule(Module *M, SourceLocation ImportLoc, 
-                         bool ForPragma) override { 
-     First->EnteredSubmodule(M, ImportLoc, ForPragma); 
-     Second->EnteredSubmodule(M, ImportLoc, ForPragma); 
-   } 
-   
-   void LeftSubmodule(Module *M, SourceLocation ImportLoc, 
-                      bool ForPragma) override { 
-     First->LeftSubmodule(M, ImportLoc, ForPragma); 
-     Second->LeftSubmodule(M, ImportLoc, ForPragma); 
-   } 
-   
-   void moduleImport(SourceLocation ImportLoc, ModuleIdPath Path, 
-                     const Module *Imported) override { 
-     First->moduleImport(ImportLoc, Path, Imported); 
-     Second->moduleImport(ImportLoc, Path, Imported); 
-   } 
-   
-   void EndOfMainFile() override { 
-     First->EndOfMainFile(); 
-     Second->EndOfMainFile(); 
-   } 
-   
-   void Ident(SourceLocation Loc, StringRef str) override { 
-     First->Ident(Loc, str); 
-     Second->Ident(Loc, str); 
-   } 
-   
-   void PragmaDirective(SourceLocation Loc, 
-                        PragmaIntroducerKind Introducer) override { 
-     First->PragmaDirective(Loc, Introducer); 
-     Second->PragmaDirective(Loc, Introducer); 
-   } 
-   
-   void PragmaComment(SourceLocation Loc, const IdentifierInfo *Kind, 
-                      StringRef Str) override { 
-     First->PragmaComment(Loc, Kind, Str); 
-     Second->PragmaComment(Loc, Kind, Str); 
-   } 
-   
-   void PragmaMark(SourceLocation Loc, StringRef Trivia) override { 
-     First->PragmaMark(Loc, Trivia); 
-     Second->PragmaMark(Loc, Trivia); 
-   } 
-   
-   void PragmaDetectMismatch(SourceLocation Loc, StringRef Name, 
-                             StringRef Value) override { 
-     First->PragmaDetectMismatch(Loc, Name, Value); 
-     Second->PragmaDetectMismatch(Loc, Name, Value); 
-   } 
-   
-   void PragmaDebug(SourceLocation Loc, StringRef DebugType) override { 
-     First->PragmaDebug(Loc, DebugType); 
-     Second->PragmaDebug(Loc, DebugType); 
-   } 
-   
-   void PragmaMessage(SourceLocation Loc, StringRef Namespace, 
-                      PragmaMessageKind Kind, StringRef Str) override { 
-     First->PragmaMessage(Loc, Namespace, Kind, Str); 
-     Second->PragmaMessage(Loc, Namespace, Kind, Str); 
-   } 
-   
-   void PragmaDiagnosticPush(SourceLocation Loc, StringRef Namespace) override { 
-     First->PragmaDiagnosticPush(Loc, Namespace); 
-     Second->PragmaDiagnosticPush(Loc, Namespace); 
-   } 
-   
-   void PragmaDiagnosticPop(SourceLocation Loc, StringRef Namespace) override { 
-     First->PragmaDiagnosticPop(Loc, Namespace); 
-     Second->PragmaDiagnosticPop(Loc, Namespace); 
-   } 
-   
-   void PragmaDiagnostic(SourceLocation Loc, StringRef Namespace, 
-                         diag::Severity mapping, StringRef Str) override { 
-     First->PragmaDiagnostic(Loc, Namespace, mapping, Str); 
-     Second->PragmaDiagnostic(Loc, Namespace, mapping, Str); 
-   } 
-   
-   void HasInclude(SourceLocation Loc, StringRef FileName, bool IsAngled, 
-                   OptionalFileEntryRef File, 
-                   SrcMgr::CharacteristicKind FileType) override; 
-   
-   void PragmaOpenCLExtension(SourceLocation NameLoc, const IdentifierInfo *Name, 
-                              SourceLocation StateLoc, unsigned State) override { 
-     First->PragmaOpenCLExtension(NameLoc, Name, StateLoc, State); 
-     Second->PragmaOpenCLExtension(NameLoc, Name, StateLoc, State); 
-   } 
-   
-   void PragmaWarning(SourceLocation Loc, PragmaWarningSpecifier WarningSpec, 
-                      ArrayRef<int> Ids) override { 
-     First->PragmaWarning(Loc, WarningSpec, Ids); 
-     Second->PragmaWarning(Loc, WarningSpec, Ids); 
-   } 
-   
-   void PragmaWarningPush(SourceLocation Loc, int Level) override { 
-     First->PragmaWarningPush(Loc, Level); 
-     Second->PragmaWarningPush(Loc, Level); 
-   } 
-   
-   void PragmaWarningPop(SourceLocation Loc) override { 
-     First->PragmaWarningPop(Loc); 
-     Second->PragmaWarningPop(Loc); 
-   } 
-   
-   void PragmaExecCharsetPush(SourceLocation Loc, StringRef Str) override { 
-     First->PragmaExecCharsetPush(Loc, Str); 
-     Second->PragmaExecCharsetPush(Loc, Str); 
-   } 
-   
-   void PragmaExecCharsetPop(SourceLocation Loc) override { 
-     First->PragmaExecCharsetPop(Loc); 
-     Second->PragmaExecCharsetPop(Loc); 
-   } 
-   
-   void PragmaAssumeNonNullBegin(SourceLocation Loc) override { 
-     First->PragmaAssumeNonNullBegin(Loc); 
-     Second->PragmaAssumeNonNullBegin(Loc); 
-   } 
-   
-   void PragmaAssumeNonNullEnd(SourceLocation Loc) override { 
-     First->PragmaAssumeNonNullEnd(Loc); 
-     Second->PragmaAssumeNonNullEnd(Loc); 
-   } 
-   
-   void MacroExpands(const Token &MacroNameTok, const MacroDefinition &MD, 
-                     SourceRange Range, const MacroArgs *Args) override { 
-     First->MacroExpands(MacroNameTok, MD, Range, Args); 
-     Second->MacroExpands(MacroNameTok, MD, Range, Args); 
-   } 
-   
-   void MacroDefined(const Token &MacroNameTok, 
-                     const MacroDirective *MD) override { 
-     First->MacroDefined(MacroNameTok, MD); 
-     Second->MacroDefined(MacroNameTok, MD); 
-   } 
-   
-   void MacroUndefined(const Token &MacroNameTok, 
-                       const MacroDefinition &MD, 
-                       const MacroDirective *Undef) override { 
-     First->MacroUndefined(MacroNameTok, MD, Undef); 
-     Second->MacroUndefined(MacroNameTok, MD, Undef); 
-   } 
-   
-   void Defined(const Token &MacroNameTok, const MacroDefinition &MD, 
-                SourceRange Range) override { 
-     First->Defined(MacroNameTok, MD, Range); 
-     Second->Defined(MacroNameTok, MD, Range); 
-   } 
-   
-   void SourceRangeSkipped(SourceRange Range, SourceLocation EndifLoc) override { 
-     First->SourceRangeSkipped(Range, EndifLoc); 
-     Second->SourceRangeSkipped(Range, EndifLoc); 
-   } 
-   
-   /// Hook called whenever an \#if is seen. 
-   void If(SourceLocation Loc, SourceRange ConditionRange, 
-           ConditionValueKind ConditionValue) override { 
-     First->If(Loc, ConditionRange, ConditionValue); 
-     Second->If(Loc, ConditionRange, ConditionValue); 
-   } 
-   
-   /// Hook called whenever an \#elif is seen. 
-   void Elif(SourceLocation Loc, SourceRange ConditionRange, 
-             ConditionValueKind ConditionValue, SourceLocation IfLoc) override { 
-     First->Elif(Loc, ConditionRange, ConditionValue, IfLoc); 
-     Second->Elif(Loc, ConditionRange, ConditionValue, IfLoc); 
-   } 
-   
-   /// Hook called whenever an \#ifdef is seen. 
-   void Ifdef(SourceLocation Loc, const Token &MacroNameTok, 
-              const MacroDefinition &MD) override { 
-     First->Ifdef(Loc, MacroNameTok, MD); 
-     Second->Ifdef(Loc, MacroNameTok, MD); 
-   } 
-   
-   /// Hook called whenever an \#elifdef is taken. 
-   void Elifdef(SourceLocation Loc, const Token &MacroNameTok, 
-                const MacroDefinition &MD) override { 
-     First->Elifdef(Loc, MacroNameTok, MD); 
-     Second->Elifdef(Loc, MacroNameTok, MD); 
-   } 
-   /// Hook called whenever an \#elifdef is skipped. 
-   void Elifdef(SourceLocation Loc, SourceRange ConditionRange, 
-                SourceLocation IfLoc) override { 
-     First->Elifdef(Loc, ConditionRange, IfLoc); 
-     Second->Elifdef(Loc, ConditionRange, IfLoc); 
-   } 
-   
-   /// Hook called whenever an \#ifndef is seen. 
-   void Ifndef(SourceLocation Loc, const Token &MacroNameTok, 
-               const MacroDefinition &MD) override { 
-     First->Ifndef(Loc, MacroNameTok, MD); 
-     Second->Ifndef(Loc, MacroNameTok, MD); 
-   } 
-   
-   /// Hook called whenever an \#elifndef is taken. 
-   void Elifndef(SourceLocation Loc, const Token &MacroNameTok, 
-                 const MacroDefinition &MD) override { 
-     First->Elifndef(Loc, MacroNameTok, MD); 
-     Second->Elifndef(Loc, MacroNameTok, MD); 
-   } 
-   /// Hook called whenever an \#elifndef is skipped. 
-   void Elifndef(SourceLocation Loc, SourceRange ConditionRange, 
-                SourceLocation IfLoc) override { 
-     First->Elifndef(Loc, ConditionRange, IfLoc); 
-     Second->Elifndef(Loc, ConditionRange, IfLoc); 
-   } 
-   
-   /// Hook called whenever an \#else is seen. 
-   void Else(SourceLocation Loc, SourceLocation IfLoc) override { 
-     First->Else(Loc, IfLoc); 
-     Second->Else(Loc, IfLoc); 
-   } 
-   
-   /// Hook called whenever an \#endif is seen. 
-   void Endif(SourceLocation Loc, SourceLocation IfLoc) override { 
-     First->Endif(Loc, IfLoc); 
-     Second->Endif(Loc, IfLoc); 
-   } 
- }; 
-   
- }  // end namespace clang 
-   
- #endif 
-