summaryrefslogtreecommitdiff
path: root/cpp/demo/Ice/MFC/server/LogI.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'cpp/demo/Ice/MFC/server/LogI.cpp')
-rw-r--r--cpp/demo/Ice/MFC/server/LogI.cpp101
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);
+}