diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/ConfigParser.cpp | 1 | ||||
-rw-r--r-- | src/MuxElements.cpp | 49 | ||||
-rw-r--r-- | src/MuxElements.h | 34 |
3 files changed, 16 insertions, 68 deletions
diff --git a/src/ConfigParser.cpp b/src/ConfigParser.cpp index 538cb76..30140bf 100644 --- a/src/ConfigParser.cpp +++ b/src/ConfigParser.cpp @@ -193,7 +193,6 @@ static void parse_linkage(ptree& pt, linkageset->id_list.push_back(link); } } - rcs.enrol(linkageset.get()); ensemble->linkagesets.push_back(linkageset); } } diff --git a/src/MuxElements.cpp b/src/MuxElements.cpp index 70930cb..cb2d545 100644 --- a/src/MuxElements.cpp +++ b/src/MuxElements.cpp @@ -805,11 +805,22 @@ size_t DabSubchannel::readFrame(uint8_t *buffer, size_t size, std::time_t second throw logic_error("Unhandled case"); } +LinkageSet::LinkageSet(const std::string& name, + uint16_t lsn, + bool active, + bool hard, + bool international) : + lsn(lsn), + active(active), + hard(hard), + international(international), + m_name(name) +{} LinkageSet LinkageSet::filter_type(const ServiceLinkType type) { - LinkageSet lsd(m_rc_name, lsn, active, hard, international); + LinkageSet lsd(m_name, lsn, active, hard, international); lsd.active = active; lsd.keyservice = keyservice; @@ -822,39 +833,3 @@ LinkageSet LinkageSet::filter_type(const ServiceLinkType type) return lsd; } - - -void LinkageSet::set_parameter(const string& parameter, - const string& value) -{ - if (parameter == "active") { - stringstream ss; - ss << value; - - lock_guard<mutex> lock(m_active_mutex); - ss >> active; - } - else { - stringstream ss; - ss << "Parameter '" << parameter << - "' is not exported by controllable " << get_rc_name(); - throw ParameterError(ss.str()); - } -} - -const string LinkageSet::get_parameter(const string& parameter) const -{ - using namespace std::chrono; - - stringstream ss; - if (parameter == "active") { - lock_guard<mutex> lock(m_active_mutex); - ss << active; - } - else { - ss << "Parameter '" << parameter << - "' is not exported by controllable " << get_rc_name(); - throw ParameterError(ss.str()); - } - return ss.str(); -} diff --git a/src/MuxElements.h b/src/MuxElements.h index 3640e6c..77d417b 100644 --- a/src/MuxElements.h +++ b/src/MuxElements.h @@ -546,32 +546,15 @@ struct ServiceLink { * TS 103 176 Clause 5.2.3 "Linkage sets". This information will * be encoded in FIG 0/6. */ -class LinkageSet : public RemoteControllable { +class LinkageSet { public: LinkageSet(const std::string& name, uint16_t lsn, bool active, bool hard, - bool international) : - RemoteControllable(name), - lsn(lsn), - active(active), - hard(hard), - international(international) - { - RC_ADD_PARAMETER(active, "Signal this linkage set active [0 or 1]"); - } - - LinkageSet(const LinkageSet& other) : - LinkageSet(other.m_rc_name, - other.lsn, - other.active, - other.hard, - other.international) - { - } + bool international); - std::string get_name(void) const { return m_rc_name; } + std::string get_name(void) const { return m_name; } std::list<ServiceLink> id_list; @@ -587,22 +570,13 @@ class LinkageSet : public RemoteControllable { std::string keyservice; // TODO replace by pointer to service - //LinkageSet& operator=(const LinkageSet& other) = default; - /* Return a LinkageSet with id_list filtered to include * only those links of a given type */ LinkageSet filter_type(const ServiceLinkType type); - /* Remote control */ - virtual void set_parameter(const std::string& parameter, - const std::string& value); - - /* Getting a parameter always returns a string. */ - virtual const std::string get_parameter(const std::string& parameter) const; - private: - mutable std::mutex m_active_mutex; + std::string m_name; }; // FIG 0/21 |