From 3328fb3879e398494bf86d8e74c36188426178aa Mon Sep 17 00:00:00 2001 From: Marcin Siodelski Date: Fri, 15 Nov 2013 13:45:56 +0100 Subject: [2940] Addressed review comments. --- src/lib/dhcpsrv/lease.cc | 5 +++-- src/lib/dhcpsrv/lease.h | 11 ++++++++--- src/lib/dhcpsrv/memfile_lease_mgr.cc | 2 +- src/lib/dhcpsrv/memfile_lease_mgr.h | 4 ++-- src/lib/dhcpsrv/tests/test_utils.cc | 2 +- src/lib/dhcpsrv/tests/test_utils.h | 2 +- 6 files changed, 16 insertions(+), 10 deletions(-) (limited to 'src/lib/dhcpsrv') diff --git a/src/lib/dhcpsrv/lease.cc b/src/lib/dhcpsrv/lease.cc index fdc05c460e..98121d1791 100644 --- a/src/lib/dhcpsrv/lease.cc +++ b/src/lib/dhcpsrv/lease.cc @@ -74,10 +74,11 @@ Lease4::Lease4(const Lease4& other) } } -std::vector +const std::vector& Lease4::getClientIdVector() const { if(!client_id_) { - return std::vector(); + static std::vector empty_vec; + return (empty_vec); } return (client_id_->getClientId()); diff --git a/src/lib/dhcpsrv/lease.h b/src/lib/dhcpsrv/lease.h index 3f98491f8b..3734e9f2a9 100644 --- a/src/lib/dhcpsrv/lease.h +++ b/src/lib/dhcpsrv/lease.h @@ -211,9 +211,14 @@ struct Lease4 : public Lease { /// @brief Returns a client identifier. /// - /// @return A client identifier as vector, or an empty vector if client - /// identifier is NULL. - std::vector getClientIdVector() const; + /// @warning Since the function returns the reference to a vector (not a + /// copy), the returned object should be used with caution because it will + /// remain valid only for the period of time when an object which returned + /// it exists. + /// + /// @return A reference to a vector holding client identifier, + /// or an empty vector if client identifier is NULL. + const std::vector& getClientIdVector() const; /// @brief Assignment operator. /// diff --git a/src/lib/dhcpsrv/memfile_lease_mgr.cc b/src/lib/dhcpsrv/memfile_lease_mgr.cc index 075a08289a..dbc3bdd5ce 100644 --- a/src/lib/dhcpsrv/memfile_lease_mgr.cc +++ b/src/lib/dhcpsrv/memfile_lease_mgr.cc @@ -80,7 +80,7 @@ Memfile_LeaseMgr::getLease4(const HWAddr& hwaddr) const { lease != idx.end(); ++lease) { // Every Lease4 has a hardware address, so we can compare it - if((*lease)->hwaddr_ == hwaddr.hwaddr_) { + if ((*lease)->hwaddr_ == hwaddr.hwaddr_) { collection.push_back((*lease)); } } diff --git a/src/lib/dhcpsrv/memfile_lease_mgr.h b/src/lib/dhcpsrv/memfile_lease_mgr.h index 44d07d3bd6..9acc444601 100644 --- a/src/lib/dhcpsrv/memfile_lease_mgr.h +++ b/src/lib/dhcpsrv/memfile_lease_mgr.h @@ -330,7 +330,7 @@ protected: // lease: client id and subnet id. boost::multi_index::composite_key< Lease4, - boost::multi_index::const_mem_fun, + boost::multi_index::const_mem_fun&, &Lease4::getClientIdVector>, // The subnet id is accessed through the subnet_id_ member. boost::multi_index::member @@ -343,7 +343,7 @@ protected: // lease: client id and subnet id. boost::multi_index::composite_key< Lease4, - boost::multi_index::const_mem_fun, + boost::multi_index::const_mem_fun&, &Lease4::getClientIdVector>, // The hardware address is held in the hwaddr_ member of the // Lease4 object. diff --git a/src/lib/dhcpsrv/tests/test_utils.cc b/src/lib/dhcpsrv/tests/test_utils.cc index 5018487379..7563cfdbbf 100644 --- a/src/lib/dhcpsrv/tests/test_utils.cc +++ b/src/lib/dhcpsrv/tests/test_utils.cc @@ -545,7 +545,7 @@ GenericLeaseMgrTest::testGetLease4HWAddr() { } void -GenericLeaseMgrTest::testLease4ClientIdHWAddrSubnetId() { +GenericLeaseMgrTest::testGetLease4ClientIdHWAddrSubnetId() { Lease4Ptr leaseA = initializeLease4(straddress4_[4]); Lease4Ptr leaseB = initializeLease4(straddress4_[5]); Lease4Ptr leaseC = initializeLease4(straddress4_[6]); diff --git a/src/lib/dhcpsrv/tests/test_utils.h b/src/lib/dhcpsrv/tests/test_utils.h index 45970db99c..6a8672436c 100644 --- a/src/lib/dhcpsrv/tests/test_utils.h +++ b/src/lib/dhcpsrv/tests/test_utils.h @@ -116,7 +116,7 @@ public: void testGetLease4HWAddr(); /// @brief Test lease retrieval using client id, HW address and subnet id. - void testLease4ClientIdHWAddrSubnetId(); + void testGetLease4ClientIdHWAddrSubnetId(); // Member variables std::vector straddress4_; ///< String forms of IPv4 addresses -- cgit v1.2.3