From 9ef1c0adbf9399c55deeede3cf629dd4e8c20304 Mon Sep 17 00:00:00 2001 From: Neale Ranns Date: Fri, 3 Nov 2017 04:39:05 -0700 Subject: VOM reshuffle split the VOM into two halves; a top/front-end and a bottom/backend. Only the backend includes the auto-generated VAPI. This serves two purposes: 1 - improves ompile times for VOM, since the VAPI is included only in the backend. 2 - does not expose VAPI to users of VOM Change-Id: I17b93aeaef10c0eba8612016d9034aca5628d9f7 Signed-off-by: Neale Ranns Signed-off-by: Mohsin Kazmi --- src/vpp-api/vom/dhcp_config.hpp | 149 ++-------------------------------------- 1 file changed, 6 insertions(+), 143 deletions(-) (limited to 'src/vpp-api/vom/dhcp_config.hpp') diff --git a/src/vpp-api/vom/dhcp_config.hpp b/src/vpp-api/vom/dhcp_config.hpp index 9ce0635c939..f64a3c8a2e2 100644 --- a/src/vpp-api/vom/dhcp_config.hpp +++ b/src/vpp-api/vom/dhcp_config.hpp @@ -13,22 +13,20 @@ * limitations under the License. */ -#ifndef __VOM_DHCP_INTERFACE_H__ -#define __VOM_DHCP_INTERFACE_H__ +#ifndef __VOM_DHCP_CONFIG_H__ +#define __VOM_DHCP_CONFIG_H__ -#include "vom/dump_cmd.hpp" #include "vom/hw.hpp" #include "vom/inspect.hpp" #include "vom/interface.hpp" #include "vom/object_base.hpp" #include "vom/om.hpp" -#include "vom/rpc_cmd.hpp" #include "vom/singular_db.hpp" -#include "vom/sub_interface.hpp" - -#include namespace VOM { +namespace dhcp_config_cmds { +class events_cmd; +}; /** * A representation of DHCP client configuration on an interface */ @@ -72,97 +70,6 @@ public: */ static void dump(std::ostream& os); - /** - * A command class that binds the DHCP config to the interface - */ - class bind_cmd - : public rpc_cmd, rc_t, vapi::Dhcp_client_config> - { - public: - /** - * Constructor - */ - bind_cmd(HW::item& item, - const handle_t& itf, - const std::string& hostname, - const l2_address_t& client_id); - - /** - * Issue the command to VPP/HW - */ - rc_t issue(connection& con); - /** - * convert to string format for debug purposes - */ - std::string to_string() const; - - /** - * Comparison operator - only used for UT - */ - bool operator==(const bind_cmd& i) const; - - private: - /** - * Reference to the HW::item of the interface to bind - */ - const handle_t& m_itf; - - /** - * The DHCP client's hostname - */ - const std::string m_hostname; - - /** - * The DHCP client's ID - */ - const l2_address_t m_client_id; - }; - - /** - * A cmd class that Unbinds Dhcp Config from an interface - */ - class unbind_cmd - : public rpc_cmd, rc_t, vapi::Dhcp_client_config> - { - public: - /** - * Constructor - */ - unbind_cmd(HW::item& item, - const handle_t& itf, - const std::string& hostname); - - /** - * Issue the command to VPP/HW - */ - rc_t issue(connection& con); - /** - * convert to string format for debug purposes - */ - std::string to_string() const; - - /** - * Comparison operator - only used for UT - */ - bool operator==(const unbind_cmd& i) const; - - private: - /** - * Reference to the HW::item of the interface to unbind - */ - const handle_t& m_itf; - - /** - * The DHCP client's hostname - */ - const std::string m_hostname; - }; - - /** - * Forward declartion of the Event Command - */ - class events_cmd; - /** * A class that listens to DHCP Events */ @@ -178,7 +85,7 @@ public: * listener's virtual function invoked when a DHCP event is * available to read */ - virtual void handle_dhcp_event(events_cmd* cmd) = 0; + virtual void handle_dhcp_event(dhcp_config_cmds::events_cmd* cmd) = 0; /** * Return the HW::item associated with this command @@ -192,50 +99,6 @@ public: HW::item m_status; }; - /** - * A functor class represents our desire to recieve interface events - */ - class events_cmd - : public event_cmd - { - public: - /** - * Constructor - */ - events_cmd(event_listener& el); - - /** - * Issue the command to VPP/HW - subscribe to DHCP events - */ - rc_t issue(connection& con); - - /** - * Retire the command - unsubscribe - */ - void retire(connection& con); - /** - * convert to string format for debug purposes - */ - std::string to_string() const; - - /** - * Comparison operator - only used for UT - */ - bool operator==(const events_cmd& i) const; - - /** - * called in the VAPI RX thread when data is available. - */ - void notify(); - - private: - void succeeded() {} - /** - * The listner of this command - */ - event_listener& m_listener; - }; - private: /** * Class definition for listeners to OM events -- cgit 1.2.3-korg