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 #include "config.h" 00032 #include "SpaceAvailCustody.h" 00033 #include "Node.h" 00034 00035 using namespace DTN; 00036 00037 CustodyPolicy::CustodyReturn 00038 SpaceAvailCustody::takeCustody( const Bundle& b ) 00039 { 00040 if ( 0 == m_owner ) 00041 { 00042 return kDropBundle; 00043 } 00044 if ( 0 == m_store ) 00045 { 00046 return kNoCustody; 00047 } 00048 Bundle::BundleType t = b.type(); 00049 if ( ( Bundle::kBcast & t ) || 00050 ( Bundle::kACK & t ) || 00051 !( Bundle::kCustodial & t ) ) 00052 { 00053 // This isn't a custodial bundle type. 00054 return kNoCustody; 00055 } 00056 if ( m_owner->addr() == b.custodian() ) 00057 { 00058 // We're already the custodian. 00059 return kNoCustody; 00060 } 00061 00062 unsigned int size = b.size(); 00063 unsigned int avail = 00064 m_owner->persistentCap() - m_owner->usedPersistentCap(); 00065 if ( size > avail ) 00066 { 00067 m_owner->signalExhausted(b); 00068 return kNoCustody; 00069 } 00070 00071 Bundle* pB = b.clone(); 00072 pB->custodian() = m_owner->addr(); 00073 BundlePointer ptr = m_store->addBundle( pB ); 00074 if ( ptr.isNull() ) 00075 { 00076 return kNoCustody; 00077 } 00078 return kCustodyTaken; 00079 } 00080 00081 void 00082 SpaceAvailCustody::retry() 00083 { 00084 if ( ( 0 == m_owner ) || ( 0 == m_store ) ) return; 00085 00086 // very simple semantics -- try to send each stored Bundle 00087 BundlePointer itr = m_store->getPointer( BundlePointer() ); 00088 for ( ; ! itr.isNull() ; itr = itr.next() ) 00089 { 00090 m_owner->forward( itr.repr()->bundle()->clone() ); 00091 } 00092 }
1.5.4