FileDocCategorySizeDatePackage
POALocalCRDImpl.javaAPI DocJava SE 5 API4616Fri Aug 26 14:54:30 BST 2005com.sun.corba.se.impl.protocol

POALocalCRDImpl.java

/*
 * @(#)POALocalCRDImpl.java	1.24 03/12/19
 * 
 * Copyright 2004 Sun Microsystems, Inc. All rights reserved.
 * SUN PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
 */

package com.sun.corba.se.impl.protocol;

import org.omg.CORBA.SystemException;
import org.omg.CORBA.OBJ_ADAPTER ;
import org.omg.CORBA.UNKNOWN ;
import org.omg.CORBA.CompletionStatus ;

import org.omg.CORBA.portable.ServantObject;

import com.sun.corba.se.pept.protocol.ClientRequestDispatcher;

import com.sun.corba.se.spi.protocol.LocalClientRequestDispatcher;
import com.sun.corba.se.spi.protocol.LocalClientRequestDispatcherFactory;
import com.sun.corba.se.spi.protocol.ForwardException ;

import com.sun.corba.se.spi.oa.ObjectAdapter;
import com.sun.corba.se.spi.oa.OAInvocationInfo ;
import com.sun.corba.se.spi.oa.OADestroyed;

import com.sun.corba.se.spi.orb.ORB;

import com.sun.corba.se.spi.ior.IOR ;

import com.sun.corba.se.spi.logging.CORBALogDomains ;

import com.sun.corba.se.impl.logging.POASystemException ;
import com.sun.corba.se.impl.logging.ORBUtilSystemException ;

public class POALocalCRDImpl extends LocalClientRequestDispatcherBase
{
    private ORBUtilSystemException wrapper ;
    private POASystemException poaWrapper ;

    public POALocalCRDImpl( ORB orb, int scid, IOR ior)
    {
	super( (com.sun.corba.se.spi.orb.ORB)orb, scid, ior );
	wrapper = ORBUtilSystemException.get( orb, 
	    CORBALogDomains.RPC_PROTOCOL ) ;
	poaWrapper = POASystemException.get( orb, 
	    CORBALogDomains.RPC_PROTOCOL ) ;
    }

    private OAInvocationInfo servantEnter( ObjectAdapter oa ) throws OADestroyed
    {
	oa.enter() ;

	OAInvocationInfo info = oa.makeInvocationInfo( objectId ) ;
	orb.pushInvocationInfo( info ) ;

	return info ;
    }

    private void servantExit( ObjectAdapter oa ) 
    {
	try {
	    oa.returnServant();
	} finally {
	    oa.exit() ;
	    orb.popInvocationInfo() ; 
	}
    }

    // Look up the servant for this request and return it in a 
    // ServantObject.  Note that servant_postinvoke is always called
    // by the stub UNLESS this method returns null.  However, in all
    // cases we must be sure that ObjectAdapter.getServant and
    // ObjectAdapter.returnServant calls are paired, as required for
    // Portable Interceptors and Servant Locators in the POA.
    // Thus, this method must call returnServant if it returns null.
    public ServantObject servant_preinvoke(org.omg.CORBA.Object self,
                                           String operation,
                                           Class expectedType) 
    {
	ObjectAdapter oa = oaf.find( oaid ) ;
	OAInvocationInfo info = null ;

	try {
	    info = servantEnter( oa ) ;
	    info.setOperation( operation ) ;
        } catch ( OADestroyed ex ) {
            // Destroyed POAs can be recreated by normal adapter activation.
            // So just reinvoke this method.
            return servant_preinvoke(self, operation, expectedType);
	}

        try {
	    try {
		oa.getInvocationServant( info );
		if (!checkForCompatibleServant( info, expectedType ))
		    return null ;
	    } catch (Throwable thr) {
		// Cleanup after this call, then throw to allow
		// outer try to handle the exception appropriately.
		servantExit( oa ) ;
		throw thr ;
	    }
        } catch ( ForwardException ex ) {
	    /* REVISIT
	    ClientRequestDispatcher csub = (ClientRequestDispatcher)
		StubAdapter.getDelegate( ex.forward_reference ) ;
	    IOR ior = csub.getIOR() ;
	    setLocatedIOR( ior ) ;
	    */
	    RuntimeException runexc = new RuntimeException("deal with this.");
	    runexc.initCause( ex ) ;
	    throw runexc ;
        } catch ( ThreadDeath ex ) {
	    // ThreadDeath on the server side should not cause a client
	    // side thread death in the local case.  We want to preserve
	    // this behavior for location transparency, so that a ThreadDeath
	    // has the same affect in either the local or remote case.
	    // The non-colocated case is handled in iiop.ORB.process, which
	    // throws the same exception.
	    throw wrapper.runtimeexception( ex ) ;
        } catch ( Throwable t ) {
            if (t instanceof SystemException)
		throw (SystemException)t ;

	    throw poaWrapper.localServantLookup( t ) ;
        } 

	if (!checkForCompatibleServant( info, expectedType )) {
	    servantExit( oa ) ;
	    return null ;
	}

        return info;
    }

    public void servant_postinvoke(org.omg.CORBA.Object self,
                                   ServantObject servantobj) 
    {
        ObjectAdapter oa = orb.peekInvocationInfo().oa() ; 
	servantExit( oa ) ;	
    }
}

// End of file.