Wiselib
wiselib.stable/external_interface/isense/isense_debug.h
Go to the documentation of this file.
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
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Defines