@ -3,41 +3,31 @@
# include "leveldb/env.h"
# include "leveldb/env.h"
# include "leveldb/statistics.h"
# include "leveldb/statistics.h"
# include <iostream>
namespace leveldb {
namespace leveldb {
// Auto-scoped.
// Records the statistic into the corresponding histogram.
class StopWatch {
class StopWatch {
public :
public :
virtual uint64_t ElapsedMicros ( ) = 0 ;
StopWatch (
virtual ~ StopWatch ( ) { }
Env * const env ,
} ;
std : : shared_ptr < Statistics > statistics ,
const Histograms histogram_name ) :
env_ ( env ) ,
start_time_ ( env - > NowMicros ( ) ) ,
statistics_ ( statistics ) ,
histogram_name_ ( histogram_name ) { }
class DoNothingStopWatch : public StopWatch {
public :
virtual uint64_t ElapsedMicros ( ) {
return 0 ;
}
} ;
// Auto-scoped.
// Records the statistic into the corresponding histogram.
class ScopedRecordingStopWatch : public StopWatch {
public :
ScopedRecordingStopWatch ( Env * const env ,
std : : shared_ptr < Statistics > statistics ,
const Histograms histogram_name ) :
env_ ( env ) ,
start_time_ ( env - > NowMicros ( ) ) ,
statistics_ ( statistics ) ,
histogram_name_ ( histogram_name ) { }
virtual uint64_t ElapsedMicros ( ) {
uint64_t ElapsedMicros ( ) {
return env_ - > NowMicros ( ) - start_time_ ;
return env_ - > NowMicros ( ) - start_time_ ;
}
}
virtual ~ ScopedRecordingStopWatch ( ) {
~ StopWatch ( ) {
uint64_t elapsed_time = env_ - > NowMicros ( ) - start_time_ ;
if ( statistics_ ) {
statistics_ - > measureTime ( histogram_name_ , elapsed_time ) ;
statistics_ - > measureTime ( histogram_name_ , ElapsedMicros ( ) ) ;
}
}
}
private :
private :
@ -47,22 +37,5 @@ class ScopedRecordingStopWatch : public StopWatch {
const Histograms histogram_name_ ;
const Histograms histogram_name_ ;
} ;
} ;
namespace stats {
// Helper method
std : : unique_ptr < StopWatch > StartStopWatch ( Env * const env ,
std : : shared_ptr < Statistics > stats ,
Histograms histogram_name ) {
assert ( env ) ;
if ( stats ) {
return std : : unique_ptr < StopWatch > ( new ScopedRecordingStopWatch (
env ,
stats ,
histogram_name ) ) ;
} else {
return std : : unique_ptr < StopWatch > ( new DoNothingStopWatch ( ) ) ;
}
} ;
} // namespace stats
} // namespace leveldb
} // namespace leveldb
# endif // STORAGE_LEVELDB_UTIL_STOP_WATCH_H_
# endif // STORAGE_LEVELDB_UTIL_STOP_WATCH_H_