blob: 06f370dbe5b4695361ab99d3602e3f6655c3b21f [file] [log] [blame]
alokp@chromium.org8b851c62012-06-15 16:25:11 +00001//
2// Copyright (c) 2012 The ANGLE Project Authors. All rights reserved.
3// Use of this source code is governed by a BSD-style license that can be
4// found in the LICENSE file.
5//
6
7#include "compiler/Diagnostics.h"
8
alokp@chromium.org6b495712012-06-29 00:06:58 +00009#include "compiler/debug.h"
alokp@chromium.org8b851c62012-06-15 16:25:11 +000010#include "compiler/InfoSink.h"
daniel@transgaming.comb401a922012-10-26 18:58:24 +000011#include "compiler/preprocessor/SourceLocation.h"
alokp@chromium.org8b851c62012-06-15 16:25:11 +000012
alokp@chromium.org6b495712012-06-29 00:06:58 +000013TDiagnostics::TDiagnostics(TInfoSink& infoSink) :
14 mInfoSink(infoSink),
15 mNumErrors(0),
16 mNumWarnings(0)
alokp@chromium.org8b851c62012-06-15 16:25:11 +000017{
18}
19
20TDiagnostics::~TDiagnostics()
21{
22}
23
24void TDiagnostics::writeInfo(Severity severity,
25 const pp::SourceLocation& loc,
26 const std::string& reason,
27 const std::string& token,
28 const std::string& extra)
29{
alokp@chromium.org6b495712012-06-29 00:06:58 +000030 TPrefixType prefix = EPrefixNone;
31 switch (severity)
32 {
33 case ERROR:
34 ++mNumErrors;
35 prefix = EPrefixError;
36 break;
37 case WARNING:
38 ++mNumWarnings;
39 prefix = EPrefixWarning;
40 break;
41 default:
42 UNREACHABLE();
43 break;
44 }
alokp@chromium.org8b851c62012-06-15 16:25:11 +000045
alokp@chromium.org6b495712012-06-29 00:06:58 +000046 TInfoSinkBase& sink = mInfoSink.info;
alokp@chromium.org8b851c62012-06-15 16:25:11 +000047 /* VC++ format: file(linenum) : error #: 'token' : extrainfo */
48 sink.prefix(prefix);
49 sink.location(EncodeSourceLoc(loc.file, loc.line));
50 sink << "'" << token << "' : " << reason << " " << extra << "\n";
51}
52
53void TDiagnostics::writeDebug(const std::string& str)
54{
55 mInfoSink.debug << str;
56}
57
58void TDiagnostics::print(ID id,
59 const pp::SourceLocation& loc,
60 const std::string& text)
61{
alokp@chromium.org6b495712012-06-29 00:06:58 +000062 writeInfo(severity(id), loc, message(id), text, "");
alokp@chromium.org8b851c62012-06-15 16:25:11 +000063}