org.omg.PortableInterceptor

Interface ORBInitInfoOperations

  • All Known Subinterfaces:
    ORBInitInfo

    public interface ORBInitInfoOperations
    Passed to each ORBInitializer, allowing it to to register interceptors and perform other duties while the ORB is initializing.

    The ORBInitInfo object is only valid during ORB.init. If a service keeps a reference to its ORBInitInfo object and tries to use it after ORB.init returns, the object no longer exists and an OBJECT_NOT_EXIST exception shall be thrown.

    See Also:
    ORBInitializer
    • Method Detail

      • arguments

        String[] arguments()
        Returns the arguments passed to ORB.init. They may or may not contain the ORB's arguments.
      • orb_id

        String orb_id()
        Returns the ID of the ORB being initialized.
      • codec_factory

        CodecFactory codec_factory()
        Returns the IOP.CodecFactory. The CodecFactory is normally obtained via a call to ORB.resolve_initial_references( "CodecFactory" ), but since the ORB is not yet available and Interceptors, particularly when processing service contexts, will require a Codec, a means of obtaining a Codec is necessary during ORB initialization.
      • register_initial_reference

        void register_initial_reference(String id,
                                      Object obj)
                                        throws InvalidName
        Identical to ORB.register_initial_reference. This same functionality exists here because the ORB, not yet fully initialized, is not yet available but initial references may need to be registered as part of Interceptor registration. The only difference is that the version of this operation on the ORB uses PIDL (CORBA.ORB.ObjectId) and (CORBA.ORB.InvalidName) whereas the version in this interface uses IDL defined in this interface; the semantics are identical.
        Throws:
        InvalidName
      • resolve_initial_references

        Object resolve_initial_references(String id)
                                          throws InvalidName
        Identical to ORB.resolve_initial_references. This same functionality exists here because the ORB, not yet fully initialized, is not yet available but initial references may be required from the ORB as part of Interceptor registration. The only difference is that the version of this operation on the ORB uses PIDL (CORBA::ORB::ObjectId and CORBA::ORB::InvalidName) whereas the version in this interface uses IDL defined in this interface; the semantics are identical.

        This operation is only valid during post_init.

        Throws:
        InvalidName
      • add_client_request_interceptor

        void add_client_request_interceptor(ClientRequestInterceptor interceptor)
                                            throws DuplicateName
        Used to add a client-side request Interceptor to the list of client-side request Interceptors.
        Parameters:
        interceptor - The ClientRequestInterceptor to be added.
        Throws:
        DuplicateName - thrown if a client-side request Interceptor has already been registered with this Interceptor's name.
      • add_server_request_interceptor

        void add_server_request_interceptor(ServerRequestInterceptor interceptor)
                                            throws DuplicateName
        Used to add a server-side request Interceptor to the list of server-side request Interceptors.
        Parameters:
        interceptor - The ServerRequestInterceptor to be added.
        Throws:
        DuplicateName - thrown if a server-side request Interceptor has already been registered with this Interceptor's name
      • add_ior_interceptor

        void add_ior_interceptor(IORInterceptor interceptor)
                                 throws DuplicateName
        Used to add an IOR Interceptor to the list of IOR Interceptors.
        Parameters:
        interceptor - The IORInterceptor to be added.
        Throws:
        DuplicateName - thrown if an IOR Interceptor has already been registered with this Interceptor's name.
      • allocate_slot_id

        int allocate_slot_id()
        Called to allocate a slot on PortableInterceptor.Current.

        Note that while slot id's can be allocated within an ORB initializer, the slots themselves cannot be initialized.

        Returns:
        The index to the slot which has been allocated.
        Throws:
        BAD_INV_ORDER - thrown, with a standard minor code of 14, if set_slot or get_slot is called on the PICurrent within an ORB initializer.
        See Also:
        Current
      • register_policy_factory

        void register_policy_factory(int type,
                                   PolicyFactory policy_factory)
        Registers a PolicyFactory for the given PolicyType.
        Parameters:
        type - The policy type that the given PolicyFactory serves.
        policy_factory - The factory for the given policy type.
        Throws:
        BAD_INV_ORDER - thrown, with a standard minor code of 16, if a PolicyFactory already exists for the given PolicyType.

Traduction non disponible

Les API Java ne sont pas encore traduites en français sur l'infobrol. Seule la version anglaise est disponible pour l'instant.

Version en cache

23/10/2025 07:53:42 Cette version de la page est en cache (à la date du 23/10/2025 07:53:42) afin d'accélérer le traitement.
Vous pouvez activer le mode utilisateur dans le menu en haut pour afficher la version plus récente de la page.

Document créé le 07/12/2006, dernière modification le 04/03/2020
Source du document imprimé : https://www.gaudry.be/java-api-rf-org/omg/portableinterceptor/orbinitinfooperations.html

L'infobrol est un site personnel dont le contenu n'engage que moi. Le texte est mis à disposition sous licence CreativeCommons(BY-NC-SA). Plus d'info sur les conditions d'utilisation et sur l'auteur.

Références

  1. Consulter le document html Langue du document :fr Manuel PHP : https://docs.oracle.com/en/java/, Interface ORBInitInfoOperations

Ces références et liens indiquent des documents consultés lors de la rédaction de cette page, ou qui peuvent apporter un complément d'information, mais les auteurs de ces sources ne peuvent être tenus responsables du contenu de cette page.
L'auteur de ce site est seul responsable de la manière dont sont présentés ici les différents concepts, et des libertés qui sont prises avec les ouvrages de référence. N'oubliez pas que vous devez croiser les informations de sources multiples afin de diminuer les risques d'erreurs.