diff options
author | Nico Weber <nicolasweber@gmx.de> | 2008-08-05 23:33:20 +0000 |
---|---|---|
committer | Nico Weber <nicolasweber@gmx.de> | 2008-08-05 23:33:20 +0000 |
commit | fd54ebcaaf9a165846fdfafb32362238458e7f2d (patch) | |
tree | ed47385606c70808f06c6fba7d71842d4500a5ef /lib/Driver/TextDiagnosticBuffer.cpp | |
parent | 3c827a79cb7d04c255db8080e682ee2c6912373d (diff) |
add a libDriver, for now only move the text diangostics stuff from Driver to there
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@54383 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Driver/TextDiagnosticBuffer.cpp')
-rw-r--r-- | lib/Driver/TextDiagnosticBuffer.cpp | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/lib/Driver/TextDiagnosticBuffer.cpp b/lib/Driver/TextDiagnosticBuffer.cpp new file mode 100644 index 0000000000..35aba58aad --- /dev/null +++ b/lib/Driver/TextDiagnosticBuffer.cpp @@ -0,0 +1,41 @@ +//===--- TextDiagnosticBuffer.cpp - Buffer Text Diagnostics ---------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// This is a concrete diagnostic client, which buffers the diagnostic messages. +// +//===----------------------------------------------------------------------===// + +#include "clang/Driver/TextDiagnosticBuffer.h" +#include "clang/Basic/SourceManager.h" +using namespace clang; + +/// HandleDiagnostic - Store the errors & warnings that are reported. +/// +void TextDiagnosticBuffer::HandleDiagnostic(Diagnostic &Diags, + Diagnostic::Level Level, + FullSourceLoc Pos, + diag::kind ID, + const std::string *Strs, + unsigned NumStrs, + const SourceRange *, + unsigned) { + switch (Level) { + default: assert(0 && "Diagnostic not handled during diagnostic buffering!"); + case Diagnostic::Warning: + Warnings.push_back(std::make_pair(Pos.getLocation(), + FormatDiagnostic(Diags, Level, ID, + Strs, NumStrs))); + break; + case Diagnostic::Error: + Errors.push_back(std::make_pair(Pos.getLocation(), + FormatDiagnostic(Diags, Level, ID, + Strs, NumStrs))); + break; + } +} |