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 }
1.5.4