OpenRTM-aist  2.1.0
ConfigAdmin.h
Go to the documentation of this file.
1 // -*- C++ -*-
19 #ifndef RTC_CONFIGADMIN_H
20 #define RTC_CONFIGADMIN_H
21 
22 #include <coil/Properties.h>
23 #include <coil/stringutil.h>
25 
26 #include <string>
27 #include <vector>
28 #include <iostream>
29 
44 namespace RTC
45 {
58 
71 
84 
97 
110 
123 
124  // forward decl
125  class ConfigAdmin;
126 
127  //============================================================
128  // ConfigBase class
129  //============================================================
160  struct ConfigBase
161  {
183  ConfigBase(const char* name_, const char* def_val)
184  : name(name_), default_value(def_val),
185  string_value(""), m_admin(nullptr), m_callback(nullptr)
186  {}
187 
203  virtual ~ConfigBase() = default;
204 
205  // typedef of ConfigAdmin's member function
206  using CallbackFunc = void (ConfigAdmin::*)(const char *, const char*);
207 
225 
241  void notifyUpdate(const char* key, const char* val);
242 
268  virtual bool update(const char* val) = 0;
269 
277  const char* name;
278 
286  const char* default_value;
287 
288  protected:
296  std::string string_value;
313  };
314 
315  //============================================================
316  // Config template class
317  //============================================================
350  template <typename VarType,
351  typename TransFunc = bool (*)(VarType&, const char*)>
352  class Config
353  : public ConfigBase
354  {
355  public:
381  Config(const char* conf_name, VarType& var, const char* def_val,
382  TransFunc trans = coil::stringTo)
383  : ConfigBase(conf_name, def_val), m_var(var), m_trans(trans)
384  {
385  }
386 
402  ~Config() override = default;
403 
427  bool update(const char* val) override
428  {
429  if (string_value == val) { return true; }
430  string_value = val;
431  // value changed
432  if ((*m_trans)(m_var, val))
433  {
434  notifyUpdate(name, val);
435  return true;
436  }
437  (*m_trans)(m_var, default_value);
438  notifyUpdate(name, val);
439  return false;
440  }
441 
442  protected:
450  VarType& m_var;
451 
460  TransFunc m_trans;
461  };
462 
463  //============================================================
464  // ConfigAdmin class
465  //============================================================
612  {
613  public:
633  explicit ConfigAdmin(coil::Properties& configsets);
634 
651 
692  template <typename VarType>
693  bool bindParameter(const char* param_name, VarType& var,
694  const char* def_val,
695  bool (*trans)(VarType&, const char*) = coil::stringTo)
696  {
697  if (param_name == nullptr) { return false; }
698  if (def_val == nullptr) { return false; }
699  if (isExist(param_name)) { return false; }
700  if (!trans(var, def_val)) { return false; }
701  Config<VarType>* c = new Config<VarType>(param_name, var, def_val, trans);
702  m_params.emplace_back(c);
704  update(getActiveId(), param_name);
705  return true;
706  }
707 
733  bool unbindParameter(const char* param_name);
734 
761  void update();
762 
797  void update(const char* config_set);
798 
836  void update(const char* config_set, const char* config_param);
837 
864  bool isExist(const char* param_name);
865 
886  bool isChanged() {return m_changed;}
887 
907  coil::vstring& changedParameters() { return m_changedParam; }
908 
928  const char* getActiveId() {return m_activeId.c_str();}
929 
954  bool haveConfig(const char* config_id)
955  {
956  return (m_configsets.hasKey(config_id) == nullptr) ? false : true;
957  }
958 
979  bool isActive()
980  {
981  return m_active;
982  }
983 
1003  const std::vector<coil::Properties*>& getConfigurationSets();
1004 
1032  const coil::Properties& getConfigurationSet(const char* config_id);
1033 
1064 
1089 
1113  bool addConfigurationSet(const coil::Properties& config_set);
1114 
1169  bool removeConfigurationSet(const char* config_id);
1170 
1198  bool activateConfigurationSet(const char* config_id);
1199 
1200  //------------------------------------------------------------
1201  // obsolete functions
1202  //
1204 
1206 
1208 
1210 
1212 
1214  //
1215  // end of obsolete functions
1216  //------------------------------------------------------------
1217 
1251  ConfigurationParamListener* listener,
1252  bool autoclean = true);
1253 
1279  ConfigurationParamListener* listener);
1280 
1313  ConfigurationSetListener* listener,
1314  bool autoclean = true);
1315 
1339  ConfigurationSetListener* listener);
1340 
1375  void
1377  ConfigurationSetNameListener* listener,
1378  bool autoclean = true);
1379 
1406  void
1408  ConfigurationSetNameListener* listener);
1409 
1410  protected:
1430  void onUpdate(const char* config_set);
1431 
1453  void onUpdateParam(const char* config_param, const char* config_value);
1454 
1474  void onSetConfigurationSet(const coil::Properties& config_set);
1475 
1495  void onAddConfigurationSet(const coil::Properties& config_set);
1496 
1516  void onRemoveConfigurationSet(const char* config_id);
1517 
1537  void onActivateSet(const char* config_id);
1538 
1539  private:
1540  ConfigAdmin(const ConfigAdmin& ca) = delete;
1541  ConfigAdmin& operator=(const ConfigAdmin& ca) = delete;
1542 
1543  struct find_conf
1544  {
1545  std::string m_name;
1546  explicit find_conf(const char* name) : m_name(name) {}
1547  bool operator()(ConfigBase* conf)
1548  {
1549  if (conf == nullptr) { return false; }
1550  return (m_name == conf->name);
1551  }
1552  };
1553 
1554  coil::Properties& m_configsets;
1555  coil::Properties m_emptyconf;
1556  std::vector<ConfigBase*> m_params;
1557  std::string m_activeId;
1558  bool m_active;
1559  bool m_changed;
1560  coil::vstring m_changedParam;
1561  coil::vstring m_newConfig;
1562  ConfigurationListeners m_listeners;
1563 
1564  };
1565 } // namespace RTC
1566 #endif // RTC_CONFIGADMIN_H
Configuration related event listener classes.
ConfigAdmin class.
Definition: ConfigAdmin.h:612
bool addConfigurationSet(const coil::Properties &config_set)
Add the configuration value to configuration set.
bool isChanged()
Confirm to change configuration parameters.
Definition: ConfigAdmin.h:886
ConfigAdmin(coil::Properties &configsets)
Constructor.
bool isActive()
Confirm to activate configuration set.
Definition: ConfigAdmin.h:979
coil::vstring & changedParameters()
Changed parameters list.
Definition: ConfigAdmin.h:907
bool unbindParameter(const char *param_name)
Unbinding configuration parameters.
void setOnActivateSet(OnActivateSetCallback *cb)
void update(const char *config_set, const char *config_param)
Update the values of configuration parameters (By name)
const coil::Properties & getConfigurationSet(const char *config_id)
Get a configuration set by specified ID.
bool activateConfigurationSet(const char *config_id)
Activate the configuration set.
bool bindParameter(const char *param_name, VarType &var, const char *def_val, bool(*trans)(VarType &, const char *)=coil::stringTo)
Setup for configuration parameters.
Definition: ConfigAdmin.h:693
const std::vector< coil::Properties * > & getConfigurationSets()
Get all configuration sets.
void setOnAddConfigurationSet(OnAddConfigurationAddCallback *cb)
void update()
Update the values of configuration parameters (Active configuration set)
void removeConfigurationSetListener(ConfigurationSetListenerType type, ConfigurationSetListener *listener)
Removing ConfigurationSetListener.
const char * getActiveId()
Get ID of active configuration set.
Definition: ConfigAdmin.h:928
void update(const char *config_set)
Update configuration parameter (By ID)
void setOnUpdateParam(OnUpdateParamCallback *cb)
void removeConfigurationParamListener(ConfigurationParamListenerType type, ConfigurationParamListener *listener)
Removing ConfigurationParamListener.
bool isExist(const char *param_name)
Check the existence of configuration parameters.
void setOnSetConfigurationSet(OnSetConfigurationSetCallback *cb)
void removeConfigurationSetNameListener(ConfigurationSetNameListenerType type, ConfigurationSetNameListener *listener)
Removing ConfigurationSetNameListener.
void setOnUpdate(OnUpdateCallback *cb)
void addConfigurationParamListener(ConfigurationParamListenerType type, ConfigurationParamListener *listener, bool autoclean=true)
Adding ConfigurationParamListener.
void onUpdateParam(const char *config_param, const char *config_value)
When the configuration parameter is updated, it is called.
void onSetConfigurationSet(const coil::Properties &config_set)
Called when the property is added to the configuration set.
void onRemoveConfigurationSet(const char *config_id)
Called when the configuration set has been deleted.
void onAddConfigurationSet(const coil::Properties &config_set)
Called when a set value is added to the configuration set.
void setOnRemoveConfigurationSet(OnRemoveConfigurationSetCallback *cb)
void addConfigurationSetListener(ConfigurationSetListenerType type, ConfigurationSetListener *listener, bool autoclean=true)
Adding ConfigurationSetListener.
const coil::Properties & getActiveConfigurationSet()
Get the active configuration set.
void addConfigurationSetNameListener(ConfigurationSetNameListenerType type, ConfigurationSetNameListener *listener, bool autoclean=true)
Adding ConfigurationSetNameListener.
void onActivateSet(const char *config_id)
Called when the configuration set is made active.
void onUpdate(const char *config_set)
When the configuration parameter is updated, it is called.
~ConfigAdmin()
Virtual Destructor.
bool haveConfig(const char *config_id)
Check the existence of configuration set.
Definition: ConfigAdmin.h:954
bool removeConfigurationSet(const char *config_id)
Remove the configuration set.
bool setConfigurationSetValues(const coil::Properties &config_set)
Add to configuration set from specified property.
Config class.
Definition: ConfigAdmin.h:354
VarType & m_var
Configuration parameter variable.
Definition: ConfigAdmin.h:450
~Config() override=default
Virtual Destructor.
bool update(const char *val) override
Update a bind parameter value.
Definition: ConfigAdmin.h:427
Config(const char *conf_name, VarType &var, const char *def_val, TransFunc trans=coil::stringTo)
Constructor.
Definition: ConfigAdmin.h:381
TransFunc m_trans
Transformation function to convert configuration parameter type into string format.
Definition: ConfigAdmin.h:460
ConfigurationParamListener class.
Definition: ConfigurationListener.h:75
ConfigurationSetListener class.
Definition: ConfigurationListener.h:191
ConfigurationSetNameListener class.
Definition: ConfigurationListener.h:304
RT-Component.
ConfigurationSetNameListenerType
The types of ConfigurationSetNameListener.
Definition: ConfigurationListener.h:272
ConfigurationSetListenerType
The types of ConfigurationSetListener.
Definition: ConfigurationListener.h:161
coil::Properties Properties
Definition: RTC.h:72
ConfigurationParamListenerType
The types of ConnectorDataListener.
Definition: ConfigurationListener.h:46
ConfigBase abstract class.
Definition: ConfigAdmin.h:161
const char * name
Configuration name.
Definition: ConfigAdmin.h:277
const char * default_value
Default value in string format.
Definition: ConfigAdmin.h:286
ConfigAdmin * m_admin
A pointer to the ConfigAdmin object.
Definition: ConfigAdmin.h:304
virtual bool update(const char *val)=0
Pure virtual function to update configuration parameter values.
ConfigBase(const char *name_, const char *def_val)
Constructer.
Definition: ConfigAdmin.h:183
void(ConfigAdmin::*)(const char *, const char *) CallbackFunc
Definition: ConfigAdmin.h:206
void setCallback(ConfigAdmin *cadmin, CallbackFunc cbf)
Setting callback.
std::string string_value
Current value in string format.
Definition: ConfigAdmin.h:296
void notifyUpdate(const char *key, const char *val)
Observer function to notify variable changed.
CallbackFunc m_callback
A member function pointer to the callback function.
Definition: ConfigAdmin.h:312
virtual ~ConfigBase()=default
Virtual Destructor.