Added specToMicroseconds() and microsecondsToSpec().
Simplified advanceMicros() and advanceMs()
This commit is contained in:
parent
b721d11b1a
commit
24e35872b2
75
cwTime.cpp
75
cwTime.cpp
@ -218,51 +218,40 @@ void cw::time::subtractMicros( spec_t& ts, unsigned micros )
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void cw::time::advanceMicros( spec_t& ts, unsigned us )
|
void cw::time::advanceMicros( spec_t& ts, unsigned us )
|
||||||
{
|
{
|
||||||
if( us > 1000000 )
|
const unsigned us_per_sec = 1000000;
|
||||||
{
|
const unsigned ns_per_sec = 1000000000;
|
||||||
// strip off whole seconds from usec
|
|
||||||
unsigned sec = us / 1000000;
|
|
||||||
|
|
||||||
// find the remaining fractional second in microseconds
|
unsigned sec = us / us_per_sec;
|
||||||
us = (us - sec*1000000);
|
|
||||||
|
|
||||||
ts.tv_sec += sec;
|
ts.tv_sec += sec;
|
||||||
|
ts.tv_nsec += (us - sec*us_per_sec)*1000;
|
||||||
|
|
||||||
|
sec = ts.tv_nsec / ns_per_sec;
|
||||||
|
|
||||||
|
ts.tv_sec += sec;
|
||||||
|
ts.tv_nsec -= sec * ns_per_sec;
|
||||||
}
|
}
|
||||||
|
|
||||||
ts.tv_nsec += us * 1000; // convert microseconds to nanoseconds
|
|
||||||
|
|
||||||
// stip off whole seconds from tv_nsec
|
|
||||||
while( ts.tv_nsec > 1000000000 )
|
|
||||||
{
|
|
||||||
ts.tv_nsec -= 1000000000;
|
|
||||||
ts.tv_sec +=1;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void cw::time::advanceMs( spec_t& ts, unsigned ms )
|
void cw::time::advanceMs( spec_t& ts, unsigned ms )
|
||||||
{
|
{
|
||||||
if( ms > 1000 )
|
|
||||||
{
|
|
||||||
// strip off whole seconds from ms
|
|
||||||
unsigned sec = ms / 1000;
|
|
||||||
|
|
||||||
// find the remaining fractional second in milliseconds
|
const unsigned ms_per_sec = 1000;
|
||||||
ms = (ms - sec*1000);
|
const unsigned ns_per_sec = 1000000000;
|
||||||
|
|
||||||
|
unsigned sec = ms / ms_per_sec;
|
||||||
|
|
||||||
ts.tv_sec += sec;
|
ts.tv_sec += sec;
|
||||||
}
|
ts.tv_nsec += (ms - (sec*ms_per_sec)) * 1000000;
|
||||||
|
|
||||||
ts.tv_nsec += ms * 1000000; // convert millisconds to nanoseconds
|
sec = ts.tv_nsec / ns_per_sec;
|
||||||
|
|
||||||
// stip off whole seconds from tv_nsec
|
ts.tv_sec += sec;
|
||||||
while( ts.tv_nsec > 1000000000 )
|
ts.tv_nsec -= sec * ns_per_sec;
|
||||||
{
|
|
||||||
ts.tv_nsec -= 1000000000;
|
|
||||||
ts.tv_sec +=1;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
cw::rc_t cw::time::futureMs( spec_t& ts, unsigned ms )
|
cw::rc_t cw::time::futureMs( spec_t& ts, unsigned ms )
|
||||||
@ -293,6 +282,19 @@ double cw::time::specToSeconds( const spec_t& t )
|
|||||||
return sec + ((double)ts.tv_nsec)/1e9;
|
return sec + ((double)ts.tv_nsec)/1e9;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
unsigned long long cw::time::specToMicroseconds( const spec_t& ts )
|
||||||
|
{
|
||||||
|
const unsigned long long us_per_sec = 1000000;
|
||||||
|
const unsigned long long ns_per_sec = 1000000000;
|
||||||
|
|
||||||
|
unsigned long long us = ts.tv_sec * us_per_sec;
|
||||||
|
unsigned long long sec = ts.tv_nsec / ns_per_sec;
|
||||||
|
us += sec * us_per_sec;
|
||||||
|
us += (ts.tv_nsec - (sec * ns_per_sec))/1000;
|
||||||
|
|
||||||
|
return us;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void cw::time::millisecondsToSpec( spec_t& ts, unsigned ms )
|
void cw::time::millisecondsToSpec( spec_t& ts, unsigned ms )
|
||||||
{
|
{
|
||||||
@ -303,15 +305,24 @@ void cw::time::millisecondsToSpec( spec_t& ts, unsigned ms )
|
|||||||
ts.tv_nsec = ns;
|
ts.tv_nsec = ns;
|
||||||
}
|
}
|
||||||
|
|
||||||
void cw::time::microsecondsToSpec( spec_t& ts, unsigned us )
|
void cw::time::microsecondsToSpec( spec_t& ts, unsigned long long us )
|
||||||
{
|
{
|
||||||
unsigned sec = us/1000000;
|
const unsigned long long usPerSec = 1000000;
|
||||||
unsigned ns = (us - (sec*1000000)) * 1000;
|
unsigned long long sec = us/usPerSec;
|
||||||
|
unsigned long long ns = (us - (sec*usPerSec)) * 1000;
|
||||||
|
|
||||||
ts.tv_sec = sec;
|
ts.tv_sec = sec;
|
||||||
ts.tv_nsec = ns;
|
ts.tv_nsec = ns;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
cw::time::spec_t cw::time::microsecondsToSpec( unsigned long long us )
|
||||||
|
{
|
||||||
|
spec_t ts;
|
||||||
|
microsecondsToSpec(ts,us);
|
||||||
|
return ts;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
unsigned cw::time::formatDateTime( char* buffer, unsigned bufN, bool includeDateFl )
|
unsigned cw::time::formatDateTime( char* buffer, unsigned bufN, bool includeDateFl )
|
||||||
{
|
{
|
||||||
|
5
cwTime.h
5
cwTime.h
@ -76,8 +76,11 @@ namespace cw
|
|||||||
void secondsToSpec( spec_t& ts, unsigned sec );
|
void secondsToSpec( spec_t& ts, unsigned sec );
|
||||||
double specToSeconds( const spec_t& ts );
|
double specToSeconds( const spec_t& ts );
|
||||||
|
|
||||||
|
unsigned long long specToMicroseconds( const spec_t& ts );
|
||||||
|
|
||||||
void millisecondsToSpec( spec_t& ts, unsigned ms );
|
void millisecondsToSpec( spec_t& ts, unsigned ms );
|
||||||
void microsecondsToSpec( spec_t& ts, unsigned us );
|
void microsecondsToSpec( spec_t& ts, unsigned long long us );
|
||||||
|
spec_t microsecondsToSpec( unsigned long long us );
|
||||||
|
|
||||||
// Return count of bytes in in buf[]
|
// Return count of bytes in in buf[]
|
||||||
unsigned formatDateTime( char* buf, unsigned bufN, bool includeDateFl=false );
|
unsigned formatDateTime( char* buf, unsigned bufN, bool includeDateFl=false );
|
||||||
|
Loading…
Reference in New Issue
Block a user