summaryrefslogtreecommitdiff
path: root/java/src/IceInternal/LocatorManager.java
diff options
context:
space:
mode:
authorMatthew Newhook <matthew@zeroc.com>2014-10-20 11:40:05 -0230
committerMatthew Newhook <matthew@zeroc.com>2014-10-20 11:40:05 -0230
commitb51469b41167fb86ae2059a15cf0475c53fdda7b (patch)
treefc85d6ca2efd89c67e1e4e7438f437c3e08313f4 /java/src/IceInternal/LocatorManager.java
parentFixed (ICE-5695) - IceSSL: misleading exception (diff)
downloadice-b51469b41167fb86ae2059a15cf0475c53fdda7b.tar.bz2
ice-b51469b41167fb86ae2059a15cf0475c53fdda7b.tar.xz
ice-b51469b41167fb86ae2059a15cf0475c53fdda7b.zip
Down with ant. From the gradle to the grave.
Diffstat (limited to 'java/src/IceInternal/LocatorManager.java')
-rw-r--r--java/src/IceInternal/LocatorManager.java140
1 files changed, 0 insertions, 140 deletions
diff --git a/java/src/IceInternal/LocatorManager.java b/java/src/IceInternal/LocatorManager.java
deleted file mode 100644
index 0e651b5935c..00000000000
--- a/java/src/IceInternal/LocatorManager.java
+++ /dev/null
@@ -1,140 +0,0 @@
-// **********************************************************************
-//
-// Copyright (c) 2003-2014 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.
-//
-// **********************************************************************
-
-package IceInternal;
-
-public final class LocatorManager
-{
- static private class LocatorKey implements Cloneable
- {
- @Override
- public boolean
- equals(Object o)
- {
- assert(o instanceof LocatorKey);
- LocatorKey k = (LocatorKey)o;
- if(!k._id.equals(_id))
- {
- return false;
- }
- if(!k._encoding.equals(_encoding))
- {
- return false;
- }
- return true;
- }
-
- @Override
- public int
- hashCode()
- {
- int h = 5381;
- h = IceInternal.HashUtil.hashAdd(h, _id);
- h = IceInternal.HashUtil.hashAdd(h, _encoding);
- return h;
- }
-
- @Override
- public java.lang.Object
- clone()
- {
- java.lang.Object o = null;
- try
- {
- o = super.clone();
- }
- catch(CloneNotSupportedException ex)
- {
- assert false; // impossible
- }
- return o;
- }
-
- LocatorKey set(Ice.LocatorPrx locator)
- {
- Reference r = ((Ice.ObjectPrxHelperBase)locator).__reference();
- _id = r.getIdentity();
- _encoding = r.getEncoding();
- return this;
- }
-
- private Ice.Identity _id;
- private Ice.EncodingVersion _encoding;
- }
-
- LocatorManager(Ice.Properties properties)
- {
- _background = properties.getPropertyAsInt("Ice.BackgroundLocatorCacheUpdates") > 0;
- }
-
- synchronized void
- destroy()
- {
- for(LocatorInfo info : _table.values())
- {
- info.destroy();
- }
- _table.clear();
- _locatorTables.clear();
- }
-
- //
- // Returns locator info for a given locator. Automatically creates
- // the locator info if it doesn't exist yet.
- //
- public LocatorInfo
- get(Ice.LocatorPrx loc)
- {
- if(loc == null)
- {
- return null;
- }
-
- //
- // The locator can't be located.
- //
- Ice.LocatorPrx locator = Ice.LocatorPrxHelper.uncheckedCast(loc.ice_locator(null));
-
- //
- // TODO: reap unused locator info objects?
- //
-
- synchronized(this)
- {
- LocatorInfo info = _table.get(locator);
- if(info == null)
- {
- //
- // Rely on locator identity for the adapter table. We want to
- // have only one table per locator (not one per locator
- // proxy).
- //
- LocatorTable table = _locatorTables.get(_lookupKey.set(locator));
- if(table == null)
- {
- table = new LocatorTable();
- _locatorTables.put((LocatorKey)_lookupKey.clone(), table);
- }
-
- info = new LocatorInfo(locator, table, _background);
- _table.put(locator, info);
- }
-
- return info;
- }
- }
-
- final private boolean _background;
-
- private java.util.HashMap<Ice.LocatorPrx, LocatorInfo> _table =
- new java.util.HashMap<Ice.LocatorPrx, LocatorInfo>();
- private java.util.HashMap<LocatorKey, LocatorTable> _locatorTables =
- new java.util.HashMap<LocatorKey, LocatorTable>();
- private LocatorKey _lookupKey = new LocatorKey(); // A key used for the lookup
-}