summaryrefslogtreecommitdiff
path: root/java/demo/Ice/async/Consumer.java
diff options
context:
space:
mode:
authorDwayne Boone <dwayne@zeroc.com>2006-11-16 17:31:10 +0000
committerDwayne Boone <dwayne@zeroc.com>2006-11-16 17:31:10 +0000
commit51b5c23482df36ac145c82d58e9ccdef9728f935 (patch)
tree15a62e43b132ebdd721ec13a0d6b664133d00e3a /java/demo/Ice/async/Consumer.java
parentRemove debug code (diff)
downloadice-51b5c23482df36ac145c82d58e9ccdef9728f935.tar.bz2
ice-51b5c23482df36ac145c82d58e9ccdef9728f935.tar.xz
ice-51b5c23482df36ac145c82d58e9ccdef9728f935.zip
Added async demo
Diffstat (limited to 'java/demo/Ice/async/Consumer.java')
-rw-r--r--java/demo/Ice/async/Consumer.java107
1 files changed, 107 insertions, 0 deletions
diff --git a/java/demo/Ice/async/Consumer.java b/java/demo/Ice/async/Consumer.java
new file mode 100644
index 00000000000..c3019837324
--- /dev/null
+++ b/java/demo/Ice/async/Consumer.java
@@ -0,0 +1,107 @@
+// **********************************************************************
+//
+// 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.
+//
+// **********************************************************************
+
+import Demo.*;
+
+public class Consumer extends Ice.Application
+{
+ public class AMI_Queue_getI extends AMI_Queue_get
+ {
+ public void ice_response(String message)
+ {
+ System.out.println(message);
+ }
+
+ public void ice_exception(Ice.LocalException ex)
+ {
+ ex.printStackTrace();
+ }
+ }
+
+ private static void
+ menu()
+ {
+ System.out.println(
+ "usage:\n" +
+ "g: get a message\n" +
+ "x: exit\n" +
+ "?: help\n");
+ }
+
+ public int
+ run(String[] args)
+ {
+ Ice.Properties properties = communicator().getProperties();
+ final String proxyProperty = "Queue.Proxy";
+ String proxy = properties.getProperty(proxyProperty);
+ if(proxy.length() == 0)
+ {
+ System.err.println("property `" + proxyProperty + "' not set");
+ return 1;
+ }
+
+ QueuePrx queue = QueuePrxHelper.checkedCast(communicator().stringToProxy(proxy));
+ if(queue == null)
+ {
+ System.err.println("invalid proxy");
+ return 1;
+ }
+
+ 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("g"))
+ {
+ queue.get_async(new AMI_Queue_getI());
+ }
+ else if(line.equals("x"))
+ {
+ // Nothing to do
+ }
+ 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)
+ {
+ Consumer app = new Consumer();
+ int status = app.main("Consumer", args, "config.client");
+ System.exit(status);
+ }
+}