diff options
Diffstat (limited to 'cpp/demo/Ice/MFC/server/LogI.cpp')
-rw-r--r-- | cpp/demo/Ice/MFC/server/LogI.cpp | 101 |
1 files changed, 101 insertions, 0 deletions
diff --git a/cpp/demo/Ice/MFC/server/LogI.cpp b/cpp/demo/Ice/MFC/server/LogI.cpp new file mode 100644 index 00000000000..f092c40b83c --- /dev/null +++ b/cpp/demo/Ice/MFC/server/LogI.cpp @@ -0,0 +1,101 @@ +// ********************************************************************** +// +// 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 <IceUtil/DisableWarnings.h> +#include <stdafx.h> +#include <LogI.h> + +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); +} |