StoreTracer.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 "simlpy/interpreter_defs.h"
00032 
00033 #include "StoreTracer.h"
00034 #include "pydtn/WrapNode.h"
00035 #include "pydtn/WrapLink.h"
00036 #include "simlpy/Clock.h"
00037 #include <iostream>
00038 #include <ctype.h>
00039 #include <netinet/in.h>
00040 
00041 StoreTracer::StoreTracer( std::ostream& s ) :
00042    m_stream( s )
00043 {
00044    m_stream << std::fixed;
00045 }
00046 
00047 StoreTracer::~StoreTracer()
00048 {
00049 }
00050 
00051 void
00052 StoreTracer::node( const WrapNode& wn )
00053 {
00054 }
00055 
00056 void
00057 StoreTracer::link( const WrapLink& wl )
00058 {
00059 }
00060 
00061 void
00062 StoreTracer::enqueue( const DTN::Bundle& b, const DTN::Node* n )
00063 {
00064    if ( 0 == n ) return;
00065    trace(*n);
00066 }
00067 
00068 void
00069 StoreTracer::dequeue( const DTN::Bundle& b, const DTN::Node* n )
00070 {
00071    if ( 0 == n ) return;
00072    trace(*n);
00073 }
00074 
00075 void
00076 StoreTracer::send( const DTN::Bundle& b, const DTN::Node* n )
00077 {
00078 }
00079 
00080 void
00081 StoreTracer::receive( const DTN::Bundle& b, const DTN::Node* n )
00082 {
00083 }
00084 
00085 void
00086 StoreTracer::drop( const DTN::Bundle& b,
00087                    const DTN::DropCause& c,
00088                    const DTN::Node* n )
00089 {
00090 }
00091 
00092 void
00093 StoreTracer::trace( const DTN::Node& n )
00094 {
00095    Time t = Clock::time();
00096    m_stream << t.tv.tv_sec << "," << t.tv.tv_usec << " "
00097             << stringify(n.addr()) << " "
00098             << n.persistentBundles(false) << " "
00099             << n.usedPersistentCap(false) << " "
00100             << n.persistentCap() << " "
00101             << ( 1.0 * n.usedPersistentCap(false) ) / n.persistentCap()
00102             << std::endl;
00103 }
00104 
00105 std::string
00106 StoreTracer::stringify( const DTN::ByteString& b ) const
00107 {
00108    if ( 0 == b.length() ) return "-";
00109    std::string s;
00110    bool printable = true;
00111    for ( unsigned int i = 0 ; i < b.length() ; ++i )
00112    {
00113       if ( !isprint(b[i]) ) printable = false;
00114       if ( isspace(b[i]) ) printable = false;
00115    }
00116    if ( ! printable )
00117    {
00118       s += "0x";
00119    }
00120    for ( unsigned int i = 0 ; i < b.length() ; ++i )
00121    {
00122       if ( printable )
00123       {
00124          s += b[i];
00125       }
00126       else
00127       {
00128          char tmp[3];
00129          ::sprintf(tmp,"%02X",b[i]);
00130          s += tmp[0];
00131          s += tmp[1];
00132       }
00133    }
00134 
00135    return s;
00136 }

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