| /* |
| * Copyright 2008 Google Inc. |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); you may not |
| * use this file except in compliance with the License. You may obtain a copy of |
| * the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT |
| * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the |
| * License for the specific language governing permissions and limitations under |
| * the License. |
| */ |
| |
| #include <cstdio> |
| |
| #ifdef _WINDOWS |
| #include <windows.h> |
| #endif |
| |
| #include "Debug.h" |
| |
| #ifdef GWT_DEBUGDISABLE |
| // Dummy implementations for when debugging has been disabled |
| Debug::DebugStream& Debug::flush(Debug::DebugStream& dbg) { |
| return dbg; |
| } |
| |
| void Debug::logFinish() {} |
| |
| void Debug::logString(const char* str) {} |
| |
| #else |
| // Warning: this function is inlined in the manipulator output operator in DebugStream. |
| // It only remains here because some compiler/linker combinations such as MSVC will |
| // give unresolved symbol errors if it isn't -- GCC, for example, will completely remove |
| // all traces of this method. |
| Debug::DebugStream& Debug::flush(Debug::DebugStream& dbg) { |
| Debug::logFinish(); |
| return dbg; |
| } |
| |
| // These methods are implemented in an Objective-C++ file on OSX |
| #if !defined(__APPLE_CC__) || defined(__mac) |
| |
| #ifdef _WINDOWS |
| #define DEBUG_BUF_SIZE 2048 |
| |
| static char buf[DEBUG_BUF_SIZE + 3]; // room for CR NL Null |
| static char *bufPtr = buf; |
| #endif |
| |
| void Debug::logFinish() { |
| #ifdef _WINDOWS |
| logString("\r\n"); |
| ::OutputDebugStringA(buf); |
| bufPtr = buf; |
| #else |
| putchar('\n'); |
| #endif |
| } |
| |
| // logStart may be called multiple times per logFinish |
| void Debug::logStart(LogLevel level) { |
| } |
| |
| void Debug::logString(const char* str) { |
| #ifdef _WINDOWS |
| size_t len = strlen(str); |
| size_t buflen = DEBUG_BUF_SIZE - (bufPtr - buf); |
| if (len >= buflen) { |
| len = buflen - 1; |
| } |
| strncpy_s(bufPtr, buflen, str, len); |
| bufPtr += len; |
| #else |
| fputs(str, stdout); |
| #endif |
| } |
| #endif |
| #endif |
| |