diff options
Diffstat (limited to 'ACE/TAO/DevGuideExamples/Multithreading/ThreadPerConnection/MessengerClient.cpp')
-rw-r--r-- | ACE/TAO/DevGuideExamples/Multithreading/ThreadPerConnection/MessengerClient.cpp | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/ACE/TAO/DevGuideExamples/Multithreading/ThreadPerConnection/MessengerClient.cpp b/ACE/TAO/DevGuideExamples/Multithreading/ThreadPerConnection/MessengerClient.cpp new file mode 100644 index 00000000000..b4269742a43 --- /dev/null +++ b/ACE/TAO/DevGuideExamples/Multithreading/ThreadPerConnection/MessengerClient.cpp @@ -0,0 +1,71 @@ +// $Id$ + +#include "MessengerC.h" +#include "ace/Get_Opt.h" +#include <iostream> + +const ACE_TCHAR *ior = ACE_TEXT ("file://test.ior"); + +int +parse_args (int argc, ACE_TCHAR *argv[]) +{ + ACE_Get_Opt get_opts (argc, argv, ACE_TEXT("k:")); + int c; + + while ((c = get_opts ()) != -1) + switch (c) + { + case 'k': + ior = get_opts.opt_arg (); + break; + + case '?': + default: + ACE_ERROR_RETURN ((LM_ERROR, + "usage: %s " + "-k <ior> " + "\n", + argv [0]), + -1); + } + // Indicates successful parsing of the command line + return 0; +} + +int ACE_TMAIN (int argc, ACE_TCHAR* argv[]) +{ + try { + // Initialize the ORB. + CORBA::ORB_var orb = CORBA::ORB_init( argc, argv ); + + if (parse_args (argc, argv) != 0) + return 1; + + // Read and destringify the Messenger object's IOR. + CORBA::Object_var obj = orb->string_to_object(ior); + if( CORBA::is_nil( obj.in() ) ) { + std::cerr << "Could not get Messenger IOR." << std::endl; + return 1; + } + + // Narrow the IOR to a Messenger object reference. + Messenger_var messenger = Messenger::_narrow( obj.in() ); + if( CORBA::is_nil( messenger.in() ) ) { + std::cerr << "IOR was not a Messenger object reference." << std::endl; + return 1; + } + + // Send a message the the Messenger object. + CORBA::String_var message = CORBA::string_dup( "Hello!" ); + messenger->send_message( "TAO User", "TAO Test", message.inout() ); + + // Print the Messenger's reply. + std::cout << "Reply: " << message.in() << std::endl; + } + catch(const CORBA::Exception& ex) { + std::cerr << "CORBA exception: " << ex << std::endl; + return 1; + } + + return 0; +} |