SpaceAvailCustody.cc

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 }

Generated on Mon Mar 24 11:15:45 2008 for Pydtn Simulator by  doxygen 1.5.4