Edit

kc3-lang/angle/src/compiler/Diagnostics.cpp

Branch :

  • Show log

    Commit

  • Author : Jamie Madill
    Date : 2013-07-08 13:30:19
    Hash : 075edd84
    Message : Refactor location tracking. R=kbr@chromium.org Review URL: https://codereview.appspot.com/9078046 git-svn-id: https://angleproject.googlecode.com/svn/trunk@2202 736b8ea6-26fd-11df-bfd4-992fa37f6226 TRAC #23333 Authored-by: alokp@chromium.org Signed-off-by: Shannon Woods Signed-off-by Nicolas Capens Merged-by: Jamie Madill

  • src/compiler/Diagnostics.cpp
  • //
    // Copyright (c) 2012-2013 The ANGLE Project Authors. All rights reserved.
    // Use of this source code is governed by a BSD-style license that can be
    // found in the LICENSE file.
    //
    
    #include "compiler/Diagnostics.h"
    
    #include "compiler/debug.h"
    #include "compiler/InfoSink.h"
    #include "compiler/preprocessor/SourceLocation.h"
    
    TDiagnostics::TDiagnostics(TInfoSink& infoSink) :
        mInfoSink(infoSink),
        mNumErrors(0),
        mNumWarnings(0)
    {
    }
    
    TDiagnostics::~TDiagnostics()
    {
    }
    
    void TDiagnostics::writeInfo(Severity severity,
                                 const pp::SourceLocation& loc,
                                 const std::string& reason,
                                 const std::string& token,
                                 const std::string& extra)
    {
        TPrefixType prefix = EPrefixNone;
        switch (severity)
        {
          case ERROR:
            ++mNumErrors;
            prefix = EPrefixError;
            break;
          case WARNING:
            ++mNumWarnings;
            prefix = EPrefixWarning;
            break;
          default:
            UNREACHABLE();
            break;
        }
    
        TInfoSinkBase& sink = mInfoSink.info;
        /* VC++ format: file(linenum) : error #: 'token' : extrainfo */
        sink.prefix(prefix);
        sink.location(loc.file, loc.line);
        sink << "'" << token <<  "' : " << reason << " " << extra << "\n";
    }
    
    void TDiagnostics::writeDebug(const std::string& str)
    {
        mInfoSink.debug << str;
    }
    
    void TDiagnostics::print(ID id,
                             const pp::SourceLocation& loc,
                             const std::string& text)
    {
        writeInfo(severity(id), loc, message(id), text, "");
    }