summaryrefslogtreecommitdiff
path: root/cpp/demo/Ice/converter/Client.cpp
diff options
context:
space:
mode:
authorDwayne Boone <dwayne@zeroc.com>2006-05-16 17:02:30 +0000
committerDwayne Boone <dwayne@zeroc.com>2006-05-16 17:02:30 +0000
commit8e923a0c6a7dec2e85d53fadb6f920ce01061b7f (patch)
tree2fe5421c1f0700e59c96320b6c998171ea44581d /cpp/demo/Ice/converter/Client.cpp
parentadding IceSSL.Random for Java (diff)
downloadice-8e923a0c6a7dec2e85d53fadb6f920ce01061b7f.tar.bz2
ice-8e923a0c6a7dec2e85d53fadb6f920ce01061b7f.tar.xz
ice-8e923a0c6a7dec2e85d53fadb6f920ce01061b7f.zip
Added string converter demo
Diffstat (limited to 'cpp/demo/Ice/converter/Client.cpp')
-rw-r--r--cpp/demo/Ice/converter/Client.cpp162
1 files changed, 162 insertions, 0 deletions
diff --git a/cpp/demo/Ice/converter/Client.cpp b/cpp/demo/Ice/converter/Client.cpp
new file mode 100644
index 00000000000..761a4746e3b
--- /dev/null
+++ b/cpp/demo/Ice/converter/Client.cpp
@@ -0,0 +1,162 @@
+// **********************************************************************
+//
+// Copyright (c) 2003-2006 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/Application.h>
+#include <Hello.h>
+#include <StringConverterI.h>
+#include <IceUtil/StringUtil.h>
+
+using namespace std;
+using namespace Demo;
+
+void
+menu()
+{
+ cout <<
+ "usage:\n"
+ "t: send greeting with conversion\n"
+ "u: send greeting without conversion\n"
+ "s: shutdown server\n"
+ "x: exit\n"
+ "?: help\n";
+}
+
+int
+run(int argc, char* argv[], const Ice::CommunicatorPtr& communicator1, const Ice::CommunicatorPtr& communicator2)
+{
+ Ice::PropertiesPtr properties = communicator1->getProperties();
+ const char* proxyProperty = "Hello.Proxy";
+ string proxy = properties->getProperty(proxyProperty);
+ if(proxy.empty())
+ {
+ cerr << argv[0] << ": property `" << proxyProperty << "' not set" << endl;
+ return EXIT_FAILURE;
+ }
+
+ HelloPrx hello1 = HelloPrx::checkedCast(communicator1->stringToProxy(proxy));
+ if(!hello1)
+ {
+ cerr << argv[0] << ": invalid proxy" << endl;
+ return EXIT_FAILURE;
+ }
+
+ HelloPrx hello2 = HelloPrx::checkedCast(communicator2->stringToProxy(proxy));
+ if(!hello2)
+ {
+ cerr << argv[0] << ": invalid proxy" << endl;
+ return EXIT_FAILURE;
+ }
+
+ menu();
+
+ string uber = "\374ber";
+
+ char c;
+ do
+ {
+ try
+ {
+ cout << "==> ";
+ cin >> c;
+ if(c == 't')
+ {
+ string ret = hello1->sayHello(uber);
+ cout << "Received: \"" << IceUtil::escapeString(ret, "") << '\"' << endl;
+ }
+ else if(c == 'u')
+ {
+ string ret = hello2->sayHello(uber);
+ cout << "Received: \"" << IceUtil::escapeString(ret, "") << '\"' << endl;
+ }
+ else if(c == 's')
+ {
+ hello1->shutdown();
+ }
+ else if(c == 'x')
+ {
+ // Nothing to do
+ }
+ else if(c == '?')
+ {
+ menu();
+ }
+ else
+ {
+ cout << "unknown command `" << c << "'" << endl;
+ menu();
+ }
+ }
+ catch(const Ice::Exception& ex)
+ {
+ cerr << ex << endl;
+ }
+ }
+ while(cin.good() && c != 'x');
+
+ return EXIT_SUCCESS;
+}
+
+int
+main(int argc, char* argv[])
+{
+ int status;
+ Ice::CommunicatorPtr communicator1;
+ Ice::CommunicatorPtr communicator2;
+
+ try
+ {
+ //
+ // Create two communicators, one with string converter configured
+ // and one without.
+ //
+ Ice::InitializationData initData;
+ initData.stringConverter = new StringConverterI();
+ initData.properties = Ice::createProperties();
+ initData.properties->load("config.client");
+ communicator1 = Ice::initialize(argc, argv, initData);
+
+ communicator2 = Ice::initialize(argc, argv);
+
+ status = run(argc, argv, communicator1, communicator2);
+ }
+ catch(const Ice::Exception& ex)
+ {
+ cerr << ex << endl;
+ status = EXIT_FAILURE;
+ }
+
+ if(communicator1)
+ {
+ try
+ {
+ communicator1->destroy();
+ }
+ catch(const Ice::Exception& ex)
+ {
+ cerr << ex << endl;
+ status = EXIT_FAILURE;
+ }
+ }
+
+ if(communicator2)
+ {
+ try
+ {
+ communicator2->destroy();
+ }
+ catch(const Ice::Exception& ex)
+ {
+ cerr << ex << endl;
+ status = EXIT_FAILURE;
+ }
+ }
+
+ return status;
+}
+