diff options
author | nsylvain@google.com <nsylvain@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-08-06 17:02:34 +0000 |
---|---|---|
committer | nsylvain@google.com <nsylvain@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-08-06 17:02:34 +0000 |
commit | dd88bf243bf1ddc01f16fdce388d5a9718240dea (patch) | |
tree | 7ed873c4f947832816a2acd65d3122c8c9166827 | |
parent | 1010f7d1107f4df30be4a6d97ddeead2d4f3e585 (diff) | |
download | chromium_src-dd88bf243bf1ddc01f16fdce388d5a9718240dea.zip chromium_src-dd88bf243bf1ddc01f16fdce388d5a9718240dea.tar.gz chromium_src-dd88bf243bf1ddc01f16fdce388d5a9718240dea.tar.bz2 |
Revert change 430 because it breaks the build.
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@437 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | base/logging.cc | 191 | ||||
-rw-r--r-- | base/logging.h | 4 |
2 files changed, 27 insertions, 168 deletions
diff --git a/base/logging.cc b/base/logging.cc index 97bab69..eba177e 100644 --- a/base/logging.cc +++ b/base/logging.cc @@ -27,37 +27,15 @@ // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -#include "build/build_config.h" - -#if defined(WIN32) -#include <windows.h> -typedef HANDLE FileHandle; -typedef HANDLE MutexHandle; -#endif - -#if defined(OS_MACOSX) -#include <CoreFoundation/CoreFoundation.h> -#include <mach/mach.h> -#include <mach/mach_time.h> -#include <mach-o/dyld.h> -#include <stdlib.h> -#include <stdio.h> -#include <string.h> -#include <unistd.h> -#define MAX_PATH PATH_MAX -typedef FILE* FileHandle; -typedef pthread_mutex_t* MutexHandle; -#endif - #include <ctime> #include <iomanip> #include <cstring> +#include <windows.h> #include <algorithm> #include "base/base_switches.h" #include "base/command_line.h" #include "base/lock_impl.h" #include "base/logging.h" -#include "base/string_util.h" namespace logging { @@ -76,15 +54,10 @@ char* log_filter_prefix = NULL; // which log file to use? This is initialized by InitLogging or // will be lazily initialized to the default value when it is // first needed. -#if defined(OS_WIN) -typedef wchar_t PathChar; -#else -typedef char PathChar; -#endif -PathChar log_file_name[MAX_PATH] = { 0 }; +wchar_t log_file_name[MAX_PATH] = { 0 }; // this file is lazily opened and the handle may be NULL -FileHandle log_file = NULL; +HANDLE log_file = NULL; // what should be prepended to each message? bool log_process_id = false; @@ -103,60 +76,7 @@ static LockImpl* log_lock = NULL; // When we don't use a lock, we are using a global mutex. We need to do this // because LockFileEx is not thread safe. -#if defined(OS_WIN) -MutexHandle log_mutex = NULL; -#elif defined(OS_POSIX) -pthread_mutex_t log_mutex = PTHREAD_MUTEX_INITIALIZER; -#endif - -// Helper functions to wrap platform differences. -// TODO(pinkerton): move these into a separate support file, perhaps - -int32 CurrentProcessId() { -#if defined(OS_WIN) - return GetCurrentProcessId(); -#elif defined(OS_POSIX) - return getpid(); -#endif -} - -int32 CurrentThreadId() { -#if defined(OS_WIN) - return GetCurrentThreadId(); -#elif defined(OS_MACOSX) - return mach_thread_self(); -#else - // TODO(pinkerton): need linux-fu to fill in thread id here - return 0; -#endif -} - -uint64 TickCount() { -#if defined(OS_WIN) - return GetTickCount(); -#elif defined(OS_MACOSX) - return mach_absolute_time(); -#else - // TODO(pinkerton): need linux-fu to fill in time here - return 0; -#endif -} - -void CloseFile(FileHandle log) { -#if defined(OS_WIN) - CloseHandle(log); -#else - fclose(log); -#endif -} - -void DeleteFilePath(PathChar* log_name) { -#if defined(OS_WIN) - DeleteFile(log_name); -#else - unlink(log_name); -#endif -} +HANDLE log_mutex = NULL; // Called by logging functions to ensure that debug_file is initialized // and can be used for writing. Returns false if the file could not be @@ -165,14 +85,13 @@ bool InitializeLogFileHandle() { if (log_file) return true; -#if defined(OS_WIN) if (!log_file_name[0]) { // nobody has called InitLogging to specify a debug log file, so here we // initialize the log file name to the default GetModuleFileName(NULL, log_file_name, MAX_PATH); wchar_t* last_backslash = wcsrchr(log_file_name, '\\'); if (last_backslash) - last_backslash[1] = 0; // name now ends with the backslash + last_backslash[1] = 0; // name now ends with the backslash wcscat_s(log_file_name, L"debug.log"); } @@ -190,34 +109,10 @@ bool InitializeLogFileHandle() { } } SetFilePointer(log_file, 0, 0, FILE_END); -#elif defined(OS_POSIX) - if (!log_file_name[0]) { -#if defined(OS_MACOSX) - // nobody has called InitLogging to specify a debug log file, so here we - // initialize the log file name to the default - uint32_t log_file_name_size = arraysize(log_file_name); - _NSGetExecutablePath(log_file_name, &log_file_name_size); - char* last_slash = strrchr(log_file_name, '/'); - if (last_slash) - last_slash[1] = 0; // name now ends with the slash - strlcat(log_file_name, "debug.log", arraysize(log_file_name)); -#endif - } - - log_file = fopen(log_file_name, "a"); - if (log_file == NULL) { - // try the current directory - log_file = fopen("debug.log", "a"); - if (log_file == NULL) { - return false; - } - } -#endif return true; } void InitLogMutex() { -#if defined(OS_WIN) if (!log_mutex) { // \ is not a legal character in mutex names so we replace \ with / std::wstring safe_name(log_file_name); @@ -226,19 +121,16 @@ void InitLogMutex() { t.append(safe_name); log_mutex = ::CreateMutex(NULL, FALSE, t.c_str()); } -#elif defined(OS_POSIX) - // statically initialized -#endif } -void InitLogging(const PathChar* new_log_file, LoggingDestination logging_dest, +void InitLogging(const wchar_t* new_log_file, LoggingDestination logging_dest, LogLockingState lock_log, OldFileDeletionState delete_old) { g_enable_dcheck = CommandLine().HasSwitch(switches::kEnableDCHECK); if (log_file) { // calling InitLogging twice or after some log call has already opened the // default log file will re-initialize to the new options - CloseFile(log_file); + CloseHandle(log_file); log_file = NULL; } @@ -250,13 +142,9 @@ void InitLogging(const PathChar* new_log_file, LoggingDestination logging_dest, logging_destination == LOG_ONLY_TO_SYSTEM_DEBUG_LOG) return; -#if defined(OS_WIN) wcscpy_s(log_file_name, MAX_PATH, new_log_file); -#elif defined(OS_POSIX) - strlcpy(log_file_name, new_log_file, arraysize(log_file_name)); -#endif if (delete_old == DELETE_OLD_LOG_FILE) - DeleteFilePath(log_file_name); + DeleteFile(log_file_name); if (lock_log_file == LOCK_LOG_FILE) { InitLogMutex(); @@ -284,11 +172,7 @@ void SetLogFilterPrefix(const char* filter) { if (filter) { size_t size = strlen(filter)+1; log_filter_prefix = new char[size]; -#if defined(OS_WIN) strcpy_s(log_filter_prefix, size, filter); -#elif defined(OS_POSIX) - strlcpy(log_filter_prefix, filter, size); -#endif } } @@ -315,7 +199,6 @@ void DisplayDebugMessage(const std::string& str) { if (str.empty()) return; -#if defined(OS_WIN) // look for the debug dialog program next to our application wchar_t prog_name[MAX_PATH]; GetModuleFileNameW(NULL, prog_name, MAX_PATH); @@ -348,9 +231,6 @@ void DisplayDebugMessage(const std::string& str) { MessageBoxW(NULL, cmdline.get(), L"Fatal error", MB_OK | MB_ICONHAND | MB_TOPMOST); } -#else - fprintf(stderr, "%s\n", str.c_str()); -#endif } LogMessage::LogMessage(const char* file, int line, LogSeverity severity, @@ -386,9 +266,9 @@ void LogMessage::Init(const char* file, int line) { stream_ << '['; if (log_process_id) - stream_ << CurrentProcessId() << ':'; + stream_ << GetCurrentProcessId() << ':'; if (log_thread_id) - stream_ << CurrentThreadId() << ':'; + stream_ << GetCurrentThreadId() << ':'; if (log_timestamp) { time_t t = time(NULL); #if _MSC_VER >= 1400 @@ -408,7 +288,7 @@ void LogMessage::Init(const char* file, int line) { << ':'; } if (log_tickcount) - stream_ << TickCount() << ':'; + stream_ << GetTickCount() << ':'; stream_ << log_severity_names[severity_] << ":" << file << "(" << line << ")] "; message_start_ = stream_.tellp(); @@ -430,14 +310,9 @@ LogMessage::~LogMessage() { } if (logging_destination == LOG_ONLY_TO_SYSTEM_DEBUG_LOG || - logging_destination == LOG_TO_BOTH_FILE_AND_SYSTEM_DEBUG_LOG) { -#if defined(OS_WIN) + logging_destination == LOG_TO_BOTH_FILE_AND_SYSTEM_DEBUG_LOG) OutputDebugStringA(str_newline.c_str()); -#else - fprintf(stderr, str_newline.c_str()); -#endif - } - + // write to log file if (logging_destination != LOG_NONE && logging_destination != LOG_ONLY_TO_SYSTEM_DEBUG_LOG && @@ -449,12 +324,8 @@ LogMessage::~LogMessage() { // call InitLogging. This is not thread safe. See below InitLogMutex(); -#if defined(OS_WIN) DWORD r = ::WaitForSingleObject(log_mutex, INFINITE); DCHECK(r != WAIT_ABANDONED); -#elif defined(OS_POSIX) - pthread_mutex_lock(&log_mutex); -#endif } else { // use the lock if (!log_lock) { @@ -468,20 +339,12 @@ LogMessage::~LogMessage() { log_lock->Lock(); } -#if defined(OS_WIN) SetFilePointer(log_file, 0, 0, SEEK_END); DWORD num_written; WriteFile(log_file, (void*)str_newline.c_str(), (DWORD)str_newline.length(), &num_written, NULL); -#else - fprintf(log_file, "%s", str_newline.c_str()); -#endif if (lock_log_file == LOCK_LOG_FILE) { -#if defined(OS_WIN) ReleaseMutex(log_mutex); -#elif defined(OS_POSIX) - pthread_mutex_unlock(&log_mutex); -#endif } else { log_lock->Unlock(); } @@ -489,13 +352,9 @@ LogMessage::~LogMessage() { if (severity_ == LOG_FATAL) { // display a message or break into the debugger on a fatal error -#if defined(OS_WIN) if (::IsDebuggerPresent()) { __debugbreak(); - } - else -#endif - { + } else { if (log_assert_handler) { // make a copy of the string for the handler out of paranoia log_assert_handler(std::string(stream_.str())); @@ -504,16 +363,7 @@ LogMessage::~LogMessage() { // the debug message process DisplayDebugMessage(stream_.str()); // Crash the process to generate a dump. -#if defined(OS_WIN) __debugbreak(); -#elif defined(OS_POSIX) -#if defined(OS_MACOSX) - // TODO: when we have breakpad support, generate a breakpad dump, but - // until then, do not invoke the Apple crash reporter. - Debugger(); -#endif - exit(-1); -#endif } } } @@ -523,7 +373,7 @@ void CloseLogFile() { if (!log_file) return; - CloseFile(log_file); + CloseHandle(log_file); log_file = NULL; } @@ -533,5 +383,14 @@ std::ostream& operator<<(std::ostream& out, const wchar_t* wstr) { if (!wstr || !wstr[0]) return out; - return out << WideToUTF8(wstr).c_str(); + // compute the length of the buffer we'll need + int charcount = WideCharToMultiByte(CP_UTF8, 0, wstr, -1, + NULL, 0, NULL, NULL); + if (charcount == 0) + return out; + + // convert + scoped_array<char> buf(new char[charcount]); + WideCharToMultiByte(CP_UTF8, 0, wstr, -1, buf.get(), charcount, NULL, NULL); + return out << buf.get(); } diff --git a/base/logging.h b/base/logging.h index f380a9b..40c176f 100644 --- a/base/logging.h +++ b/base/logging.h @@ -143,10 +143,10 @@ enum OldFileDeletionState { DELETE_OLD_LOG_FILE, APPEND_TO_OLD_LOG_FILE }; // The default log file is initialized to "debug.log" in the application // directory. You probably don't want this, especially since the program // directory may not be writable on an enduser's system. -#if defined(OS_WIN) +#if defined(WIN32) void InitLogging(const wchar_t* log_file, LoggingDestination logging_dest, LogLockingState lock_log, OldFileDeletionState delete_old); -#elif defined(OS_POSIX) +#else // TODO(avi): do we want to do a unification of character types here? void InitLogging(const char* log_file, LoggingDestination logging_dest, LogLockingState lock_log, OldFileDeletionState delete_old); |