#ifndef COMMON_HPP #define COMMON_HPP #include // rindex #include // string #include "Logger.hpp" #include // timespec, CLOCK_REALTIME #include //typeid #include // runtime_error #include // ostringstream const long NANO = 1000000000L; // 10^9 inline timespec addTotimespec( const long int & sec, const long int & nsec) { timespec abs_time; clock_gettime ( CLOCK_REALTIME, &abs_time ); long int nsecSum( abs_time.tv_nsec + nsec ); if ( nsecSum >= NANO ) { abs_time.tv_sec += sec + nsecSum / NANO; abs_time.tv_nsec = nsecSum % NANO; } else { abs_time.tv_sec += sec; abs_time.tv_nsec += nsec; } return abs_time; } inline timespec timespecAdd( timespec& t1, const timespec& t2 ) { timespec result; result.tv_sec = t1.tv_sec + t2.tv_sec ; result.tv_nsec = t1.tv_nsec + t2.tv_nsec ; if (result.tv_nsec >= NANO ) { result.tv_sec++ ; result.tv_nsec = result.tv_nsec - NANO; } return result; } inline timespec timespecSubstract( timespec& t1, const timespec& t2 ) { timespec result; if ((t1.tv_sec < t2.tv_sec) || ((t1.tv_sec == t2.tv_sec) && (t1.tv_nsec <= t2.tv_nsec))) { result.tv_sec = result.tv_nsec = 0 ; } else { result.tv_sec = t1.tv_sec - t2.tv_sec ; if (t1.tv_nsec < t2.tv_nsec) { result.tv_nsec = t1.tv_nsec + NANO - t2.tv_nsec ; result.tv_sec-- ; } else { result.tv_nsec = t1.tv_nsec - t2.tv_nsec ; } } return result; } inline const char* extractFilename( const char *path ) { char const * f = rindex(path, '/'); if (f) return ++f; return path; } template inline std::string stringify(T const& x) { std::ostringstream o; o << x; return o.str(); } inline std::string getTime( void ) { time_t tim = time( NULL ); struct tm * now = localtime( &tim ); std::string ret = stringify(now->tm_hour) + ":" + stringify(now->tm_min) + ":" + stringify(now->tm_sec); return ret; } template inline std::string TToStr(const T t) { std::ostringstream oss; oss << t; return oss.str(); } template inline void StrToT( T &t, const std::string s ) { std::stringstream ss(s); ss >> t; } #endif // COMMON_HPP