diff options
| author | Reinhard Tartler <siretart@tauware.de> | 2011-11-13 09:27:51 +0100 | 
|---|---|---|
| committer | Reinhard Tartler <siretart@tauware.de> | 2011-11-13 09:27:51 +0100 | 
| commit | 3e924126b56c4d421e8263d25f6b14aa4ceed047 (patch) | |
| tree | 921403de7b834fb1ac89f97d84ce105e0b487051 /nxcomp/Timestamp.h | |
| parent | a840692edc9c6d19cd7c057f68e39c7d95eb767d (diff) | |
| download | nx-libs-nxcomp/3.1.0-4.tar.gz nx-libs-nxcomp/3.1.0-4.tar.bz2 nx-libs-nxcomp/3.1.0-4.zip | |
Imported nxcomp-3.1.0-4.tar.gznxcomp/3.1.0-4
Summary: Imported nxcomp-3.1.0-4.tar.gz
Keywords:
Imported nxcomp-3.1.0-4.tar.gz
into Git repository
Diffstat (limited to 'nxcomp/Timestamp.h')
| -rwxr-xr-x | nxcomp/Timestamp.h | 342 | 
1 files changed, 342 insertions, 0 deletions
| diff --git a/nxcomp/Timestamp.h b/nxcomp/Timestamp.h new file mode 100755 index 000000000..270dd3863 --- /dev/null +++ b/nxcomp/Timestamp.h @@ -0,0 +1,342 @@ +/**************************************************************************/ +/*                                                                        */ +/* Copyright (c) 2001, 2007 NoMachine, http://www.nomachine.com/.         */ +/*                                                                        */ +/* NXCOMP, NX protocol compression and NX extensions to this software     */ +/* are copyright of NoMachine. Redistribution and use of the present      */ +/* software is allowed according to terms specified in the file LICENSE   */ +/* which comes in the source distribution.                                */ +/*                                                                        */ +/* Check http://www.nomachine.com/licensing.html for applicability.       */ +/*                                                                        */ +/* NX and NoMachine are trademarks of NoMachine S.r.l.                    */ +/*                                                                        */ +/* All rights reserved.                                                   */ +/*                                                                        */ +/**************************************************************************/ + +#ifndef Timestamp_H +#define Timestamp_H + +#include <stdio.h> +#include <stdlib.h> +#include <string.h> + +#include <time.h> +#include <sys/time.h> + +#include "Misc.h" + +// +// Log level. +// + +#define PANIC +#define WARNING +#undef  TEST +#undef  DEBUG + +// +// If not defined, always query the system time. +// + +#undef  CACHE_TIMESTAMP + +// +// Log a warning if the time difference since +// the last update exceeds the given number +// of milliseconds. +// + +#define DRIFT_TIMESTAMP  1 + +// +// Type used for timeout manipulation. +// + +typedef struct timeval T_timestamp; + +// +// Last timestamp taken from the system. If the +// timestamp is cached, we need to explicitly +// get a new timestamp after any operation that +// may have required a relevant amount of time. +// + +extern T_timestamp timestamp; + +// +// Get a timestamp instance with values set +// at the given amount of milliseconds. +// + +inline T_timestamp getTimestamp(long ms) +{ +  struct timeval ts; + +  ts.tv_sec  = ms / 1000; +  ts.tv_usec = (ms % 1000) * 1000; + +  return ts; +} + +// +// Return the difference in milliseconds +// between the two timestamps. +// + +inline long diffTimestamp(const T_timestamp &ts1, const T_timestamp &ts2) +{ +  if (ts1.tv_sec == 0 && ts1.tv_usec == 0) +  { +     return -1; +  } + +  // +  // Add 500 microseconds to round up +  // to the nearest millisecond. +  // + +  long ms = ((ts2.tv_sec * 1000 + (ts2.tv_usec + 500) / 1000) - +                 (ts1.tv_sec * 1000 + (ts1.tv_usec + 500) / 1000)); + +  return (ms < 0 ? -1 : ms); +} + +// +// The same in microseconds. It doesn't +// round the value. +// + +inline long diffUsTimestamp(const T_timestamp &ts1, const T_timestamp &ts2) +{ +  if (ts1.tv_sec == 0 && ts1.tv_usec == 0) +  { +     return -1; +  } + +  // +  // Add 500 microseconds to round up +  // to the nearest millisecond. +  // + +  long ms = ((ts2.tv_sec * 1000000 + ts2.tv_usec) - +                 (ts1.tv_sec * 1000000 + ts1.tv_usec)); + +  return (ms < 0 ? -1 : ms); +} + +// +// Return the last timestamp taken from the +// system. It doesn't update the timestamp. +// + +inline T_timestamp getTimestamp() +{ +  #ifdef CACHE_TIMESTAMP + +  #ifdef TEST + +  T_timestamp ts; + +  gettimeofday(&ts, NULL); + +  long diffTs = diffTimestamp(timestamp, ts); + +  if (diffTs > DRIFT_TIMESTAMP) +  { +    *logofs << "Timestamp: WARNING! Time difference since the " +            << "current timestamp is " << diffTs << " Ms.\n" +            << logofs_flush; +  } + +  #endif + +  return timestamp; + +  #else + +  gettimeofday(×tamp, NULL); + +  return timestamp; + +  #endif +} + +inline T_timestamp &setTimestamp(T_timestamp &ts, long ms) +{ +  ts.tv_sec  = ms / 1000; +  ts.tv_usec = (ms % 1000) * 1000; + +  return ts; +} + +// +// Return the smaller between two timestamps. +// + +inline T_timestamp &setMinTimestamp(T_timestamp &ts, long ms) +{ +  if ((ts.tv_sec * 1000 + ts.tv_usec / 1000) > ms) +  { +    ts.tv_sec  = ms / 1000; +    ts.tv_usec = (ms % 1000) * 1000; +  } + +  return ts; +} + +inline T_timestamp &setMinTimestamp(T_timestamp &ts1, T_timestamp &ts2) +{ +  if ((ts1.tv_sec * 1000000 + ts1.tv_usec) > +           (ts2.tv_sec * 1000000 + ts2.tv_usec)) +  { +    ts1.tv_sec  = ts2.tv_sec; +    ts1.tv_usec = ts2.tv_usec; +  } + +  return ts1; +} + +// +// Convert a timestamp in the total number +// of milliseconds. +// + +inline long getMsTimestamp(const T_timestamp &ts) +{ +  return ts.tv_sec * 1000 + ts.tv_usec / 1000; +} + +// +// A 0 value on both seconds and microseconds +// fields means that timestamp is invalid or +// not set. +// + +inline T_timestamp nullTimestamp() +{ +  struct timeval ts; + +  ts.tv_sec  = 0; +  ts.tv_usec = 0; + +  return ts; +} + +inline bool isTimestamp(const T_timestamp &ts) +{ +  if (ts.tv_sec == 0 && ts.tv_usec == 0) +  { +     return 0; +  } + +  return 1; +} + +inline void subMsToTimestamp(T_timestamp &ts, long ms) +{ +  long sec = ms / 1000; + +  ts.tv_sec -= sec; + +  long mod = ms % (ms * 1000); + +  if (ts.tv_usec >= (mod * 1000)) +  { +    ts.tv_sec -= mod * 1000; +  } +  else +  { +    ts.tv_sec--; + +    ts.tv_usec = 1000000 - mod * 1000; +  } +} + +inline void addMsToTimestamp(T_timestamp &ts, long ms) +{ +  long sec = ms / 1000; + +  ts.tv_sec += sec; + +  long mod = ms % (ms * 1000); + +  ts.tv_usec += mod * 1000; + +  if (ts.tv_usec > 1000000) +  { +    ts.tv_sec += 1; +  } +} + +// +// Check the difference between timestamps. +// Return 0 if the system time went backward +// compared to the second timestamp, or the +// difference between the timestamps exceeds +// the given number of milliseconds. +// + +inline int checkDiffTimestamp(const T_timestamp &ts1, const T_timestamp &ts2, +                                  long ms = 30000) +{ +  long diffTs = diffTimestamp(ts1, ts2); + +  if (diffTs < 0 || diffTs > ms) +  { +    return 0; +  } + +  return 1; +} + +// +// Return a string representing the timestamp. +// + +char *strTimestamp(const T_timestamp &ts); +char *strMsTimestamp(const T_timestamp &ts); + +inline char *strTimestamp() +{ +  return strTimestamp(getTimestamp()); +} + +inline char *strMsTimestamp() +{ +  return strMsTimestamp(getTimestamp()); +} + +// +// Update the current timestamp. +// + +inline T_timestamp getNewTimestamp() +{ +  #ifdef TEST + +  T_timestamp ts; + +  gettimeofday(&ts, NULL); + +  *logofs << "Timestamp: Updating the current timestamp at " +          << strMsTimestamp(ts) << ".\n" << logofs_flush; + +  long diffTs = diffTimestamp(timestamp, ts); + +  if (diffTs > DRIFT_TIMESTAMP) +  { +    *logofs << "Timestamp: WARNING! Time difference since the " +            << "old timestamp is " << diffTs << " Ms.\n" +            << logofs_flush; +  } + +  #endif + +  gettimeofday(×tamp, NULL); + +  return timestamp; +} + +#endif /* Timestamp_H */ | 
