blob: 7322a5745c79e8c737cdb9a40b4307ac40241f56 [file] [log] [blame]
//===- TextDiagnosticBuffer.h - Buffer Text Diagnostics ---------*- 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
//
//===----------------------------------------------------------------------===//
//
// This is a concrete diagnostic client. The diagnostics are buffered rather
// than printed. In order to print them, use the FlushDiagnostics method.
// Pretty-printing is not supported.
//
//===----------------------------------------------------------------------===//
#ifndef LLVM_FLANG_FRONTEND_TEXTDIAGNOSTICBUFFER_H
#define LLVM_FLANG_FRONTEND_TEXTDIAGNOSTICBUFFER_H
#include "clang/Basic/Diagnostic.h"
#include "clang/Basic/SourceLocation.h"
#include <cstddef>
#include <string>
#include <utility>
#include <vector>
namespace Fortran::frontend {
class TextDiagnosticBuffer : public clang::DiagnosticConsumer {
public:
using DiagList = std::vector<std::pair<clang::SourceLocation, std::string>>;
using DiagnosticsLevelAndIndexPairs =
std::vector<std::pair<clang::DiagnosticsEngine::Level, size_t>>;
private:
DiagList errors_, warnings_, remarks_, notes_;
/// All diagnostics in the order in which they were generated. That order
/// likely doesn't correspond to user input order, but at least it keeps
/// notes in the right places. Each pair is a diagnostic level and an index
/// into the corresponding DiagList above.
DiagnosticsLevelAndIndexPairs all_;
public:
void HandleDiagnostic(clang::DiagnosticsEngine::Level diagLevel,
const clang::Diagnostic &info) override;
/// Flush the buffered diagnostics to a given diagnostic engine.
void FlushDiagnostics(clang::DiagnosticsEngine &diags) const;
};
} // namespace Fortran::frontend
#endif // LLVM_CLANG_FRONTEND_TEXTDIAGNOSTICBUFFER_H