NS-3 based Named Data Networking (NDN) simulator
ndnSIM 2.5: NDN, CCN, CCNx, content centric networks
API Documentation
in-memory-storage-lru.cpp
Go to the documentation of this file.
1
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2
/*
3
* Copyright (c) 2013-2018 Regents of the University of California.
4
*
5
* This file is part of ndn-cxx library (NDN C++ library with eXperimental eXtensions).
6
*
7
* ndn-cxx library is free software: you can redistribute it and/or modify it under the
8
* terms of the GNU Lesser General Public License as published by the Free Software
9
* Foundation, either version 3 of the License, or (at your option) any later version.
10
*
11
* ndn-cxx library is distributed in the hope that it will be useful, but WITHOUT ANY
12
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
13
* PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
14
*
15
* You should have received copies of the GNU General Public License and GNU Lesser
16
* General Public License along with ndn-cxx, e.g., in COPYING.md file. If not, see
17
* <http://www.gnu.org/licenses/>.
18
*
19
* See AUTHORS.md for complete list of ndn-cxx authors and contributors.
20
*/
21
22
#include "
ndn-cxx/ims/in-memory-storage-lru.hpp
"
23
24
namespace
ndn
{
25
26
InMemoryStorageLru::InMemoryStorageLru
(
size_t
limit)
27
:
InMemoryStorage
(limit)
28
{
29
}
30
31
InMemoryStorageLru::InMemoryStorageLru
(
DummyIoService
& ioService,
32
size_t
limit)
33
:
InMemoryStorage
(ioService, limit)
34
{
35
}
36
37
void
38
InMemoryStorageLru::afterInsert
(
InMemoryStorageEntry
* entry)
39
{
40
BOOST_ASSERT(m_cleanupIndex.size() <=
size
());
41
InMemoryStorageEntry
* ptr = entry;
42
m_cleanupIndex.insert(ptr);
43
}
44
45
bool
46
InMemoryStorageLru::evictItem
()
47
{
48
if
(!m_cleanupIndex.get<byUsedTime>().empty()) {
49
CleanupIndex::index<byUsedTime>::type::iterator it = m_cleanupIndex.get<byUsedTime>().
begin
();
50
eraseImpl
((*it)->getFullName());
51
m_cleanupIndex.get<byUsedTime>().
erase
(it);
52
return
true
;
53
}
54
55
return
false
;
56
}
57
58
void
59
InMemoryStorageLru::beforeErase
(
InMemoryStorageEntry
* entry)
60
{
61
CleanupIndex::index<byEntity>::type::iterator it = m_cleanupIndex.get<byEntity>().
find
(entry);
62
if
(it != m_cleanupIndex.get<byEntity>().end())
63
m_cleanupIndex.get<byEntity>().
erase
(it);
64
}
65
66
void
67
InMemoryStorageLru::afterAccess
(
InMemoryStorageEntry
* entry)
68
{
69
beforeErase
(entry);
70
afterInsert
(entry);
71
}
72
73
}
// namespace ndn
ndn::InMemoryStorage::begin
InMemoryStorage::const_iterator begin() const
Returns begin iterator of the in-memory storage ordering by name with digest.
Definition:
in-memory-storage.cpp:356
ndn::InMemoryStorageLru::afterInsert
void afterInsert(InMemoryStorageEntry *entry) override
Update the entry after a entry is successfully inserted, add it to the cleanupIndex.
Definition:
in-memory-storage-lru.cpp:38
ndn::InMemoryStorage::find
shared_ptr< const Data > find(const Interest &interest)
Finds the best match Data for an Interest.
Definition:
in-memory-storage.cpp:217
in-memory-storage-lru.hpp
ndn::InMemoryStorage::erase
void erase(const Name &prefix, const bool isPrefix=true)
Deletes in-memory storage entry by prefix by default.
Definition:
in-memory-storage.cpp:321
ndn::InMemoryStorageLru::afterAccess
void afterAccess(InMemoryStorageEntry *entry) override
Update the entry when the entry is returned by the find() function, update the last used time accordi...
Definition:
in-memory-storage-lru.cpp:67
ndn::InMemoryStorage::size
size_t size() const
Definition:
in-memory-storage.hpp:200
ndn::InMemoryStorage::eraseImpl
void eraseImpl(const Name &name)
deletes in-memory storage entries by the Name with implicit digest.
Definition:
in-memory-storage.cpp:346
ndn::InMemoryStorageEntry
Represents an in-memory storage entry.
Definition:
in-memory-storage-entry.hpp:34
ndn::InMemoryStorageLru::InMemoryStorageLru
InMemoryStorageLru(size_t limit=16)
Definition:
in-memory-storage-lru.cpp:26
ndn::DummyIoService
Definition:
asio-fwd.hpp:28
ndn::InMemoryStorage::evictItem
virtual bool evictItem()=0
Removes one Data packet from in-memory storage based on derived class implemented replacement policy.
ndn::InMemoryStorageLru::beforeErase
void beforeErase(InMemoryStorageEntry *entry) override
Update the entry or other data structures before a entry is successfully erased, erase it from the cl...
Definition:
in-memory-storage-lru.cpp:59
ndn::InMemoryStorage
Represents in-memory storage.
Definition:
in-memory-storage.hpp:43
ndn
Copyright (c) 2011-2015 Regents of the University of California.
Definition:
ndn-strategy-choice-helper.hpp:34
ndnSIM
ndn-cxx
ndn-cxx
ims
in-memory-storage-lru.cpp
Generated on Mon Jun 1 2020 22:32:14 for ndnSIM by
1.8.18