Edit

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

Branch :

  • Show log

    Commit

  • Author : alokp@chromium.org
    Date : 2012-06-15 16:25:11
    Hash : 8b851c6d
    Message : Preparation of hooking up the new preprocessor. - Added custom Diagnostics class. Routed all info-log messages via this new class. - Added custom DirectiveHandler class. Moved directive-handling code to this class and routed the old path. - Deleted lexer_glue because it is not needed anymore. The new preprocessor is almost ready! - Killed a bunch of dead code related to PragmaTable. Review URL: https://codereview.appspot.com/6308074 git-svn-id: https://angleproject.googlecode.com/svn/trunk@1150 736b8ea6-26fd-11df-bfd4-992fa37f6226

  • src/compiler/debug.cpp
  • //
    // Copyright (c) 2002-2010 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.
    //
    
    // debug.cpp: Debugging utilities.
    
    #include "compiler/debug.h"
    
    #include <stdarg.h>
    #include <stdio.h>
    
    #include "compiler/InitializeParseContext.h"
    #include "compiler/ParseHelper.h"
    
    static const int kTraceBufferLen = 1024;
    
    #ifdef TRACE_ENABLED
    extern "C" {
    void Trace(const char *format, ...) {
        if (!format) return;
    
        TParseContext* parseContext = GetGlobalParseContext();
        if (parseContext) {
            char buf[kTraceBufferLen];
            va_list args;
            va_start(args, format);
            vsnprintf(buf, kTraceBufferLen, format, args);
            va_end(args);
    
            parseContext->trace(buf);
        }
    }
    }  // extern "C"
    #endif  // TRACE_ENABLED