summaryrefslogtreecommitdiff
path: root/cppe/demo/IceE/callback/Client.cpp
diff options
context:
space:
mode:
authorDwayne Boone <dwayne@zeroc.com>2005-07-05 11:09:55 +0000
committerDwayne Boone <dwayne@zeroc.com>2005-07-05 11:09:55 +0000
commit9b8cc712d4a41d71840416776bc94ee8485bb9b3 (patch)
tree7d467fdd6a66bc2b5878d82070d45adbd5c20414 /cppe/demo/IceE/callback/Client.cpp
parentcleaning the cache method out of ReferenceFactory (diff)
downloadice-9b8cc712d4a41d71840416776bc94ee8485bb9b3.tar.bz2
ice-9b8cc712d4a41d71840416776bc94ee8485bb9b3.tar.xz
ice-9b8cc712d4a41d71840416776bc94ee8485bb9b3.zip
Changed Ice to IceE EVERYWHERE!!!
Diffstat (limited to 'cppe/demo/IceE/callback/Client.cpp')
-rw-r--r--cppe/demo/IceE/callback/Client.cpp161
1 files changed, 161 insertions, 0 deletions
diff --git a/cppe/demo/IceE/callback/Client.cpp b/cppe/demo/IceE/callback/Client.cpp
new file mode 100644
index 00000000000..13ed6f79d2d
--- /dev/null
+++ b/cppe/demo/IceE/callback/Client.cpp
@@ -0,0 +1,161 @@
+// **********************************************************************
+//
+// Copyright (c) 2003-2005 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 <IceE/IceE.h>
+#include <Callback.h>
+
+using namespace std;
+using namespace IceE;
+using namespace Demo;
+
+class CallbackReceiverI : public CallbackReceiver
+{
+public:
+
+ virtual void callback(const Current&)
+ {
+ printf("received callback\n");
+ }
+};
+
+
+void
+menu()
+{
+ printf("usage:\n");
+ printf("t: send callback as twoway\n");
+ printf("o: send callback as oneway\n");
+ printf("O: send callback as batch oneway\n");
+ printf("f: flush all batch requests\n");
+ printf("s: shutdown server\n");
+ printf("x: exit\n");
+ printf("?: help\n");
+}
+
+int
+run(int argc, char* argv[], const IceE::CommunicatorPtr& communicator)
+{
+ PropertiesPtr properties = communicator->getProperties();
+ const char* proxyProperty = "Callback.Client.CallbackServer";
+ std::string proxy = properties->getProperty(proxyProperty);
+ if(proxy.empty())
+ {
+ fprintf(stderr, "%s: property `%s' not set\n", argv[0], proxyProperty);
+ return EXIT_FAILURE;
+ }
+
+ ObjectPrx base = communicator->stringToProxy(proxy);
+ CallbackPrx twoway = CallbackPrx::checkedCast(base->ice_twoway()->ice_timeout(-1));
+ if(!twoway)
+ {
+ fprintf(stderr, "%s: invalid proxy\n", argv[0]);
+ return EXIT_FAILURE;
+ }
+ CallbackPrx oneway = CallbackPrx::uncheckedCast(twoway->ice_oneway());
+ CallbackPrx batchOneway = CallbackPrx::uncheckedCast(twoway->ice_batchOneway());
+
+ ObjectAdapterPtr adapter = communicator->createObjectAdapter("Callback.Client");
+ adapter->add(new CallbackReceiverI, stringToIdentity("callbackReceiver"));
+ adapter->activate();
+
+ CallbackReceiverPrx twowayR = CallbackReceiverPrx::uncheckedCast(
+ adapter->createProxy(stringToIdentity("callbackReceiver")));
+ CallbackReceiverPrx onewayR = CallbackReceiverPrx::uncheckedCast(twowayR->ice_oneway());
+
+ menu();
+
+ char c;
+ do
+ {
+ try
+ {
+ printf("==> ");
+ do
+ {
+ c = getchar();
+ }
+ while(c != EOF && c == '\n');
+ if(c == 't')
+ {
+ twoway->initiateCallback(twowayR);
+ }
+ else if(c == 'o')
+ {
+ oneway->initiateCallback(onewayR);
+ }
+ else if(c == 'O')
+ {
+ batchOneway->initiateCallback(onewayR);
+ }
+ else if(c == 'f')
+ {
+ communicator->flushBatchRequests();
+ }
+ else if(c == 's')
+ {
+ twoway->shutdown();
+ }
+ else if(c == 'x')
+ {
+ // Nothing to do
+ }
+ else if(c == '?')
+ {
+ menu();
+ }
+ else
+ {
+ printf("unknown command `%c'\n", c);
+ menu();
+ }
+ }
+ catch(const Exception& ex)
+ {
+ fprintf(stderr, "%s\n", ex.toString().c_str());
+ }
+ }
+ while(c != EOF && c != 'x');
+
+ return EXIT_SUCCESS;
+}
+
+int
+main(int argc, char* argv[])
+{
+ int status;
+ IceE::CommunicatorPtr communicator;
+
+ try
+ {
+ IceE::PropertiesPtr properties = IceE::createProperties();
+ properties->load("config");
+ communicator = IceE::initializeWithProperties(argc, argv, properties);
+ status = run(argc, argv, communicator);
+ }
+ catch(const IceE::Exception& ex)
+ {
+ fprintf(stderr, "%s\n", ex.toString().c_str());
+ status = EXIT_FAILURE;
+ }
+
+ if(communicator)
+ {
+ try
+ {
+ communicator->destroy();
+ }
+ catch(const IceE::Exception& ex)
+ {
+ fprintf(stderr, "%s\n", ex.toString().c_str());
+ status = EXIT_FAILURE;
+ }
+ }
+
+ return status;
+}