PrefixRoutingTable.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 "PrefixRoutingTable.h"
00032 #include "PrefixRoute.h"
00033 #include "Link.h"
00034 #include "Bundle.h"
00035 #include "Exception.h"
00036 
00037 using namespace DTN;
00038 
00039 PrefixRoutingTable::PrefixRoutingTable()
00040 {
00041 }
00042 
00043 PrefixRoutingTable::~PrefixRoutingTable()
00044 {
00045    RouteMap::iterator end = m_routes.end();
00046    RouteMap::iterator itr = m_routes.begin();
00047    for ( ; itr != end ; ++itr )
00048    {
00049       if ( 0 != itr->second )
00050       {
00051          delete itr->second;
00052       }
00053    }
00054 }
00055 
00056 Link&
00057 PrefixRoutingTable::target( const Bundle& b ) const
00058 {
00059    unsigned int destLength = b.destination().length();
00060 
00061    for ( int length = destLength ; length >= 0 ; --length )
00062    {
00063       ByteString substring = b.destination().substr(0,length);
00064       RouteMap::iterator rmItr = m_routes.find( substring );
00065       if ( m_routes.end() != rmItr )
00066       {
00067          if ( 0 == rmItr->second )
00068          {
00069             throw Exception( __FILE__ , __LINE__ );
00070          }
00071          if ( ! rmItr->second->matches( b ) )
00072          {
00073             throw Exception( __FILE__ , __LINE__ );
00074          }
00075          return rmItr->second->link();
00076       }
00077    }
00078 
00079    throw NoRoute( __FILE__ , __LINE__ );
00080 }
00081 
00082 void
00083 PrefixRoutingTable::addRoute( PrefixRoute* r )
00084 {
00085    if ( 0 != r )
00086    {
00087       m_routes.insert( RouteMap::value_type( r->prefix(), r ) );
00088    }
00089 }
00090 
00091 void
00092 PrefixRoutingTable::delRoute( const ByteString& pfix )
00093 {
00094    m_routes.erase( pfix );
00095 }

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