RTC::MultiModeObject Interface Reference

import "RTC.idl";

Inheritance diagram for RTC::MultiModeObject:

RTC::LightweightRTObject RTC::ModeCapable RTC::MultiModeComponentAction RTC::ComponentAction

List of all members.

Public Member Functions

ReturnCode_t initialize ()
 initialize
ReturnCode_t finalize ()
 finalize
boolean is_alive (in ExecutionContext exec_context)
 is_alive
ReturnCode_t exit ()
 exit
ExecutionContextHandle_t attach_context (in ExecutionContext exec_context)
 attach_context
ReturnCode_t detach_context (in ExecutionContextHandle_t exec_handle)
 detach_context
ExecutionContext get_context (in ExecutionContextHandle_t exec_handle)
 get_context
ExecutionContextList get_owned_contexts ()
 get_owned_contexts
ExecutionContextList get_participating_contexts ()
 * get_participating_contexts
ExecutionContextHandle_t get_context_handle (in ExecutionContext cxt)
 get_context_handle
ReturnCode_t on_initialize ()
 on_initialize
ReturnCode_t on_finalize ()
 on_finalize
ReturnCode_t on_startup (in ExecutionContextHandle_t exec_handle)
 on_startup
ReturnCode_t on_shutdown (in ExecutionContextHandle_t exec_handle)
 on_shutdown
ReturnCode_t on_activated (in ExecutionContextHandle_t exec_handle)
 on_activated
ReturnCode_t on_deactivated (in ExecutionContextHandle_t exec_handle)
 on_deactivated
ReturnCode_t on_aborting (in ExecutionContextHandle_t exec_handle)
 on_aborting
ReturnCode_t on_error (in ExecutionContextHandle_t exec_handle)
 on_error
ReturnCode_t on_reset (in ExecutionContextHandle_t exec_handle)
 on_reset
Mode get_default_mode ()
 get_default_mode
Mode get_current_mode ()
 get_current_mode
Mode get_current_mode_in_context (in ExecutionContext exec_context)
 get_current_mode_in_context
Mode get_pending_mode ()
 get_pending_mode
Mode get_pending_mode_in_context (in ExecutionContext exec_context)
 get_pending_mode_in_context
ReturnCode_t set_mode (in Mode new_mode, in boolean immediate)
 set_mode
ReturnCode_t on_mode_changed (in ExecutionContextHandle_t exec_handle)
 on_mode_changed


Member Function Documentation

ReturnCode_t RTC::LightweightRTObject::initialize (  )  [inherited]

initialize

Description

Initialize the RTC that realizes this interface.

Semantics

The invocation of this operation shall result in the invocation of the callback ComponentAction::on_initialize.

Constraints

  • An RTC may be initialized only while it is in the Created state. Any attempt to invoke this operation while in another state shall fail with ReturnCode_t::PRECONDITION_NOT_MET.
  • Application developers are not expected to call this operation directly; it exists for use by the RTC infrastructure.

ReturnCode_t RTC::LightweightRTObject::finalize (  )  [inherited]

finalize

Description

Finalize the RTC that realizes this interface, preparing it for destruction.

Semantics

This invocation of this operation shall result in the invocation of the callback ComponentAction::on_finalize

Constraints

  • An RTC may not be finalized while it is participating in any execution context. It must first be removed with ExecutionContextOperations::remove_component. Otherwise, this operation shall fail with ReturnCode_t::PRECONDITION_NOT_MET. See Figure 5.9.

  • An RTC may not be finalized while it is in the Created state. Any attempt to invoke this operation while in that state shall fail with ReturnCode_t::PRECONDITION_NOT_MET.

  • Application developers are not expected to call this operation directly; it exists for use by the RTC infrastructure.

boolean RTC::LightweightRTObject::is_alive ( in ExecutionContext  exec_context  )  [inherited]

is_alive

Description

A component is alive or not regardless of the execution context from which it is observed. However, whether or not it is Active, Inactive, or in Error is dependent on the execution context(s) (see Figure 5.7) in which it is running. That is, it may be Active in one context but Inactive in another. Therefore, this operation shall report whether this RTC is either Active, Inactive, or in Error; which of those states a component is in with respect to a particular context may be queried from the context itself.

ReturnCode_t RTC::LightweightRTObject::exit (  )  [inherited]

exit

Description

Stop the RTC¡Çs execution context(s) and finalize it along with its contents.

Semantics

Any execution contexts for which the RTC is the owner shall be stopped. If the RTC participates in any execution contexts belonging to another RTC that contains it, directly or indirectly (i.e., the containing RTC is the owner of the ExecutionContext), it shall be deactivated in those contexts. After the RTC is no longer Active in any Running execution context, it and any RTCs contained transitively within it shall be finalized.

Constraints

An RTC cannot be exited if it has not yet been initialized. Any attempt to exit an RTC that is in the Created state shall fail with ReturnCode_t::PRECONDITION_NOT_MET.

ExecutionContextHandle_t RTC::LightweightRTObject::attach_context ( in ExecutionContext  exec_context  )  [inherited]

attach_context

Description

Inform this RTC that it is participating in the given execution context. Return a handle that represents the association of this RTC with the context.

Semantics

This operation is intended to be invoked by ExecutionContextOperations::add_component (see Section 5.2.2.6.6). It is not intended for use by other clients.

ReturnCode_t RTC::LightweightRTObject::detach_context ( in ExecutionContextHandle_t  exec_handle  )  [inherited]

detach_context

Description

Inform this RTC that it is no longer participating in the given execution context.

Semantics

This operation is intended to be invoked by ExecutionContextOperations::remove_component (see Section 5.2.2.6.7). It is not intended for use by other clients.

Constraints

  • This operation may not be invoked if this RTC is not already participating in the execution context. Such a call shall fail with ReturnCode_t::PRECONDITION_NOT_MET.

  • This operation may not be invoked if this RTC is Active in the indicated execution context. Otherwise, it shall fail with ReturnCode_t::PRECONDITION_NOT_MET.

ExecutionContext RTC::LightweightRTObject::get_context ( in ExecutionContextHandle_t  exec_handle  )  [inherited]

get_context

Description

Obtain a reference to the execution context represented by the given handle.

Semantics

The mapping from handle to context is specific to a particular RTC instance. The given handle must have been obtained by a previous call to attach_context on this RTC.

ExecutionContextList RTC::LightweightRTObject::get_owned_contexts (  )  [inherited]

get_owned_contexts

Description

This operation returns a list of all execution contexts owned by this RTC.

ExecutionContextList RTC::LightweightRTObject::get_participating_contexts (  )  [inherited]

* get_participating_contexts

Description

This operation returns a list of all execution contexts in which this RTC participates.

Semantics

Each call to attach_context causes the provided context to be added to this list. Each call to detach_context causes the provided context to be removed from this list.

ExecutionContextHandle_t RTC::LightweightRTObject::get_context_handle ( in ExecutionContext  cxt  )  [inherited]

get_context_handle

Description

This operation returns a handle that is associated with the given execution context.

ReturnCode_t RTC::ComponentAction::on_initialize (  )  [inherited]

on_initialize

Description

The RTC has been initialized and entered the Alive state.

Semantics

Any RTC-specific initialization logic should be performed here.

ReturnCode_t RTC::ComponentAction::on_finalize (  )  [inherited]

on_finalize

Description

The RTC is being destroyed.

Semantics

Any final RTC-specific tear-down logic should be performed here.

ReturnCode_t RTC::ComponentAction::on_startup ( in ExecutionContextHandle_t  exec_handle  )  [inherited]

on_startup

Description

The given execution context, in which the RTC is participating, has transitioned from Stopped to Running.

ReturnCode_t RTC::ComponentAction::on_shutdown ( in ExecutionContextHandle_t  exec_handle  )  [inherited]

on_shutdown

Description

The given execution context, in which the RTC is participating, has transitioned from Running to Stopped.

ReturnCode_t RTC::ComponentAction::on_activated ( in ExecutionContextHandle_t  exec_handle  )  [inherited]

on_activated

Description

The RTC has been activated in the given execution context.

ReturnCode_t RTC::ComponentAction::on_deactivated ( in ExecutionContextHandle_t  exec_handle  )  [inherited]

on_deactivated

Description

The RTC has been deactivated in the given execution context.

ReturnCode_t RTC::ComponentAction::on_aborting ( in ExecutionContextHandle_t  exec_handle  )  [inherited]

on_aborting

Description

The RTC is transitioning from the Active state to the Error state in some execution context.

Semantics

This callback is invoked only a single time for time that the RTC transitions into the Error state from another state. This behavior is in contrast to that of on_error.

ReturnCode_t RTC::ComponentAction::on_error ( in ExecutionContextHandle_t  exec_handle  )  [inherited]

on_error

Description

The RTC remains in the Error state.

Semantics

If the RTC is in the Error state relative to some execution context when it would otherwise be invoked from that context (according to the context¡Çs ExecutionKind), this callback shall be invoked instead. For example,

  • If the ExecutionKind is PERIODIC, this operation shall be invoked in sorted order at the rate of the context instead of DataFlowComponentAction::on_execute and on_state_update.

ReturnCode_t RTC::ComponentAction::on_reset ( in ExecutionContextHandle_t  exec_handle  )  [inherited]

on_reset

Description

The RTC is in the Error state. An attempt is being made to recover it such that it can return to the Inactive state.

Semantics

If the RTC was successfully recovered and can safely return to the Inactive state, this method shall complete with ReturnCode_t::OK. Any other result shall indicate that the RTC should remain in the Error state.

Mode RTC::ModeCapable::get_default_mode (  )  [inherited]

get_default_mode

Description

This operation shall return the mode in which the RTC shall be when no other mode has been set.

Constraints

  • This operation shall not return nil.

Mode RTC::ModeCapable::get_current_mode (  )  [inherited]

get_current_mode

Description

This operation shall return the last mode to have stabilized. If no mode has been explicitly set, the current mode shall be the default mode.

Constraints

  • This operation shall never return nil.

Mode RTC::ModeCapable::get_current_mode_in_context ( in ExecutionContext  exec_context  )  [inherited]

get_current_mode_in_context

Description

This operation returns the current mode of the component as seen by the indicated execution context.

Semantics

The manner in which this property changes is described in Figure 5.26.

Mode RTC::ModeCapable::get_pending_mode (  )  [inherited]

get_pending_mode

Description

This operation shall return the last mode to have been passed to set_mode that has not yet stabilized. Once the RTC¡Çs mode has stabilized, this operation shall return nil.

Mode RTC::ModeCapable::get_pending_mode_in_context ( in ExecutionContext  exec_context  )  [inherited]

get_pending_mode_in_context

Description

If the last mode to be requested by a call to set_mode is different than the current mode as seen by the indicated execution context (see get_current_mode_in_context), this operation returns the former. If the requested mode has already been seen in that context, it returns nil.

Semantics

See Figure 5.26 for a description of how the pending mode relates to the current mode within a given execution context.

ReturnCode_t RTC::ModeCapable::set_mode ( in Mode  new_mode,
in boolean  immediate 
) [inherited]

set_mode

Description

This operation shall request that the RTC change to the indicated mode.

Semantics

Usually, the new mode will be pending in each execution context in which the component executes until the next sample period (if the execution kind is PERIODIC); at that point it will become the current mode in that context and there will no longer be a pending mode. However, in some cases it is important for a mode change to take place immediately; for example, a serious fault has occurred and the component must enter an emergency mode to ensure fail-safe behavior in a safety-critical system. In such a case, immediate should be true and the mode change will take place in all contexts without waiting for the next sample period.

ReturnCode_t RTC::MultiModeComponentAction::on_mode_changed ( in ExecutionContextHandle_t  exec_handle  )  [inherited]

on_mode_changed

Description

This callback is invoked each time the observed mode of a component has changed with respect to a particular execution context.

Semantics

If the context is PERIODIC, this callback shall come before the next call to on_execute (see Section 5.3.1.2.1) within that context. The new mode can be retrieved with get_current_mode_in_context. If the result is the same as the result of get_current_mode, the mode has stabilized.


The documentation for this interface was generated from the following file:

Generated on Wed Jun 16 15:02:16 2010 for OpenRTM by  doxygen 1.5.5