Edit

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

Branch :

  • Show log

    Commit

  • Author : shannon.woods%transgaming.com@gtempaccount.com
    Date : 2013-04-13 03:38:16
    Hash : 5524db0c
    Message : Add support for new ESSL 3.00 keywords. TRAC #22715 Signed-off-by: Jamie Madill Signed-off-by: Shannon Woods Author: Nicolas Capens git-svn-id: https://angleproject.googlecode.com/svn/branches/es3proto@2122 736b8ea6-26fd-11df-bfd4-992fa37f6226

  • 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(EncodeSourceLoc(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, "");
    }