public interface ORBInitInfoOperations
ORBInitializer
に渡されて、ORBが初期化しているときにインタセプタを登録したり、ほかの処理を実行したりできるようにします。
ORBInitInfo
オブジェクトは、ORB.init
の実行中のみ有効です。サービスがそのORBInitInfo
オブジェクトへの参照を保管し、ORB.init
が復帰したあとでそれを使用しようとすると、そのオブジェクトはもう存在しないため、OBJECT_NOT_EXIST
例外がスローされます。
ORBInitializer
修飾子と型 | メソッドと説明 |
---|---|
void |
add_client_request_interceptor(ClientRequestInterceptor interceptor)
クライアント側の要求インタセプタをクライアント側の要求インタセプタのリストに追加します。
|
void |
add_ior_interceptor(IORInterceptor interceptor)
IORインタセプタをIORインタセプタのリストに追加します。
|
void |
add_server_request_interceptor(ServerRequestInterceptor interceptor)
サーバー側の要求インタセプタをサーバー側の要求インタセプタのリストに追加します。
|
int |
allocate_slot_id()
PortableInterceptor.Current にスロットを割り当てるために呼び出されます。 |
String[] |
arguments()
ORB.init に渡された引数を返します。 |
CodecFactory |
codec_factory()
IOP.CodecFactory を返します。 |
String |
orb_id()
初期化されるORBのIDを返します。
|
void |
register_initial_reference(String id, Object obj)
ORB.register_initial_reference と同じ。 |
void |
register_policy_factory(int type, PolicyFactory policy_factory)
指定された
PolicyType のPolicyFactory を登録します。 |
Object |
resolve_initial_references(String id)
ORB.resolve_initial_references と同じ。 |
String[] arguments()
ORB.init
に渡された引数を返します。ORBの引数が含まれている場合も含まれていない場合もあります。String orb_id()
CodecFactory codec_factory()
IOP.CodecFactory
を返します。CodecFactory
は通常、ORB.resolve_initial_references("CodecFactory")
の呼出しを介して取得されますが、ORBがまだ利用できず、インタセプタがCodec
を必要とする(特にサービス・コンテキストの処理時)ため、ORBの初期化時にはCodec
を取得する手段が必要となります。void register_initial_reference(String id, Object obj) throws InvalidName
ORB.register_initial_reference
と同じ。同じ機能がここに用意されているのは、ORBの初期化が完了していないためまだ利用できないときに、インタセプタ登録の一環として初期参照を登録することが必要な場合があるためです。唯一の違いは、ORBのバージョンではPIDL (CORBA.ORB.ObjectId
とCORBA.ORB.InvalidName
)を使用するのに対して、このインタフェースのバージョンではこのインタフェースに定義されたIDLを使用する点です。ただし、セマンティックスは同じです。InvalidName
Object resolve_initial_references(String id) throws InvalidName
ORB.resolve_initial_references
と同じ。同じ機能がここに用意されているのは、ORBの初期化が完了していないためまだ利用できないときに、インタセプタ登録の一環として、ORBから初期参照を必要とする場合があるためです。唯一の違いは、ORBのバージョンではPIDL (CORBA::ORB::ObjectId
とCORBA::ORB::InvalidName
)を使用するのに対して、このインタフェースのバージョンではこのインタフェースに定義されたIDLを使用する点です。ただし、セマンティックスは同じです。
このオペレーションは、post_initの実行時のみ有効です。
InvalidName
void add_client_request_interceptor(ClientRequestInterceptor interceptor) throws DuplicateName
interceptor
- 追加するClientRequestInterceptor
。DuplicateName
- このインタセプタの名前を持つクライアント側の要求インタセプタがすでに存在する場合にスローされる。void add_server_request_interceptor(ServerRequestInterceptor interceptor) throws DuplicateName
interceptor
- 追加するServerRequestInterceptor。DuplicateName
- このインタセプタの名前を持つサーバー側の要求インタセプタがすでに存在する場合にスローされるvoid add_ior_interceptor(IORInterceptor interceptor) throws DuplicateName
interceptor
- 追加するIORInterceptor。DuplicateName
- このインタセプタの名前を持つIORインタセプタがすでに存在する場合にスローされる。int allocate_slot_id()
PortableInterceptor.Current
にスロットを割り当てるために呼び出されます。
ORBイニシャライザの内部でスロットIDを割り当てることはできますが、それらのスロットを初期化することはできないので注意してください。
BAD_INV_ORDER
- ORBイニシャライザの内部でPICurrent
に対してset_slot
またはget_slot
が呼び出された場合、標準マイナー・コード14でスローされる。Current
void register_policy_factory(int type, PolicyFactory policy_factory)
PolicyType
のPolicyFactory
を登録します。type
- 指定されたPolicyFactory
が扱うポリシー型。policy_factory
- 指定されたポリシー型のファクトリ。BAD_INV_ORDER
- 指定されたPolicyFactory
のPolicyType
がない場合、標準マイナー・コード16でスローされる。 バグまたは機能を送信
詳細なAPIリファレンスおよび開発者ドキュメントについては、Java SEのドキュメントを参照してください。そのドキュメントには、概念的な概要、用語の定義、回避方法、有効なコード例などの、開発者を対象にしたより詳細な説明が含まれています。
Copyright© 1993, 2014, Oracle and/or its affiliates. All rights reserved.