table: mock PIT
refs #1128
Change-Id: I8943ad07d93422dc456fd051b2e4c0d5f38bc227
diff --git a/daemon/table/pit-entry.cpp b/daemon/table/pit-entry.cpp
new file mode 100644
index 0000000..e11abef
--- /dev/null
+++ b/daemon/table/pit-entry.cpp
@@ -0,0 +1,96 @@
+/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
+/**
+ * Copyright (C) 2014 Named Data Networking Project
+ * See COPYING for copyright and distribution information.
+ */
+
+#include "pit-entry.hpp"
+#include <algorithm>
+
+namespace ndn {
+namespace pit {
+
+Entry::Entry(const Interest& interest)
+ : m_interest(interest)
+{
+}
+
+const Name&
+Entry::getName() const
+{
+ return m_interest.getName();
+}
+
+const InRecordCollection&
+Entry::getInRecords() const
+{
+ return m_inRecords;
+}
+
+const OutRecordCollection&
+Entry::getOutRecords() const
+{
+ return m_outRecords;
+}
+
+bool
+Entry::isNonceSeen(uint32_t nonce) const
+{
+ return m_nonces.count(nonce) > 0;
+}
+
+static inline bool
+predicate_FaceRecord_Face(const FaceRecord& faceRecord, shared_ptr<Face> face)
+{
+ return faceRecord.getFace() == face;
+}
+
+InRecordCollection::iterator
+Entry::insertOrUpdateInRecord(shared_ptr<Face> face, const Interest& interest)
+{
+ InRecordCollection::iterator it = std::find_if(m_inRecords.begin(),
+ m_inRecords.end(), bind(&predicate_FaceRecord_Face, _1, face));
+ if (it == m_inRecords.end()) {
+ m_inRecords.push_front(InRecord(face));
+ it = m_inRecords.begin();
+ }
+
+ it->update(interest);
+ m_nonces.insert(interest.getNonce());
+ return it;
+}
+
+void
+Entry::deleteInRecords()
+{
+ m_inRecords.clear();
+}
+
+OutRecordCollection::iterator
+Entry::insertOrUpdateOutRecord(shared_ptr<Face> face, const Interest& interest)
+{
+ OutRecordCollection::iterator it = std::find_if(m_outRecords.begin(),
+ m_outRecords.end(), bind(&predicate_FaceRecord_Face, _1, face));
+ if (it == m_outRecords.end()) {
+ m_outRecords.push_front(OutRecord(face));
+ it = m_outRecords.begin();
+ }
+
+ it->update(interest);
+ m_nonces.insert(interest.getNonce());
+ return it;
+}
+
+void
+Entry::deleteOutRecord(shared_ptr<Face> face)
+{
+ OutRecordCollection::iterator it = std::find_if(m_outRecords.begin(),
+ m_outRecords.end(), bind(&predicate_FaceRecord_Face, _1, face));
+ if (it != m_outRecords.end()) {
+ m_outRecords.erase(it);
+ }
+}
+
+
+} // namespace pit
+} // namespace ndn