Wiselib
|
00001 /*************************************************************************** 00002 ** This file is part of the generic algorithm library Wiselib. ** 00003 ** Copyright (C) 2008,2009 by the Wisebed (www.wisebed.eu) project. ** 00004 ** ** 00005 ** The Wiselib is free software: you can redistribute it and/or modify ** 00006 ** it under the terms of the GNU Lesser General Public License as ** 00007 ** published by the Free Software Foundation, either version 3 of the ** 00008 ** License, or (at your option) any later version. ** 00009 ** ** 00010 ** The Wiselib 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 Lesser General Public License for more details. ** 00014 ** ** 00015 ** You should have received a copy of the GNU Lesser General Public ** 00016 ** License along with the Wiselib. ** 00017 ** If not, see <http://www.gnu.org/licenses/>. ** 00018 ***************************************************************************/ 00019 #ifndef CONNECTOR_ISENSE_DEBUGOUTPUT_H 00020 #define CONNECTOR_ISENSE_DEBUGOUTPUT_H 00021 00022 #include "isense_types.h" 00023 #include <isense/os.h> 00024 #include <stdarg.h> 00025 #include <stdio.h> 00026 00027 namespace wiselib 00028 { 00029 00037 template<typename OsModel_P> 00038 class iSenseDebug 00039 { 00040 public: 00041 typedef OsModel_P OsModel; 00042 00043 typedef iSenseDebug<OsModel> self_type; 00044 typedef self_type* self_pointer_t; 00045 // -------------------------------------------------------------------- 00049 void debug( const char *msg, ... ); 00050 // -------------------------------------------------------------------- 00051 iSenseDebug( isense::Os& os ) 00052 : os_(os) 00053 {} 00054 00055 private: 00056 isense::Os& os_; 00057 }; 00058 // ----------------------------------------------------------------------- 00059 // ----------------------------------------------------------------------- 00060 // ----------------------------------------------------------------------- 00061 template<typename OsModel_P> 00062 void 00063 iSenseDebug<OsModel_P>:: 00064 debug( const char *msg, ... ) 00065 { 00066 va_list fmtargs; 00067 char buffer[1024]; 00068 va_start( fmtargs, msg ); 00069 vsnprintf( buffer, sizeof(buffer) - 1, msg, fmtargs ); 00070 va_end( fmtargs ); 00071 os_.debug( "%s", buffer ); 00072 } 00073 } 00074 00075 #endif