// ********************************************************************** // // Copyright (c) 2003-2011 ZeroC, Inc. All rights reserved. // // This copy of Ice is licensed to you under the terms described in the // ICE_LICENSE file included in this distribution. // // ********************************************************************** #include #include #include using namespace std; LogI::LogI() : _hwnd(0) { } void LogI::print(const string& msg) { string s = msg; string::size_type idx = 0; while((idx = s.find("\n", idx)) != string::npos) { s.replace(idx, 1, "\r\n "); idx += 3; } message(s); } void LogI::trace(const string& category, const string& msg) { string s = "[ " + category + ": " + msg + " ]"; string::size_type idx = 0; while((idx = s.find("\n", idx)) != string::npos) { s.replace(idx, 1, "\r\n "); idx += 3; } message(s); } void LogI::warning(const string& msg) { message("warning: " + msg); } void LogI::error(const string& msg) { message("error: " + msg); } Ice::LoggerPtr LogI::cloneWithPrefix(const string&) { return this; } void LogI::message(const string& msg) { string line = msg + "\r\n"; if(_hwnd) { post(line); } else { _buffer.append(line); } } void LogI::setHandle(HWND hwnd) { _hwnd = hwnd; if(_hwnd != 0 && !_buffer.empty()) { post(_buffer); _buffer.clear(); } } void LogI::post(const string& data) { assert(_hwnd != 0); char* text = new char[data.size()+1]; strcpy(text, data.c_str()); ::PostMessage(_hwnd, WM_USER, (WPARAM)FALSE, (LPARAM)text); }