diff options
author | Matthew Newhook <matthew@zeroc.com> | 2015-03-18 12:58:16 -0230 |
---|---|---|
committer | Matthew Newhook <matthew@zeroc.com> | 2015-03-18 12:58:16 -0230 |
commit | 9b7668c7c92cf9cb311fe444cdddb489cd2a219d (patch) | |
tree | 5016567c58c81f5654e9d01935e199c6bf4761d2 /cpp/demo/Ice/invoke/Client.cpp | |
parent | VS add-in & build updates: (diff) | |
download | ice-9b7668c7c92cf9cb311fe444cdddb489cd2a219d.tar.bz2 ice-9b7668c7c92cf9cb311fe444cdddb489cd2a219d.tar.xz ice-9b7668c7c92cf9cb311fe444cdddb489cd2a219d.zip |
Removed demos.
Moved demoscript to distribution.
Diffstat (limited to 'cpp/demo/Ice/invoke/Client.cpp')
-rw-r--r-- | cpp/demo/Ice/invoke/Client.cpp | 348 |
1 files changed, 0 insertions, 348 deletions
diff --git a/cpp/demo/Ice/invoke/Client.cpp b/cpp/demo/Ice/invoke/Client.cpp deleted file mode 100644 index c68a6bde666..00000000000 --- a/cpp/demo/Ice/invoke/Client.cpp +++ /dev/null @@ -1,348 +0,0 @@ -// ********************************************************************** -// -// Copyright (c) 2003-2015 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 <Printer.h> - -using namespace std; -using namespace Demo; - -static ostream& -operator<<(ostream& out, Demo::Color c) -{ - switch(c) - { - case Demo::red: - out << "red"; - break; - case Demo::green: - out << "green"; - break; - case Demo::blue: - out << "blue"; - break; - } - return out; -} - -class InvokeClient : public Ice::Application -{ -public: - - InvokeClient(); - virtual int run(int, char*[]); - -private: - - void usage(const string&); - void menu(); -}; - -int -main(int argc, char* argv[]) -{ - InvokeClient app; - return app.main(argc, argv, "config.client"); -} - -InvokeClient::InvokeClient() : - // - // Since this is an interactive demo we don't want any signal - // handling. - // - Ice::Application(Ice::NoSignalHandling) -{ -} - -int -InvokeClient::run(int argc, char*[]) -{ - if(argc > 1) - { - cerr << appName() << ": too many arguments" << endl; - return EXIT_FAILURE; - } - - Ice::ObjectPrx obj = communicator()->propertyToProxy("Printer.Proxy"); - - menu(); - - char ch = 'x'; - do - { - try - { - cout << "==> "; - cin >> ch; - if(ch == '1') - { - // - // Marshal the in parameter. - // - Ice::ByteSeq inParams, outParams; - Ice::OutputStreamPtr out = Ice::createOutputStream(communicator()); - out->startEncapsulation(); - out->write("The streaming API works!"); - out->endEncapsulation(); - out->finished(inParams); - - // - // Invoke operation. - // - if(!obj->ice_invoke("printString", Ice::Normal, inParams, outParams)) - { - cout << "Unknown user exception" << endl; - } - } - else if(ch == '2') - { - // - // Marshal the in parameter. - // - Ice::ByteSeq inParams, outParams; - Ice::OutputStreamPtr out = Ice::createOutputStream(communicator()); - out->startEncapsulation(); - Demo::StringSeq arr; - arr.push_back("The"); - arr.push_back("streaming"); - arr.push_back("API"); - arr.push_back("works!"); - out->write(arr); - out->endEncapsulation(); - out->finished(inParams); - - // - // Invoke operation. - // - if(!obj->ice_invoke("printStringSequence", Ice::Normal, inParams, outParams)) - { - cout << "Unknown user exception" << endl; - } - } - else if(ch == '3') - { - // - // Marshal the in parameter. - // - Ice::ByteSeq inParams, outParams; - Ice::OutputStreamPtr out = Ice::createOutputStream(communicator()); - out->startEncapsulation(); - Demo::StringDict dict; - dict["The"] = "streaming"; - dict["API"] = "works!"; - out->write(dict); - out->endEncapsulation(); - out->finished(inParams); - - // - // Invoke operation. - // - if(!obj->ice_invoke("printDictionary", Ice::Normal, inParams, outParams)) - { - cout << "Unknown user exception" << endl; - } - } - else if(ch == '4') - { - // - // Marshal the in parameter. - // - Ice::ByteSeq inParams, outParams; - Ice::OutputStreamPtr out = Ice::createOutputStream(communicator()); - out->startEncapsulation(); - out->write(Demo::green); - out->endEncapsulation(); - out->finished(inParams); - - // - // Invoke operation. - // - if(!obj->ice_invoke("printEnum", Ice::Normal, inParams, outParams)) - { - cout << "Unknown user exception" << endl; - } - } - else if(ch == '5') - { - // - // Marshal the in parameter. - // - Ice::ByteSeq inParams, outParams; - Ice::OutputStreamPtr out = Ice::createOutputStream(communicator()); - out->startEncapsulation(); - Demo::Structure s; - s.name = "red"; - s.value = Demo::red; - out->write(s); - out->endEncapsulation(); - out->finished(inParams); - - // - // Invoke operation. - // - if(!obj->ice_invoke("printStruct", Ice::Normal, inParams, outParams)) - { - cout << "Unknown user exception" << endl; - } - } - else if(ch == '6') - { - // - // Marshal the in parameter. - // - Ice::ByteSeq inParams, outParams; - Ice::OutputStreamPtr out = Ice::createOutputStream(communicator()); - out->startEncapsulation(); - Demo::StructureSeq arr; - arr.push_back(Demo::Structure()); - arr.back().name = "red"; - arr.back().value = Demo::red; - arr.push_back(Demo::Structure()); - arr.back().name = "green"; - arr.back().value = Demo::green; - arr.push_back(Demo::Structure()); - arr.back().name = "blue"; - arr.back().value = Demo::blue; - out->write(arr); - out->endEncapsulation(); - out->finished(inParams); - - // - // Invoke operation. - // - if(!obj->ice_invoke("printStructSequence", Ice::Normal, inParams, outParams)) - { - cout << "Unknown user exception" << endl; - } - } - else if(ch == '7') - { - // - // Marshal the in parameter. - // - Ice::ByteSeq inParams, outParams; - Ice::OutputStreamPtr out = Ice::createOutputStream(communicator()); - out->startEncapsulation(); - Demo::CPtr c = new Demo::C; - c->s.name = "blue"; - c->s.value = Demo::blue; - out->write(c); - out->writePendingObjects(); - out->endEncapsulation(); - out->finished(inParams); - - // - // Invoke operation. - // - if(!obj->ice_invoke("printClass", Ice::Normal, inParams, outParams)) - { - cout << "Unknown user exception" << endl; - } - } - else if(ch == '8') - { - // - // Invoke operation. - // - Ice::ByteSeq inParams, outParams; - if(!obj->ice_invoke("getValues", Ice::Normal, inParams, outParams)) - { - cout << "Unknown user exception" << endl; - continue; - } - - // - // Unmarshal the results. - // - Ice::InputStreamPtr in = Ice::createInputStream(communicator(), outParams); - in->startEncapsulation(); - Demo::CPtr c; - in->read(c); - string str; - in->read(str); - in->readPendingObjects(); - in->endEncapsulation(); - cout << "Got string `" << str << "' and class: s.name=" << c->s.name - << ", s.value=" << c->s.value << endl; - } - else if(ch == '9') - { - // - // Invoke operation. - // - Ice::ByteSeq inParams, outParams; - if(obj->ice_invoke("throwPrintFailure", Ice::Normal, inParams, outParams)) - { - cout << "Expected exception" << endl; - continue; - } - - Ice::InputStreamPtr in = Ice::createInputStream(communicator(), outParams); - in->startEncapsulation(); - try - { - in->throwException(); - } - catch(const Demo::PrintFailure&) - { - // Expected. - } - catch(const Ice::UserException&) - { - cout << "Unknown user exception" << endl; - } - in->endEncapsulation(); - } - else if(ch == 's') - { - Ice::ByteSeq inParams, outParams; - obj->ice_invoke("shutdown", Ice::Normal, inParams, outParams); - } - else if(ch == 'x') - { - // Nothing to do. - } - else if(ch == '?') - { - menu(); - } - else - { - cout << "unknown command `" << ch << "'" << endl; - menu(); - } - } - catch(const Ice::Exception& ex) - { - cerr << ex << endl; - } - } - while(cin.good() && ch != 'x'); - - return EXIT_SUCCESS; -} - -void -InvokeClient::menu() -{ - cout << - "usage:\n" - "1: print string\n" - "2: print string sequence\n" - "3: print dictionary\n" - "4: print enum\n" - "5: print struct\n" - "6: print struct sequence\n" - "7: print class\n" - "8: get values\n" - "9: throw exception\n" - "s: shutdown server\n" - "x: exit\n" - "?: help\n"; -} |