summaryrefslogtreecommitdiff
path: root/java/demo/Ice/session/ReapThread.java
diff options
context:
space:
mode:
authorMatthew Newhook <matthew@zeroc.com>2005-05-05 01:56:38 +0000
committerMatthew Newhook <matthew@zeroc.com>2005-05-05 01:56:38 +0000
commit7230719a9b53afb96280f6a26d8bbc7110ccba7a (patch)
treecb75e74e8c2a1a1503dcbd20ffd9aaac09856d33 /java/demo/Ice/session/ReapThread.java
parentfix menu message. (diff)
downloadice-7230719a9b53afb96280f6a26d8bbc7110ccba7a.tar.bz2
ice-7230719a9b53afb96280f6a26d8bbc7110ccba7a.tar.xz
ice-7230719a9b53afb96280f6a26d8bbc7110ccba7a.zip
added missing file.
Diffstat (limited to 'java/demo/Ice/session/ReapThread.java')
-rw-r--r--java/demo/Ice/session/ReapThread.java101
1 files changed, 101 insertions, 0 deletions
diff --git a/java/demo/Ice/session/ReapThread.java b/java/demo/Ice/session/ReapThread.java
new file mode 100644
index 00000000000..2b5e22778d7
--- /dev/null
+++ b/java/demo/Ice/session/ReapThread.java
@@ -0,0 +1,101 @@
+// **********************************************************************
+//
+// Copyright (c) 2003-2005 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.*;
+
+class ReapThread extends Thread
+{
+ static class SessionProxyPair
+ {
+ SessionProxyPair(Demo.SessionPrx p, SessionI s)
+ {
+ proxy = p;
+ session = s;
+ }
+
+ Demo.SessionPrx proxy;
+ SessionI session;
+ };
+
+ synchronized public void
+ run()
+ {
+ while(!_terminated)
+ {
+ try
+ {
+ wait(_timeout);
+ }
+ catch(InterruptedException e)
+ {
+ }
+
+ if(!_terminated)
+ {
+ java.util.Iterator p = _sessions.iterator();
+ while(p.hasNext())
+ {
+ SessionProxyPair s = (SessionProxyPair)p.next();
+ try
+ {
+ //
+ // Session destruction may take time in a
+ // real-world example. Therefore the current time
+ // is computed for each iteration.
+ //
+ if((System.currentTimeMillis() - s.session.timestamp()) > _timeout)
+ {
+ String name = s.proxy.getName();
+ s.proxy.destroy();
+ System.out.println("The session " + name + " has timed out.");
+ p.remove();
+ }
+ }
+ catch(Ice.ObjectNotExistException e)
+ {
+ p.remove();
+ }
+ }
+ }
+ }
+ }
+
+ synchronized public void
+ terminate()
+ {
+ _terminated = true;
+ notify();
+
+ java.util.Iterator p = _sessions.iterator();
+ while(p.hasNext())
+ {
+ SessionProxyPair s = (SessionProxyPair)p.next();
+ try
+ {
+ s.proxy.destroy();
+ }
+ catch(Ice.LocalException e)
+ {
+ // Ignore.
+ }
+ }
+
+ _sessions.clear();
+ }
+
+ synchronized public void
+ add(SessionPrx proxy, SessionI session)
+ {
+ _sessions.add(new SessionProxyPair(proxy, session));
+ }
+
+ private final long _timeout = 10 * 1000; // 10 seconds.
+ private boolean _terminated = false;
+ private java.util.List _sessions = new java.util.LinkedList();
+}