summaryrefslogtreecommitdiff
path: root/cpp/demo/Ice/multicast/Server.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'cpp/demo/Ice/multicast/Server.cpp')
-rw-r--r--cpp/demo/Ice/multicast/Server.cpp88
1 files changed, 88 insertions, 0 deletions
diff --git a/cpp/demo/Ice/multicast/Server.cpp b/cpp/demo/Ice/multicast/Server.cpp
new file mode 100644
index 00000000000..d5d10f5111a
--- /dev/null
+++ b/cpp/demo/Ice/multicast/Server.cpp
@@ -0,0 +1,88 @@
+// **********************************************************************
+//
+// 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 <Ice/Ice.h>
+
+#include <Discovery.h>
+#include <Hello.h>
+
+using namespace std;
+using namespace Demo;
+
+class HelloI : public Hello
+{
+public:
+
+ virtual void
+ sayHello(const Ice::Current&)
+ {
+ cout << "Hello World!" << endl;
+ }
+};
+
+class DiscoverI : public Discover
+{
+public:
+
+ DiscoverI(const Ice::ObjectPrx& obj) :
+ _obj(obj)
+ {
+ }
+
+ virtual void
+ lookup(const DiscoverReplyPrx& reply, const Ice::Current&)
+ {
+ try
+ {
+ reply->reply(_obj);
+ }
+ catch(const Ice::LocalException&)
+ {
+ // Ignore
+ }
+ }
+
+private:
+
+ const Ice::ObjectPrx _obj;
+};
+
+class HelloServer : public Ice::Application
+{
+public:
+
+ virtual int run(int, char*[]);
+};
+
+int
+main(int argc, char* argv[])
+{
+ HelloServer app;
+ return app.main(argc, argv, "config.server");
+}
+
+int
+HelloServer::run(int argc, char* argv[])
+{
+ Ice::StringSeq args = Ice::argsToStringSeq(argc, argv);
+ args = communicator()->getProperties()->parseCommandLineOptions("Discover", args);
+
+ Ice::ObjectAdapterPtr adapter = communicator()->createObjectAdapter("Hello");
+ Ice::ObjectAdapterPtr discoverAdapter = communicator()->createObjectAdapter("Discover");
+
+ Ice::ObjectPrx hello = adapter->addWithUUID(new HelloI);
+ DiscoverPtr d = new DiscoverI(hello);
+ discoverAdapter->add(d, communicator()->stringToIdentity("discover"));
+
+ discoverAdapter->activate();
+ adapter->activate();
+
+ communicator()->waitForShutdown();
+ return EXIT_SUCCESS;
+}