OpenRTM-aist-Python 1.1.2
公開メンバ関数 | 全メンバ一覧
OpenRTM_aist.SdoServiceProviderBase.SdoServiceProviderBase クラス

SdoServiceProvider 基底クラス [詳解]

OpenRTM_aist.SdoServiceProviderBase.SdoServiceProviderBase の継承関係図
OpenRTM_aist.SdoServiceProviderBase.SdoServiceProviderFactory

公開メンバ関数

def __del__ (self)
 仮想デストラクタ
 
def init (self, rtobj, profile)
 コンシューマクラスの初期化関数 [詳解]
 
def reinit (self, profile)
 コンシューマクラスの再初期化関数 [詳解]
 
def getProfile (self)
 ServiceProfile を返す [詳解]
 
def finalize (self)
 終了処理 [詳解]
 

詳解

SdoServiceProvider 基底クラス

SDOで定義されているSDOサービスのプロバイダを実装するための基底クラ ス。SDOサービスには、外部から提供サービスをRTC(SDO)側で利用する SDOサービスコンシューマと、RTC(SDO)自身がSDOサービスを提供するSDO サービスプロバイダがある。すべてのSDOサービスプロバイダはこの基底 クラスを継承して実装される。

このオブジェクトのライフサイクルは以下の通り。

  1. マネージャに対してロードされるとモジュール初期化関数によりオブ ジェクトファクトリが、SdoServiceProviderFactory に対して登録さ れる。登録のキーにはサービスインターフェースの IFR (interface repository) ID が利用され、これによりサービスが区別される。
  2. rtc.conf等のコンフィギュレーション指定により、有効化することが 指定されているサービスインプロバイダは、RTCの起動と同時にインス タンス化される。
  3. インスタンス化後、初期化関数 init() が呼ばれる。引数には当該サー ビスのためのコンフィギュレーションオプションが Propertyに より渡される。
  4. インスタンス化されたSDOサービスプロバイダは SDO.get_sdo_service() により外部からアクセスされる。このと き、サービスを指定するIDはIFR IDと同じである。このときのアタッ チシーケンスは以下の通り。
  5. RTCがfinalizeされ解体されると同時にSDOサービスプロバイダも解体 されるが、その際にはSdoServiceProviderBase.finalize()がコール されるので、ここでリソースの解放など終了処理を行う。
   [RTC]      [SDO service]               [Other]
     |              :                        |
     | instantiate  :                        |
     |------------->:                        |
     |    init()    |                        |
     |------------->|                        |
     |              | get_service_profiles() |
     |<--------------------------------------|
     |              |    get_sdo_service()   |
     |<--------------------------------------|
     |              |        use service     |
     |              |<-----------------------|
     |              |                        |
     |  finalize()  |                        |
     |------------->x                        |
     x              x                        |
 

このクラスの実装に当たっては、少なくとも以下の純粋仮想関数を実装す る必要がある。

SdoServiceProviderのエントリポイントは通常、ファイル名の basename + "Init" にしておく。以下に、クラス名、ファイル 名、エントリポイント関数名の推奨例を示す。

エントリポイント関数は通常以下のように、SdoServiceProviderFactory に当該コンシューマのファクトリ (と解体ファンクタ) を登録する以下の ような関数になる。

   def MySdoServiceProviderInit(mgr=None):
     factory = OpenRTM_aist.SdoServiceProviderFactory.instance()
     factory.addFactory(OpenRTM.MySdoService._NP_RepositoryId,
                        MySdoServiceProvider,
                        OpenRTM_aist.Delete)
     return
 
 

メソッド詳解

def OpenRTM_aist.SdoServiceProviderBase.SdoServiceProviderBase.finalize (   self)

終了処理

SDOサービスがでタッチされる際に呼び出される終了処理用関数。サー ビスのでタッチに際して、当該オブジェクトが保持するリソースを解放 するなどの処理を行う。

virtual void finalize() = 0;

def OpenRTM_aist.SdoServiceProviderBase.SdoServiceProviderBase.getProfile (   self)

ServiceProfile を返す

init()/reinit()で与えられた ServiceProfile は通常オブジェクト内 で保持される。SDO Service 管理フレームワークは管理上このオブジェ クトに対応する ServiceProfile を必要とするので、この関数では保持 されている ServiceProfile を返す。

戻り値
このオブジェクトが保持している ServiceProfile

virtual const SDOPackage::ServiceProfile& getProfile() const = 0;

def OpenRTM_aist.SdoServiceProviderBase.SdoServiceProviderBase.init (   self,
  rtobj,
  profile 
)

コンシューマクラスの初期化関数

このオブジェクトの初期化を行う。外部からSDOサービスが ServiceProfile とともにアタッチされると、SDOコンシューマがインス タンス化され、その直後に SDO サービスがアタッチされた RTC と与え られた ServiceProfile を引数としてこの関数が呼ばれる。

関数内では、ServiceProfile 内の SDO サービスリファレンスを CorbaProvider クラス等を利用しオブジェクト内に保持するとともに、 properties から設定内容を読み込みサービス固有の設定等を行う。与 えられたサービスのオブジェクトリファレンスが不正、あるいは properties の内容が不正、等の場合は戻り値に false を返す。

引数
rtobjこのオブジェクトがインスタンス化された RTC
profile外部から与えられた SDO ServiceProfile
戻り値
与えられた SDO Service や ServiceProfile が不正の場合 false

virtual bool init(RTObject_impl& rtobj, const SDOPackage::ServiceProfile& profile) = 0;

def OpenRTM_aist.SdoServiceProviderBase.SdoServiceProviderBase.reinit (   self,
  profile 
)

コンシューマクラスの再初期化関数

このオブジェクトの再初期化を行う。ServiceProfile には id フィー ルドにセッション固有の UUID がセットされているが、同一の id の場 合、properties に設定された設定情報の変更や、service フィールド のサービスの参照の変更が行われる。その際に呼ばれるのがこの reinit() 関数である。実装では、service フィールドのオブジェクト リファレンスの同一性を確認し、異なっている場合保持しているリファ レンスを更新する必要がある。また properties には新たな設定が与え られている可能性があるので、内容を読み込み設定を更新する。

引数
profile新たに与えられた SDO ServiceProfile
戻り値
不正な ServiceProfile が与えられた場合は false

virtual bool reinit(const SDOPackage::ServiceProfile& profile) = 0;


このクラス詳解は次のファイルから抽出されました: