| 
							- 
 - /*******************************************************************************/
 - /* Copyright (C) 2010 Jonathan Moore Liles                                     */
 - /*                                                                             */
 - /* This program is free software; you can redistribute it and/or modify it     */
 - /* under the terms of the GNU General Public License as published by the       */
 - /* Free Software Foundation; either version 2 of the License, or (at your      */
 - /* option) any later version.                                                  */
 - /*                                                                             */
 - /* This program is distributed in the hope that it will be useful, but WITHOUT */
 - /* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or       */
 - /* FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for   */
 - /* more details.                                                               */
 - /*                                                                             */
 - /* You should have received a copy of the GNU General Public License along     */
 - /* with This program; see the file COPYING.  If not,write to the Free Software */
 - /* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
 - /*******************************************************************************/
 - 
 - #pragma once
 - #include <stdio.h>
 - #include <sys/time.h>
 - #include <sys/types.h>
 - #include <unistd.h>
 - #include <string.h>
 - 
 - class Block_Timer
 - {
 - 
 -     unsigned long long ts;
 -     const char *prefix;
 - 
 -     unsigned long long tv_to_ts ( timeval *tv )
 -         {
 -             return tv->tv_sec * 1e6 + tv->tv_usec;
 -         }
 - 
 - public:
 - 
 -     Block_Timer ( const char *prefix )
 -         {
 -             this->prefix = prefix;
 - 
 -             timeval tv;
 - 
 -             gettimeofday( &tv, NULL );
 - 
 -             ts = tv_to_ts( &tv );
 -         }
 - 
 -     ~Block_Timer ( )
 -         {
 -             timeval tv;
 - 
 -             gettimeofday( &tv, NULL );
 - 
 -             fprintf( stderr, "[%Lfms] %s\n", ((long double)tv_to_ts( &tv ) - ts ) / 1000, prefix );
 -         }
 - };
 
 
  |