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

javax.rmi.CORBA.StubDelegate Maven / Gradle / Ivy

/*
 * Copyright (c) 1997, 2020 Oracle and/or its affiliates. All rights reserved.
 * Copyright (c) 1998-1999 IBM Corp. All rights reserved.
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License v. 2.0 which is available at
 * http://www.eclipse.org/legal/epl-2.0, or the Eclipse Distribution License
 * v. 1.0 which is available at
 * http://www.eclipse.org/org/documents/edl-v10.php.
 *
 * This Source Code may also be made available under the following Secondary
 * Licenses when the conditions for such availability set forth in the Eclipse
 * Public License v. 2.0 are satisfied: GNU General Public License v2.0
 * w/Classpath exception which is available at
 * https://www.gnu.org/software/classpath/license.html.
 *
 * SPDX-License-Identifier: EPL-2.0 OR BSD-3-Clause OR GPL-2.0 WITH
 * Classpath-exception-2.0
 */

package javax.rmi.CORBA;

import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.rmi.RemoteException;
import org.omg.CORBA.ORB;

/**
 * Supports delegation for method implementations in {@link Stub}.
 * A delegate is an instance of a class that implements this
 * interface and provides a replacement implementation for all the
 * methods of javax.rmi.CORBA.Stub.  If delegation is
 * enabled, each stub has an associated delegate.
 *
 * Delegates are enabled by providing the delegate's class name as the
 * value of the 
 * javax.rmi.CORBA.StubClass
 * system property.
 *
 * @see Stub
 */
public interface StubDelegate {

    /**
     * Delegation call for {@link Stub#hashCode}.
     * @param self stub to call on
     * @return int hashcode of the stub
     */
    int hashCode(Stub self);

    /**
     * Delegation call for {@link Stub#equals}.
     * @param self stub to call on
     * @param obj other object to compare
     * @return true if the two objects are equal
     */
    boolean equals(Stub self, java.lang.Object obj);

    /**
     * Delegation call for {@link Stub#toString}.
     * @param self to call toString on
     * @return String representation of the Stub
     */
    String toString(Stub self);

    /**
     * Delegation call for {@link Stub#connect}.
     * @param self stub to call on
     * @param orb the ORB to connect to
     * @throws RemoteException if there was an error connecting
     */
    void connect(Stub self, ORB orb)
        throws RemoteException;
 
    // _REVISIT_ cannot link to Stub.readObject directly... why not?
    /**
     * Delegation call for
     * Stub.readObject(java.io.ObjectInputStream).
     * @param self stub to read
     * @param s stream to read from
     * @throws IOException if there was an error reading from the stream
     * @throws ClassNotFoundException if the class that was represented by the steam cannot be found
     */
    void readObject(Stub self, ObjectInputStream s)
        throws IOException, ClassNotFoundException;

    // _REVISIT_ cannot link to Stub.writeObject directly... why not?
    /**
     * Delegation call for 
     * Stub.writeObject(java.io.ObjectOutputStream).
     * @param self stub to write
     * @param s stream to write to
     * @throws IOException if there was an error writing to stream
     */
    void writeObject(Stub self, ObjectOutputStream s)
        throws IOException;

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy