00001 // Copyright 2008 Michael Marsh, University of Maryland. 00002 // 00003 // This file is part of pydtn. 00004 // 00005 // pydtn is free software: you can redistribute it and/or modify 00006 // it under the terms of the GNU General Public License as published by 00007 // the Free Software Foundation, either version 3 of the License, or 00008 // (at your option) any later version. 00009 // 00010 // pydtn is distributed in the hope that it will be useful, 00011 // but WITHOUT ANY WARRANTY; without even the implied warranty of 00012 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00013 // GNU General Public License for more details. 00014 // 00015 // You should have received a copy of the GNU General Public License 00016 // along with pydtn. If not, see <http://www.gnu.org/licenses/>. 00017 // 00018 // The views and conclusions contained in the software and documentation 00019 // are those of the authors and should not be interpreted as representing 00020 // official policies, either expressed or implied, of the University 00021 // of Maryland. 00022 // 00023 // pydtn extends and embeds the Python interpreter, which is 00024 // Copyright 2001-2006 Python Software Foundation, All Rights Reserved, 00025 // and is released under the PSF License Agreement. 00026 // 00027 // RANLUX random number generation uses the Boost library, 00028 // Copyright 1994-2006 by various authors (details in individual files), 00029 // which is released under the Boost Software License, Version 1.0. 00030 00031 #ifndef __WRAPPERS_HARNESS_FLAT_STORE_H__ 00032 #define __WRAPPERS_HARNESS_FLAT_STORE_H__ 00033 00034 #include "config.h" 00035 00036 #include "dtn/VolatileBundleStore.h" 00037 #include <set> 00038 00041 00043 class FlatStore : public DTN::VolatileBundleStore 00044 { 00045 public : 00047 typedef std::set< DTN::Bundle* > BundleList; 00049 typedef BundleList::key_type key_type; 00050 00052 FlatStore( DTN::Node* owner ); 00054 virtual ~FlatStore(); 00055 00057 BundleList::iterator begin(); 00062 BundleList::iterator lower_bound( const key_type& x ); 00066 BundleList::iterator upper_bound( const key_type& x ); 00068 BundleList::iterator end(); 00069 00071 BundleList::const_iterator begin() const; 00076 BundleList::const_iterator lower_bound( const key_type& x ) const; 00080 BundleList::const_iterator upper_bound( const key_type& x ) const; 00082 BundleList::const_iterator end() const; 00083 00084 protected : 00089 virtual DTN::BundlePointer p_addBundle( DTN::Bundle* b ); 00092 virtual void p_deleteBundle( DTN::Bundle* b ); 00093 00102 virtual DTN::BundlePointer p_getPointer( const DTN::BundlePointer& p ); 00103 00113 virtual DTN::BundlePointer p_getPointer( const DTN::ByteString& sender, 00114 uint32_t seqNum ); 00115 00121 virtual bool p_validatePointer( const DTN::BundlePointer& p ); 00122 00126 virtual size_t p_bytesUsed() { return m_bytesUsed; } 00127 00131 virtual size_t p_bundles() { return m_list.size(); } 00132 00136 virtual void p_shrinkStore( size_t s ); 00137 00138 private : 00139 BundleList m_list; 00140 size_t m_bytesUsed; 00141 }; 00142 00144 class FlatStoreItr : public DTN::BundlePointerRepr 00145 { 00146 public : 00150 FlatStoreItr( FlatStore& store, FlatStore::BundleList::iterator itr ); 00152 virtual ~FlatStoreItr(); 00153 00158 virtual bool operator==( const DTN::BundlePointerRepr& b ); 00159 00167 virtual DTN::BundlePointerRepr* next(); 00168 00175 virtual DTN::BundlePointerRepr* clone(); 00176 00188 virtual DTN::Bundle* bundle() const; 00189 00190 private : 00191 FlatStore& m_store; 00192 FlatStore::BundleList::iterator m_itr; 00193 }; 00194 00196 00197 #endif /* __WRAPPERS_HARNESS_FLAT_STORE_H__ */
1.5.4