blob: d6afabf94a56513add741e05f35d47f328ffa712 [file] [log] [blame]
Zonr Changc383a502010-10-12 01:52:08 +08001/*
2 * Copyright 2010, The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
zonr6315f762010-10-05 15:35:14 +080017#include "slang_diagnostic_buffer.h"
Shih-wei Liao462aefd2010-06-04 15:32:04 -070018
Stephen Hinese639eb52010-11-08 19:27:20 -080019#include "clang/Basic/SourceLocation.h"
20#include "clang/Basic/SourceManager.h"
21
Shih-wei Liao9ef2f782010-10-01 12:31:37 -070022#include "llvm/ADT/SmallString.h"
Shih-wei Liao462aefd2010-06-04 15:32:04 -070023
Stephen Hines6e6578a2011-02-07 18:05:48 -080024#include "slang_assert.h"
25
Stephen Hinese639eb52010-11-08 19:27:20 -080026namespace slang {
Shih-wei Liao462aefd2010-06-04 15:32:04 -070027
Logan Chien9207a2e2011-10-21 15:39:28 +080028DiagnosticBuffer::DiagnosticBuffer()
Logan Chienc86623e2011-10-22 18:22:25 +080029 : mSOS(new llvm::raw_string_ostream(mDiags)) {
Shih-wei Liao462aefd2010-06-04 15:32:04 -070030}
31
Logan Chien9207a2e2011-10-21 15:39:28 +080032DiagnosticBuffer::~DiagnosticBuffer() {
33}
34
35void DiagnosticBuffer::HandleDiagnostic(
Stephen Hinese67239d2012-02-24 15:08:36 -080036 clang::DiagnosticsEngine::Level DiagLevel,
37 clang::Diagnostic const &Info) {
Logan Chien9207a2e2011-10-21 15:39:28 +080038 clang::SourceLocation const &SrcLoc = Info.getLocation();
39
Jean-Luc Brouillet666b0a72015-05-01 16:13:11 -070040 std::string Message;
41 llvm::raw_string_ostream stream(Message);
Shih-wei Liao462aefd2010-06-04 15:32:04 -070042
Loganbe274822011-02-16 22:02:54 +080043 if (SrcLoc.isValid()) {
Jean-Luc Brouillet666b0a72015-05-01 16:13:11 -070044 SrcLoc.print(stream, Info.getSourceManager());
45 stream << ": ";
Shih-wei Liao9ef2f782010-10-01 12:31:37 -070046 }
47
48 switch (DiagLevel) {
Logan Chien9207a2e2011-10-21 15:39:28 +080049 case clang::DiagnosticsEngine::Note: {
Jean-Luc Brouillet666b0a72015-05-01 16:13:11 -070050 stream << "note: ";
Shih-wei Liao9ef2f782010-10-01 12:31:37 -070051 break;
Shih-wei Liao462aefd2010-06-04 15:32:04 -070052 }
Logan Chien9207a2e2011-10-21 15:39:28 +080053 case clang::DiagnosticsEngine::Warning: {
Jean-Luc Brouillet666b0a72015-05-01 16:13:11 -070054 stream << "warning: ";
Shih-wei Liao9ef2f782010-10-01 12:31:37 -070055 break;
Shih-wei Liao462aefd2010-06-04 15:32:04 -070056 }
Logan Chien9207a2e2011-10-21 15:39:28 +080057 case clang::DiagnosticsEngine::Error: {
Jean-Luc Brouillet666b0a72015-05-01 16:13:11 -070058 stream << "error: ";
Shih-wei Liao9ef2f782010-10-01 12:31:37 -070059 break;
60 }
Logan Chien9207a2e2011-10-21 15:39:28 +080061 case clang::DiagnosticsEngine::Fatal: {
Jean-Luc Brouillet666b0a72015-05-01 16:13:11 -070062 stream << "fatal: ";
Shih-wei Liao9ef2f782010-10-01 12:31:37 -070063 break;
64 }
65 default: {
Stephen Hines6e6578a2011-02-07 18:05:48 -080066 slangAssert(0 && "Diagnostic not handled during diagnostic buffering!");
Shih-wei Liao9ef2f782010-10-01 12:31:37 -070067 }
68 }
Jean-Luc Brouillet666b0a72015-05-01 16:13:11 -070069 // 100 is enough for storing general diagnosis Message
70 llvm::SmallString<100> Buf;
Shih-wei Liao9ef2f782010-10-01 12:31:37 -070071 Info.FormatDiagnostic(Buf);
Jean-Luc Brouillet666b0a72015-05-01 16:13:11 -070072 stream << Buf.str() << '\n';
73 stream.flush();
Shih-wei Liao462aefd2010-06-04 15:32:04 -070074
Jean-Luc Brouillet666b0a72015-05-01 16:13:11 -070075 if (mIncludedMessages.find(Message) == mIncludedMessages.end()) {
76 mIncludedMessages.insert(Message);
77 (*mSOS) << Message;
78 }
Shih-wei Liao462aefd2010-06-04 15:32:04 -070079}
Stephen Hinese639eb52010-11-08 19:27:20 -080080
81} // namespace slang