VAT for qos_record_enable_disable API
[vpp.git] / src / vpp-api / vom / sub_interface.cpp
index de56bf2..42f7579 100644 (file)
@@ -14,6 +14,7 @@
  */
 
 #include "vom/sub_interface.hpp"
+#include "vom/sub_interface_cmds.hpp"
 
 namespace VOM {
 /**
@@ -28,15 +29,14 @@ sub_interface::sub_interface(const interface& parent,
 {
 }
 
-sub_interface::sub_interface(const handle_t& handle,
-                             const interface& parent,
+/**
+ * Construct a new object matching the desried state
+ */
+sub_interface::sub_interface(const interface& parent,
                              admin_state_t state,
+                             const route_domain& rd,
                              vlan_id_t vlan)
-  : interface(handle,
-              l2_address_t::ZERO,
-              mk_name(parent, vlan),
-              parent.type(),
-              state)
+  : interface(mk_name(parent, vlan), parent.type(), state, rd)
   , m_parent(parent.singular())
   , m_vlan(vlan)
 {
@@ -55,6 +55,13 @@ sub_interface::sub_interface(const sub_interface& o)
 {
 }
 
+bool
+sub_interface::operator==(const sub_interface& s) const
+{
+  return (interface::operator==(s) && (m_parent->key() == s.m_parent->key()) &&
+          (m_vlan == s.m_vlan));
+}
+
 std::string
 sub_interface::mk_name(const interface& parent, vlan_id_t vlan)
 {
@@ -64,7 +71,8 @@ sub_interface::mk_name(const interface& parent, vlan_id_t vlan)
 std::queue<cmd*>&
 sub_interface::mk_create_cmd(std::queue<cmd*>& q)
 {
-  q.push(new create_cmd(m_hdl, name(), m_parent->handle(), m_vlan));
+  q.push(new sub_interface_cmds::create_cmd(m_hdl, name(), m_parent->handle(),
+                                            m_vlan));
 
   return (q);
 }
@@ -72,7 +80,7 @@ sub_interface::mk_create_cmd(std::queue<cmd*>& q)
 std::queue<cmd*>&
 sub_interface::mk_delete_cmd(std::queue<cmd*>& q)
 {
-  q.push(new delete_cmd(m_hdl));
+  q.push(new sub_interface_cmds::delete_cmd(m_hdl));
 
   return (q);
 }
@@ -86,10 +94,17 @@ sub_interface::singular() const
 std::shared_ptr<interface>
 sub_interface::singular_i() const
 {
-  return m_db.find_or_add(name(), *this);
+  return m_db.find_or_add(key(), *this);
 }
+
+std::shared_ptr<sub_interface>
+sub_interface::find(const key_t& k)
+{
+  return std::dynamic_pointer_cast<sub_interface>(m_db.find(k));
 }
 
+}; // namespace VOM
+
 /*
  * fd.io coding-style-patch-verification: ON
  *