ExecutionContextWorker クラス
[詳解]
#include <ExecutionContextWorker.h>
ExecutionContextWorker クラス
RTCの状態マシン・プロキシクラス RTObjectStateMachine を保持・管理 し、コールバックを実際にコールするためのワーカークラスインターフェー スクラス。ECの実装者は、ExecutionContextBase を継承し、メンバ変数 として保持されているこの ExecutionContextWorker クラスのインター フェース経由でRTObjectのコールバックをコールすることになる。
- ECのオブジェクトリファレンスのセッタ・ゲッター
- ECの実行・停止関係関数
- RTCのアクティブ化・非アクティブ化関数
- RTC追加・削除系関数
- 状態問い合わせ系関数
- Workerの駆動およびコールバック
- から
- 1.2
◆ CompItr
◆ ExecutionContextWorker()
| RTC_impl::ExecutionContextWorker::ExecutionContextWorker |
( |
| ) |
|
デフォルトコンストラクタ
デフォルトコンストラクタ プロファイルに以下の項目を設定する。
- kind : PERIODIC
- rate : 0.0
◆ ~ExecutionContextWorker()
| virtual RTC_impl::ExecutionContextWorker::~ExecutionContextWorker |
( |
| ) |
|
|
virtual |
◆ activateComponent()
| RTC::ReturnCode_t RTC_impl::ExecutionContextWorker::activateComponent |
( |
RTC::LightweightRTObject_ptr | comp, |
|
|
RTObjectStateMachine *& | rtobj ) |
RTコンポーネントをアクティブ化する
Inactive 状態にあるRTコンポーネントをActive に遷移させ、アクティ ブ化する。この操作が呼ばれた結果、on_activate が呼び出される。指 定したRTコンポーネントが参加者リストに含まれない場合は、 BAD_PARAMETER が返される。指定したRTコンポーネントの状態が Inactive 以外の場合は、PRECONDITION_NOT_MET が返される。
- 引数
-
- 戻り値
- ReturnCode_t 型のリターンコード
◆ addComponent()
| RTC::ReturnCode_t RTC_impl::ExecutionContextWorker::addComponent |
( |
RTC::LightweightRTObject_ptr | comp | ) |
|
RTコンポーネントを追加する
指定したRTコンポーネントを"参加者リスト"に追加する。追加された RTコンポーネントは attach_context が呼ばれ、Inactive 状態に遷移 する。指定されたRTコンポーネントが null の場合は、BAD_PARAMETER が 返される。指定されたRTコンポーネントが DataFlowComponent 以外の 場合は、BAD_PARAMETER が返される。
この関数が呼ばれた段階では、他の RTC は StateMachine 内のコール バック関数を呼び出し中の可能性があり、まずは "参加者リスト:
m_addedComps" に RTC を追加しておく。コールバック呼び出しが一旦 終わった段階で同期的に updateComponentList() 関数が呼ばれ、この Worker に正式に RTC が参加した状態となる。
- 引数
-
- 戻り値
- ReturnCode_t 型のリターンコード
◆ bindComponent()
| RTC::ReturnCode_t RTC_impl::ExecutionContextWorker::bindComponent |
( |
RTC::RTObject_impl * | rtc | ) |
|
コンポーネントをバインドする。
コンポーネントに owned context をバインドする。引数に渡される RTObject_impl は、この EC の owner であり、内部的には RTObject の bindContext() をコール氏、ec_idを取得する。ec_id は ECOTHER_OFFSET よりも小さい。その後、RTObject のプロキシである RTObjectStateMachine を生成し、コンポーネントのリストに加える。
- 引数
-
- 戻り値
- ReturnCode_t 型のリターンコード
◆ deactivateComponent()
| RTC::ReturnCode_t RTC_impl::ExecutionContextWorker::deactivateComponent |
( |
RTC::LightweightRTObject_ptr | comp, |
|
|
RTObjectStateMachine *& | rtobj ) |
RTコンポーネントを非アクティブ化する
Inactive 状態にあるRTコンポーネントを非アクティブ化し、Inactive に遷移させる。この操作が呼ばれた結果、on_deactivate が呼び出され る。指定したRTコンポーネントが参加者リストに含まれない場合は、 BAD_PARAMETER が返される。指定したRTコンポーネントの状態が Active 以外の場合は、PRECONDITION_NOT_MET が返される。 a
- 引数
-
- 戻り値
- ReturnCode_t 型のリターンコード
◆ findComponent()
| RTObjectStateMachine * RTC_impl::ExecutionContextWorker::findComponent |
( |
RTC::LightweightRTObject_ptr | comp | ) |
|
◆ getComponentState()
| RTC::LifeCycleState RTC_impl::ExecutionContextWorker::getComponentState |
( |
RTC::LightweightRTObject_ptr | comp | ) |
|
RTコンポーネントの状態を取得する
指定したRTコンポーネントの状態(LifeCycleState)を取得する。指定し たRTコンポーネントが参加者リストに含まれない場合は、 UNKNOWN_STATE が返される。
- 引数
-
- 戻り値
- 現在の状態(LifeCycleState)
◆ getECRef()
| RTC::ExecutionContextService_ptr RTC_impl::ExecutionContextWorker::getECRef |
( |
| ) |
|
◆ getStateString()
| static const char * RTC_impl::ExecutionContextWorker::getStateString |
( |
RTC::LifeCycleState | state | ) |
|
|
inlinestatic |
◆ invokeWorker()
| void RTC_impl::ExecutionContextWorker::invokeWorker |
( |
| ) |
|
◆ invokeWorkerDo()
| void RTC_impl::ExecutionContextWorker::invokeWorkerDo |
( |
| ) |
|
◆ invokeWorkerPostDo()
| void RTC_impl::ExecutionContextWorker::invokeWorkerPostDo |
( |
| ) |
|
◆ invokeWorkerPreDo()
| void RTC_impl::ExecutionContextWorker::invokeWorkerPreDo |
( |
| ) |
|
◆ isAllCurrentState()
| bool RTC_impl::ExecutionContextWorker::isAllCurrentState |
( |
RTC::LifeCycleState | state | ) |
|
◆ isAllNextState()
| bool RTC_impl::ExecutionContextWorker::isAllNextState |
( |
RTC::LifeCycleState | state | ) |
|
◆ isOneOfCurrentState()
| bool RTC_impl::ExecutionContextWorker::isOneOfCurrentState |
( |
RTC::LifeCycleState | state | ) |
|
◆ isOneOfNextState()
| bool RTC_impl::ExecutionContextWorker::isOneOfNextState |
( |
RTC::LifeCycleState | state | ) |
|
◆ isRunning()
| CORBA::Boolean RTC_impl::ExecutionContextWorker::isRunning |
( |
| ) |
|
ExecutionContext 実行状態確認関数
この操作は ExecutionContext が Runnning 状態の場合に true を返す。 Executioncontext が Running の間、当該 Executioncontext に参加し ている全てのアクティブRTコンポーネントが、ExecutionContext の実 行種類に応じて実行される。
- 戻り値
- 状態確認関数(動作中:true、停止中:false)
◆ rateChanged()
| RTC::ReturnCode_t RTC_impl::ExecutionContextWorker::rateChanged |
( |
| ) |
|
ExecutionContext の実行周期が変更された
ExecutionContext の実行周期が変更された場合のコールバックを呼び 出す。ECの実装クラスの set_rate() オペレーションが呼び出された場 合、ExecutionContextProfile::setRate() が呼び出され、プロファイ ルの周期値が更新されるとともに、この関数が呼ばれ、 RTObjectStateMachine::onRateChagned() が呼び出される。
- 戻り値
- ReturnCode_t 型のリターンコード
◆ removeComponent()
| RTC::ReturnCode_t RTC_impl::ExecutionContextWorker::removeComponent |
( |
RTC::LightweightRTObject_ptr | comp | ) |
|
RTコンポーネントを参加者リストから削除する
指定したRTコンポーネントを参加者リストから削除する。削除された RTコンポーネントは detach_context が呼ばれる。指定されたRTコンポー ネントが参加者リストに登録されていない場合は、BAD_PARAMETER が返 される。
- 引数
-
- 戻り値
- ReturnCode_t 型のリターンコード
◆ resetComponent()
| RTC::ReturnCode_t RTC_impl::ExecutionContextWorker::resetComponent |
( |
RTC::LightweightRTObject_ptr | comp, |
|
|
RTObjectStateMachine *& | rtobj ) |
RTコンポーネントをリセットする
Error 状態のRTコンポーネントの復帰を試みる。この操作が呼ばれた結 果、on_reset が呼び出される。指定したRTコンポーネントが参加者リ ストに含まれない場合は、BAD_PARAMETER が返される。指定したRTコン ポーネントの状態が Error 以外の場合は、PRECONDITION_NOT_MET が返 される。
- 引数
-
- 戻り値
- ReturnCode_t 型のリターンコード
◆ setECRef()
| void RTC_impl::ExecutionContextWorker::setECRef |
( |
RTC::ExecutionContextService_ptr | ref | ) |
|
◆ start()
| RTC::ReturnCode_t RTC_impl::ExecutionContextWorker::start |
( |
| ) |
|
ExecutionContext の実行を開始
ExecutionContext の実行状態を Runnning とするためのリクエストを 発行する。ExecutionContext の状態が遷移すると ComponentAction::on_startup が呼び出される。参加しているRTコンポー ネントが、初期化されるまで ExecutionContext を開始することはでき ない。ExecutionContext は複数回開始/停止を繰り返すことができる。
- 戻り値
- ReturnCode_t 型のリターンコード
◆ startThread()
| RTC::ReturnCode_t RTC_impl::ExecutionContextWorker::startThread |
( |
| ) |
|
◆ stop()
| RTC::ReturnCode_t RTC_impl::ExecutionContextWorker::stop |
( |
| ) |
|
ExecutionContext の実行を停止
ExecutionContext の状態を Stopped とするためのリクエストを発行す る。遷移が発生した場合は、ComponentAction::on_shutdown が呼び出 される。参加しているRTコンポーネントが終了する前に ExecutionContext を停止する必要がある。ExecutionContext は複数回 開始/停止を繰り返すことができる。
- 戻り値
- ReturnCode_t 型のリターンコード
◆ stopThread()
| RTC::ReturnCode_t RTC_impl::ExecutionContextWorker::stopThread |
( |
| ) |
|
◆ updateComponentList()
| void RTC_impl::ExecutionContextWorker::updateComponentList |
( |
| ) |
|
◆ waitActivateComplete()
| RTC::ReturnCode_t RTC_impl::ExecutionContextWorker::waitActivateComplete |
( |
RTObjectStateMachine *& | rtobj, |
|
|
std::chrono::nanoseconds | timeout = std::chrono::seconds(1), |
|
|
long int | cycle = 1000 ) |
◆ waitDeactivateComplete()
| RTC::ReturnCode_t RTC_impl::ExecutionContextWorker::waitDeactivateComplete |
( |
RTObjectStateMachine *& | rtobj, |
|
|
std::chrono::nanoseconds | timeout = std::chrono::seconds(1), |
|
|
long int | cycle = 1000 ) |
◆ waitResetComplete()
| RTC::ReturnCode_t RTC_impl::ExecutionContextWorker::waitResetComplete |
( |
RTObjectStateMachine *& | rtobj, |
|
|
std::chrono::nanoseconds | timeout = std::chrono::seconds(1), |
|
|
long int | cycle = 1000 ) |
◆ m_addedComps
◆ m_addedMutex
| std::mutex RTC_impl::ExecutionContextWorker::m_addedMutex |
|
mutableprotected |
◆ m_comps
◆ m_mutex
| std::mutex RTC_impl::ExecutionContextWorker::m_mutex |
|
mutableprotected |
◆ m_ref
| RTC::ExecutionContextService_var RTC_impl::ExecutionContextWorker::m_ref |
|
protected |
◆ m_removedComps
◆ m_removedMutex
| std::mutex RTC_impl::ExecutionContextWorker::m_removedMutex |
|
mutableprotected |
◆ m_running
| bool RTC_impl::ExecutionContextWorker::m_running {false} |
|
protected |
ExecutionContext の実行状態 true: running, false: stopped
◆ rtclog
| RTC::Logger RTC_impl::ExecutionContextWorker::rtclog {"ec_worker"} |
|
protected |
このクラス詳解は次のファイルから抽出されました: