All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.zeroc.IceInternal.ServantManager Maven / Gradle / Ivy

Go to download

Ice is a comprehensive RPC framework that helps you build distributed applications with minimal effort using familiar object-oriented idioms

There is a newer version: 3.7.10
Show newest version
//
// Copyright (c) ZeroC, Inc. All rights reserved.
//

package com.zeroc.IceInternal;

public final class ServantManager
{
    public synchronized void
    addServant(com.zeroc.Ice.Object servant, com.zeroc.Ice.Identity ident, String facet)
    {
        assert(_instance != null); // Must not be called after destruction.

        if(facet == null)
        {
            facet = "";
        }

        java.util.Map m = _servantMapMap.get(ident);
        if(m == null)
        {
            m = new java.util.HashMap();
            _servantMapMap.put(ident, m);
        }
        else
        {
            if(m.containsKey(facet))
            {
                com.zeroc.Ice.AlreadyRegisteredException ex = new com.zeroc.Ice.AlreadyRegisteredException();
                ex.id = com.zeroc.Ice.Util.identityToString(ident, _instance.toStringMode());
                ex.kindOfObject = "servant";
                if(facet.length() > 0)
                {
                    ex.id += " -f " + com.zeroc.IceUtilInternal.StringUtil.escapeString(facet, "",
                                                                                        _instance.toStringMode());
                }
                throw ex;
            }
        }

        m.put(facet, servant);
    }

    public synchronized void
    addDefaultServant(com.zeroc.Ice.Object servant, String category)
    {
        assert(_instance != null); // Must not be called after destruction

        com.zeroc.Ice.Object obj = _defaultServantMap.get(category);
        if(obj != null)
        {
            com.zeroc.Ice.AlreadyRegisteredException ex = new com.zeroc.Ice.AlreadyRegisteredException();
            ex.kindOfObject = "default servant";
            ex.id = category;
            throw ex;
        }

        _defaultServantMap.put(category, servant);
    }

    public synchronized com.zeroc.Ice.Object
    removeServant(com.zeroc.Ice.Identity ident, String facet)
    {
        assert(_instance != null); // Must not be called after destruction.

        if(facet == null)
        {
            facet = "";
        }

        java.util.Map m = _servantMapMap.get(ident);
        com.zeroc.Ice.Object obj = null;
        if(m == null || (obj = m.remove(facet)) == null)
        {
            com.zeroc.Ice.NotRegisteredException ex = new com.zeroc.Ice.NotRegisteredException();
            ex.id = com.zeroc.Ice.Util.identityToString(ident, _instance.toStringMode());
            ex.kindOfObject = "servant";
            if(facet.length() > 0)
            {
                ex.id += " -f " + com.zeroc.IceUtilInternal.StringUtil.escapeString(facet, "",
                                                                                    _instance.toStringMode());
            }
            throw ex;
        }

        if(m.isEmpty())
        {
            _servantMapMap.remove(ident);
        }
        return obj;
    }

    public synchronized com.zeroc.Ice.Object
    removeDefaultServant(String category)
    {
        assert(_instance != null); // Must not be called after destruction.

        com.zeroc.Ice.Object obj = _defaultServantMap.get(category);
        if(obj == null)
        {
            com.zeroc.Ice.NotRegisteredException ex = new com.zeroc.Ice.NotRegisteredException();
            ex.kindOfObject = "default servant";
            ex.id = category;
            throw ex;
        }

        _defaultServantMap.remove(category);
        return obj;
    }

    public synchronized java.util.Map
    removeAllFacets(com.zeroc.Ice.Identity ident)
    {
        assert(_instance != null); // Must not be called after destruction.

        java.util.Map m = _servantMapMap.get(ident);
        if(m == null)
        {
            com.zeroc.Ice.NotRegisteredException ex = new com.zeroc.Ice.NotRegisteredException();
            ex.id = com.zeroc.Ice.Util.identityToString(ident, _instance.toStringMode());
            ex.kindOfObject = "servant";
            throw ex;
        }

        _servantMapMap.remove(ident);

        return m;
    }

    public synchronized com.zeroc.Ice.Object
    findServant(com.zeroc.Ice.Identity ident, String facet)
    {
        //
        // This assert is not valid if the adapter dispatch incoming
        // requests from bidir connections. This method might be called if
        // requests are received over the bidir connection after the
        // adapter was deactivated.
        //
        //assert(_instance != null); // Must not be called after destruction.

        if(facet == null)
        {
            facet = "";
        }

        java.util.Map m = _servantMapMap.get(ident);
        com.zeroc.Ice.Object obj = null;
        if(m == null)
        {
            obj = _defaultServantMap.get(ident.category);
            if(obj == null)
            {
                obj = _defaultServantMap.get("");
            }
        }
        else
        {
            obj = m.get(facet);
        }

        return obj;
    }

    public synchronized com.zeroc.Ice.Object
    findDefaultServant(String category)
    {
        assert(_instance != null); // Must not be called after destruction.

        return _defaultServantMap.get(category);
    }

    public synchronized java.util.Map
    findAllFacets(com.zeroc.Ice.Identity ident)
    {
        assert(_instance != null); // Must not be called after destruction.

        java.util.Map m = _servantMapMap.get(ident);
        if(m != null)
        {
            return new java.util.HashMap(m);
        }

        return new java.util.HashMap();
    }

    public synchronized boolean
    hasServant(com.zeroc.Ice.Identity ident)
    {
        //
        // This assert is not valid if the adapter dispatch incoming
        // requests from bidir connections. This method might be called if
        // requests are received over the bidir connection after the
        // adapter was deactivated.
        //
        //assert(_instance != null); // Must not be called after destruction.

        java.util.Map m = _servantMapMap.get(ident);
        if(m == null)
        {
            return false;
        }
        else
        {
            assert(!m.isEmpty());
            return true;
        }
    }

    public synchronized void
    addServantLocator(com.zeroc.Ice.ServantLocator locator, String category)
    {
        assert(_instance != null); // Must not be called after destruction.

        com.zeroc.Ice.ServantLocator l = _locatorMap.get(category);
        if(l != null)
        {
            com.zeroc.Ice.AlreadyRegisteredException ex = new com.zeroc.Ice.AlreadyRegisteredException();
            ex.id = com.zeroc.IceUtilInternal.StringUtil.escapeString(category, "",
                                                                      _instance.toStringMode());
            ex.kindOfObject = "servant locator";
            throw ex;
        }

        _locatorMap.put(category, locator);
    }

    public synchronized com.zeroc.Ice.ServantLocator
    removeServantLocator(String category)
    {
        com.zeroc.Ice.ServantLocator l = null;
        assert(_instance != null); // Must not be called after destruction.

        l = _locatorMap.remove(category);
        if(l == null)
        {
            com.zeroc.Ice.NotRegisteredException ex = new com.zeroc.Ice.NotRegisteredException();
            ex.id = com.zeroc.IceUtilInternal.StringUtil.escapeString(category, "",
                                                                      _instance.toStringMode());
            ex.kindOfObject = "servant locator";
            throw ex;
        }
        return l;
    }

    public synchronized com.zeroc.Ice.ServantLocator
    findServantLocator(String category)
    {
        //
        // This assert is not valid if the adapter dispatch incoming
        // requests from bidir connections. This method might be called if
        // requests are received over the bidir connection after the
        // adapter was deactivated.
        //
        //assert(_instance != null); // Must not be called after destruction.

        return _locatorMap.get(category);
    }

    //
    // Only for use by com.zeroc.Ice.ObjectAdatperI.
    //
    public
    ServantManager(Instance instance, String adapterName)
    {
        _instance = instance;
        _adapterName = adapterName;
    }

    //
    // Only for use by com.zeroc.Ice.ObjectAdapterI.
    //
    public void
    destroy()
    {
        java.util.Map locatorMap =
            new java.util.HashMap();
        com.zeroc.Ice.Logger logger = null;
        synchronized(this)
        {
            //
            // If the ServantManager has already been destroyed, we're done.
            //
            if(_instance == null)
            {
                return;
            }

            logger = _instance.initializationData().logger;

            _servantMapMap.clear();

            _defaultServantMap.clear();

            locatorMap.putAll(_locatorMap);
            _locatorMap.clear();

            _instance = null;
        }

        for(java.util.Map.Entry p : locatorMap.entrySet())
        {
            com.zeroc.Ice.ServantLocator locator = p.getValue();
            try
            {
                locator.deactivate(p.getKey());
            }
            catch(java.lang.Exception ex)
            {
                String s = "exception during locator deactivation:\n" + "object adapter: `" + _adapterName + "'\n" +
                    "locator category: `" + p.getKey() + "'\n" + Ex.toString(ex);
                logger.error(s);
            }
        }
    }

    private Instance _instance;
    final private String _adapterName;
    private java.util.Map > _servantMapMap =
        new java.util.HashMap >();
    private java.util.Map _defaultServantMap =
        new java.util.HashMap();
    private java.util.Map _locatorMap =
        new java.util.HashMap();
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy