ifw-fcf
5.0.0-pre2
|
Piezo Local Control System (LCS) Interface (IF) class. More...
#include <piezoLcsIf.hpp>
Public Member Functions | |
PiezoLcsIf (std::shared_ptr< fcf::devmgr::common::IDeviceConfig > config, fcf::devmgr::common::DataContext &data_ctx) | |
piezoLcsIf constructor. More... | |
virtual | ~PiezoLcsIf ()=default |
Default destructor. More... | |
virtual void | InitObject () |
Initialize object. More... | |
bool | IsInAuto () const |
Executes the Auto RPC. More... | |
bool | IsInPos () const |
Check if piezo is in POS state. More... | |
void | Auto () |
void | Home () |
Executes the Home RPC. More... | |
void | Pos () |
Executes the Pos RPC. More... | |
void | MoveBits (short bit1, short bit2, short bit3) |
Executes the MoveBits RPC. More... | |
void | MoveUser (double pos1, double pos2, double pos3) |
Executes the MoveUser RPC. More... | |
virtual void | ReadStatus (PiezoControllerData &status) |
Read status from the controller. More... | |
void | Listener (protocol::base::VectorVariant ¶ms) |
Callback to manage changes on the monitored items. More... | |
virtual std::string | GetRpcError (const short error_code) const |
![]() | |
DeviceLcsIf (std::shared_ptr< IDeviceConfig > config, DataContext &data_ctx) | |
DeviceLcsIf constructor. More... | |
virtual void | RegisterComm (std::shared_ptr< protocol::base::IComm > comm_if, protocol::base::Dispatcher<> &failure, protocol::base::Dispatcher<> &normal) |
Register a communication interface. More... | |
virtual void | Connect () |
Connect to the controller or simulator. More... | |
virtual void | Disconnect () |
Disconnect from the controller of simulator. More... | |
virtual bool | IsNotReady () const |
Check if controller is in Standby/NotReady state. More... | |
virtual bool | IsReady () const |
Check if controller is in Standby/Ready state. More... | |
virtual bool | IsDisabling () const |
Check if controller is in Disabling state. More... | |
virtual bool | IsOperational () const |
Check if controller is in Operational. More... | |
virtual bool | IsHwFailure () const |
Check if controller is in Hardware Failure. More... | |
virtual void | Init () |
Executes the Init RPC. More... | |
virtual void | Enable () |
Executes the Enable RPC. More... | |
virtual void | Disable () |
Executes the Disable RPC. More... | |
virtual void | Stop () |
Executes the Stop RPC. More... | |
virtual void | Reset () |
Executes the Reset RPC. More... | |
virtual void | StartMonitoring () |
Start monitoring of controller attributes. More... | |
virtual void | StopMonitoring () |
Stop monitoring of controller attributes. More... | |
virtual void | ReadStatus (DeviceControllerData &status) |
ReadStatus. More... | |
virtual std::string | GetHwError (int &error_code, const bool update=false) |
Get error message. More... | |
std::string | GetMapValue (const std::string &category, const std::string &key) const |
Get mapping value. More... | |
protocol::base::Dispatcher< protocol::base::VectorVariant & > & | GetDispatcher () |
bool | IsConfigLoaded () const |
Check if configuration was loaded. More... | |
bool | IsConnected () const |
Check is the communication was established. More... | |
virtual std::shared_ptr< IDeviceConfig > | GetDeviceConfig () const |
Get a pointer of device configuration. More... | |
const elt::configng::CiiConfigInstanceNamespace & | GetCfgInstance () const |
virtual void | GetStates (int &state, int &substate) |
Get states (state and substate) of the controller. More... | |
Protected Attributes | |
std::vector< int > | m_pos_bit {0,0,0} |
std::vector< double > | m_pos_user {0.0, 0.0, 0.0} |
![]() | |
std::unique_ptr< elt::configng::CiiConfigDocument > | m_config_doc |
Config document for mapping file. More... | |
std::shared_ptr< protocol::base::IComm > | m_comm |
Shared pointer to the communication object. More... | |
std::shared_ptr< IDeviceConfig > | m_config |
Shared pointer to the device config object. More... | |
protocol::base::Dispatcher< protocol::base::VectorVariant & > | m_dispatcher |
Dispatcher for managing subscription events. More... | |
protocol::base::Dispatcher | m_failure |
Dispatcher for managing failures in the communication. More... | |
protocol::base::Dispatcher | m_normal |
Dispatcher for managing recovery of communication failures. More... | |
int | m_state {} |
Actual controller state. More... | |
int | m_substate {} |
Actual controller substate. More... | |
bool | m_local {false} |
Actual local flag. More... | |
bool | m_error_code {false} |
Actual error code. More... | |
bool | m_config_loaded {false} |
Flag indicating whether the configuration was successfully loaded. More... | |
bool | m_connected {false} |
Flag indicating whether the LCS is connected. More... | |
fcf::devmgr::common::DataContext & | m_data_ctx |
std::string | m_lcs_prefix |
Store the prefix for storing keys in the database. More... | |
std::unordered_map< std::string, short > | m_ua_status_map |
std::vector< std::string > | m_ua_monitor_vector |
std::unordered_map< short, std::string > | m_hw_errors |
Additional Inherited Members | |
![]() | |
enum | { STAT_LOCAL = 1 , STAT_ERROR = 2 , STAT_HW_STATUS = 3 , STAT_STATE = 4 , STAT_SUBSTATE = 5 } |
![]() | |
void | LoadConfig () |
Load the YAML configuration. More... | |
void | ExecuteRpc (const std::string &obj, const std::string &proc, protocol::base::VectorVariant &attr_list) |
int | ReadErrorCode () |
void | StoreUaNames (const std::vector< std::pair< std::string, unsigned int >> &ualist) |
StoreUaNames. More... | |
void | StoreAttribute (const std::string key, const protocol::base::Variant &value, int attribute) |
Store the updated into the DB. More... | |
Piezo Local Control System (LCS) Interface (IF) class.
This class manages the Piezo connection to the LCS encapsulating all basic communication with the controller or the simulator.
Each RPC call is synchronous but it only starts the action in the controller. The controller will return successfully if the action can be started, not that the action was completed.
The completion of the action must be monitored by reading the status of the controller but this is out of the scope of this class.
fcf::devmgr::piezo::PiezoLcsIf::PiezoLcsIf | ( | std::shared_ptr< fcf::devmgr::common::IDeviceConfig > | config, |
fcf::devmgr::common::DataContext & | data_ctx | ||
) |
piezoLcsIf constructor.
[in,out] | config | Shared pointer to the device configuration. |
[in,out] | data_ctx | Reference to the data context object. |
[in] | initialise | Flag to control the initialization. This flag is used when using child classes. |
[in] | with_publisher | Flag to be used in unit tests to avoid crash of CII. |
|
virtualdefault |
Default destructor.
void fcf::devmgr::piezo::PiezoLcsIf::Auto | ( | ) |
|
virtual |
error_code | Error code |
Implements fcf::devmgr::common::DeviceLcsIf.
void fcf::devmgr::piezo::PiezoLcsIf::Home | ( | ) |
Executes the Home RPC.
an | exception if an error ocurrs. |
This RPC call shall bring the controller to HOME position.
|
virtual |
Initialize object.
an | exception if an error ocurrs. |
This method carries out basic object initialization. It is done in a separate method to allow overriden this functionality in children classes.
Reimplemented from fcf::devmgr::common::DeviceLcsIf.
bool fcf::devmgr::piezo::PiezoLcsIf::IsInAuto | ( | ) | const |
Executes the Auto RPC.
an | exception if an error ocurrs. |
This RPC call shall bring the controller to Operational/Auto state.
Check if piezo is in AUTO state
bool fcf::devmgr::piezo::PiezoLcsIf::IsInPos | ( | ) | const |
Check if piezo is in POS state.
|
virtual |
Callback to manage changes on the monitored items.
[in] | params | Vector containing the list of atributes that have changed |
This method implement the actions associated to the events originated from the monitoring of attributes.
This method is storing in the database the values that have changed. It also publish the events for the clients via zeroMQ.
Reimplemented from fcf::devmgr::common::DeviceLcsIf.
void fcf::devmgr::piezo::PiezoLcsIf::MoveBits | ( | short | bit1, |
short | bit2, | ||
short | bit3 | ||
) |
Executes the MoveBits RPC.
bit1 | Bit parameter for axis 1. |
bit2 | Bit parameter for axis 2. |
bit3 | Bit parameter for axis 3. |
an | exception if an error ocurrs. |
This RPC call make the piezo moving in bits.
void fcf::devmgr::piezo::PiezoLcsIf::MoveUser | ( | double | pos1, |
double | pos2, | ||
double | pos3 | ||
) |
Executes the MoveUser RPC.
pos1 | User position parameter for axis 1. |
pos2 | User position parameter for axis 2. |
pos3 | User position parameter for axis 3. |
an | exception if an error ocurrs. |
This RPC call make the piezo moving in user units.
void fcf::devmgr::piezo::PiezoLcsIf::Pos | ( | ) |
Executes the Pos RPC.
an | exception if an error ocurrs. |
|
virtual |
Read status from the controller.
status | structure containing the status of the controller. |
|
protected |
|
protected |