summaryrefslogtreecommitdiff
path: root/java/demo/Ice/plugin/Client.java
diff options
context:
space:
mode:
authorDwayne Boone <dwayne@zeroc.com>2009-04-21 15:59:33 -0230
committerDwayne Boone <dwayne@zeroc.com>2009-04-21 15:59:33 -0230
commitae58d9f09835de8d57e5ad27d9b33ffbcd0d5092 (patch)
treef96fbf2fd2643bf02c64931dedfd3b6772169705 /java/demo/Ice/plugin/Client.java
parentBug 2504 - added getPlugins method to PluginManager (diff)
downloadice-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.java153
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);
+ }
+}
+