/* * Copyright (c) 2017 Cisco and/or its affiliates. * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at: * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include "vom/sub_interface.hpp" #include "vom/sub_interface_cmds.hpp" namespace VOM { /** * Construct a new object matching the desried state */ sub_interface::sub_interface(const interface& parent, admin_state_t state, vlan_id_t vlan) : interface(mk_name(parent, vlan), parent.type(), state) , m_parent(parent.singular()) , m_vlan(vlan) { } /** * 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(mk_name(parent, vlan), parent.type(), state, rd) , m_parent(parent.singular()) , m_vlan(vlan) { } sub_interface::~sub_interface() { sweep(); release(); } sub_interface::sub_interface(const sub_interface& o) : interface(o) , m_parent(o.m_parent) , m_vlan(o.m_vlan) { } 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) { return (parent.name() + "." + std::to_string(vlan)); } std::queue& sub_interface::mk_create_cmd(std::queue& q) { q.push(new sub_interface_cmds::create_cmd(m_hdl, name(), m_parent->handle(), m_vlan)); return (q); } std::queue& sub_interface::mk_delete_cmd(std::queue& q) { q.push(new sub_interface_cmds::delete_cmd(m_hdl)); return (q); } std::shared_ptr sub_interface::singular() const { return std::dynamic_pointer_cast(singular_i()); } std::shared_ptr sub_interface::singular_i() const { return m_db.find_or_add(key(), *this); } std::shared_ptr sub_interface::find(const key_t& k) { return std::dynamic_pointer_cast(m_db.find(k)); } }; // namespace VOM /* * fd.io coding-style-patch-verification: ON * * Local Variables: * eval: (c-set-style "mozilla") * End: */