Home | History | Annotate | Download | only in Frontend
      1 //===- ChainedDiagnosticConsumer.h - Chain Diagnostic Clients ---*- C++ -*-===//
      2 //
      3 //                     The LLVM Compiler Infrastructure
      4 //
      5 // This file is distributed under the University of Illinois Open Source
      6 // License. See LICENSE.TXT for details.
      7 //
      8 //===----------------------------------------------------------------------===//
      9 
     10 #ifndef LLVM_CLANG_FRONTEND_CHAINEDDIAGNOSTICCONSUMER_H
     11 #define LLVM_CLANG_FRONTEND_CHAINEDDIAGNOSTICCONSUMER_H
     12 
     13 #include "clang/Basic/Diagnostic.h"
     14 #include <memory>
     15 
     16 namespace clang {
     17 class LangOptions;
     18 
     19 /// ChainedDiagnosticConsumer - Chain two diagnostic clients so that diagnostics
     20 /// go to the first client and then the second. The first diagnostic client
     21 /// should be the "primary" client, and will be used for computing whether the
     22 /// diagnostics should be included in counts.
     23 class ChainedDiagnosticConsumer : public DiagnosticConsumer {
     24   virtual void anchor();
     25   std::unique_ptr<DiagnosticConsumer> OwningPrimary;
     26   DiagnosticConsumer *Primary;
     27   std::unique_ptr<DiagnosticConsumer> Secondary;
     28 
     29 public:
     30   ChainedDiagnosticConsumer(std::unique_ptr<DiagnosticConsumer> Primary,
     31                             std::unique_ptr<DiagnosticConsumer> Secondary)
     32       : OwningPrimary(std::move(Primary)), Primary(OwningPrimary.get()),
     33         Secondary(std::move(Secondary)) {}
     34 
     35   /// \brief Construct without taking ownership of \c Primary.
     36   ChainedDiagnosticConsumer(DiagnosticConsumer *Primary,
     37                             std::unique_ptr<DiagnosticConsumer> Secondary)
     38       : Primary(Primary), Secondary(std::move(Secondary)) {}
     39 
     40   void BeginSourceFile(const LangOptions &LO,
     41                        const Preprocessor *PP) override {
     42     Primary->BeginSourceFile(LO, PP);
     43     Secondary->BeginSourceFile(LO, PP);
     44   }
     45 
     46   void EndSourceFile() override {
     47     Secondary->EndSourceFile();
     48     Primary->EndSourceFile();
     49   }
     50 
     51   void finish() override {
     52     Secondary->finish();
     53     Primary->finish();
     54   }
     55 
     56   bool IncludeInDiagnosticCounts() const override {
     57     return Primary->IncludeInDiagnosticCounts();
     58   }
     59 
     60   void HandleDiagnostic(DiagnosticsEngine::Level DiagLevel,
     61                         const Diagnostic &Info) override {
     62     // Default implementation (Warnings/errors count).
     63     DiagnosticConsumer::HandleDiagnostic(DiagLevel, Info);
     64 
     65     Primary->HandleDiagnostic(DiagLevel, Info);
     66     Secondary->HandleDiagnostic(DiagLevel, Info);
     67   }
     68 };
     69 
     70 } // end namspace clang
     71 
     72 #endif
     73