summaryrefslogtreecommitdiff
path: root/cpp/demo/Ice/plugin/LoggerI.cpp
diff options
context:
space:
mode:
authorDwayne Boone <dwayne@zeroc.com>2009-04-21 15:59:33 -0230
committerDwayne Boone <dwayne@zeroc.com>2009-04-21 15:59:33 -0230
commitae58d9f09835de8d57e5ad27d9b33ffbcd0d5092 (patch)
treef96fbf2fd2643bf02c64931dedfd3b6772169705 /cpp/demo/Ice/plugin/LoggerI.cpp
parentBug 2504 - added getPlugins method to PluginManager (diff)
downloadice-ae58d9f09835de8d57e5ad27d9b33ffbcd0d5092.tar.bz2
ice-ae58d9f09835de8d57e5ad27d9b33ffbcd0d5092.tar.xz
ice-ae58d9f09835de8d57e5ad27d9b33ffbcd0d5092.zip
Bug 3912 - added logger plugin demo
Diffstat (limited to 'cpp/demo/Ice/plugin/LoggerI.cpp')
-rw-r--r--cpp/demo/Ice/plugin/LoggerI.cpp57
1 files changed, 57 insertions, 0 deletions
diff --git a/cpp/demo/Ice/plugin/LoggerI.cpp b/cpp/demo/Ice/plugin/LoggerI.cpp
new file mode 100644
index 00000000000..d3eeefc4d01
--- /dev/null
+++ b/cpp/demo/Ice/plugin/LoggerI.cpp
@@ -0,0 +1,57 @@
+// **********************************************************************
+//
+// Copyright (c) 2003-2009 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 <Ice/Ice.h>
+
+using namespace std;
+
+namespace
+{
+
+class LoggerI : public Ice::Logger
+{
+public:
+
+ virtual void
+ print(const string& message)
+ {
+ cout << "PRINT: " << message << endl;
+ }
+
+ virtual void
+ trace(const string& category, const string& message)
+ {
+ cout << "TRACE(" << category << "): " << message << endl;
+ }
+
+ virtual void
+ warning(const string& message)
+ {
+ cout << "WARNING: " << message << endl;
+ }
+
+ virtual void
+ error(const string& message)
+ {
+ cout << "ERROR: " << message << endl;
+ }
+};
+
+};
+
+extern "C"
+{
+
+ICE_DECLSPEC_EXPORT ::Ice::Plugin*
+createLogger(const Ice::CommunicatorPtr& communicator, const string& name, const Ice::StringSeq& args)
+{
+ return new Ice::LoggerPlugin(communicator, new LoggerI);
+}
+
+}