diff options
author | Dwayne Boone <dwayne@zeroc.com> | 2009-04-21 15:59:33 -0230 |
---|---|---|
committer | Dwayne Boone <dwayne@zeroc.com> | 2009-04-21 15:59:33 -0230 |
commit | ae58d9f09835de8d57e5ad27d9b33ffbcd0d5092 (patch) | |
tree | f96fbf2fd2643bf02c64931dedfd3b6772169705 /java/demo/Ice/plugin/Client.java | |
parent | Bug 2504 - added getPlugins method to PluginManager (diff) | |
download | ice-ae58d9f09835de8d57e5ad27d9b33ffbcd0d5092.tar.bz2 ice-ae58d9f09835de8d57e5ad27d9b33ffbcd0d5092.tar.xz ice-ae58d9f09835de8d57e5ad27d9b33ffbcd0d5092.zip |
Bug 3912 - added logger plugin demo
Diffstat (limited to 'java/demo/Ice/plugin/Client.java')
-rw-r--r-- | java/demo/Ice/plugin/Client.java | 153 |
1 files changed, 153 insertions, 0 deletions
diff --git a/java/demo/Ice/plugin/Client.java b/java/demo/Ice/plugin/Client.java new file mode 100644 index 00000000000..a0a2f4f2f10 --- /dev/null +++ b/java/demo/Ice/plugin/Client.java @@ -0,0 +1,153 @@ +// ********************************************************************** +// +// Copyright (c) 2003-2009 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. +// +// ********************************************************************** + +import Demo.*; + +public class Client extends Ice.Application +{ + class ShutdownHook extends Thread + { + public void + run() + { + try + { + communicator().destroy(); + } + catch(Ice.LocalException ex) + { + ex.printStackTrace(); + } + } + } + + private static void + menu() + { + System.out.println( + "usage:\n" + + "t: send greeting as twoway\n" + + "o: send greeting as oneway\n" + + "O: send greeting as batch oneway\n" + + "d: send greeting as datagram\n" + + "D: send greeting as batch datagram\n" + + "f: flush all batch requests\n" + + "s: shutdown server\n" + + "x: exit\n" + + "?: help\n"); + } + + public int + run(String[] args) + { + if(args.length > 0) + { + System.err.println(appName() + ": too many arguments"); + return 1; + } + + // + // Since this is an interactive demo we want to clear the + // Application installed interrupt callback and install our + // own shutdown hook. + // + setInterruptHook(new ShutdownHook()); + + HelloPrx twoway = HelloPrxHelper.checkedCast(communicator().propertyToProxy("Hello.Proxy")); + if(twoway == null) + { + System.err.println("invalid proxy"); + return 1; + } + HelloPrx oneway = (HelloPrx)twoway.ice_oneway(); + HelloPrx batchOneway = (HelloPrx)twoway.ice_batchOneway(); + HelloPrx datagram = (HelloPrx)twoway.ice_datagram(); + HelloPrx batchDatagram = (HelloPrx)twoway.ice_batchDatagram(); + + menu(); + + java.io.BufferedReader in = new java.io.BufferedReader(new java.io.InputStreamReader(System.in)); + + String line = null; + do + { + try + { + System.out.print("==> "); + System.out.flush(); + line = in.readLine(); + if(line == null) + { + break; + } + if(line.equals("t")) + { + twoway.sayHello(); + } + else if(line.equals("o")) + { + oneway.sayHello(); + } + else if(line.equals("O")) + { + batchOneway.sayHello(); + } + else if(line.equals("d")) + { + datagram.sayHello(); + } + else if(line.equals("D")) + { + batchDatagram.sayHello(); + } + else if(line.equals("f")) + { + communicator().flushBatchRequests(); + } + else if(line.equals("s")) + { + twoway.shutdown(); + } + else if(line.equals("x")) + { + // Nothing to do + } + else if(line.equals("?")) + { + menu(); + } + else + { + System.out.println("unknown command `" + line + "'"); + menu(); + } + } + catch(java.io.IOException ex) + { + ex.printStackTrace(); + } + catch(Ice.LocalException ex) + { + ex.printStackTrace(); + } + } + while(!line.equals("x")); + + return 0; + } + + public static void + main(String[] args) + { + Client app = new Client(); + int status = app.main("Client", args, "config.client"); + System.exit(status); + } +} + |