summaryrefslogtreecommitdiff
path: root/examples/cxx/parser/performance/time.cxx
blob: aca5c74575b0cf8659f336e83b5a1b9499a1788b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
// file      : examples/cxx/parser/performance/time.cxx
// copyright : not copyrighted - public domain

#include "time.hxx"

#if defined (WIN32) || defined (__WIN32__)
#  define WIN32_LEAN_AND_MEAN
#  include <windows.h>  // GetSystemTimeAsFileTime
#else
#  include <time.h>     // gettimeofday
#  include <sys/time.h> // timeval
#endif

#include <ostream> // std::ostream
#include <iomanip> // std::setfill, std::setw

namespace os
{
  time::
  time ()
  {
#if defined (WIN32) || defined (__WIN32__)
    FILETIME ft;
    GetSystemTimeAsFileTime (&ft);
    unsigned long long v (
      ((unsigned long long) (ft.dwHighDateTime) << 32) + ft.dwLowDateTime);

    sec_  = static_cast<unsigned long> (v / 10000000ULL);
    nsec_ = static_cast<unsigned long> ((v % 10000000ULL) * 100);
#else
    timeval tv;
    if (gettimeofday(&tv, 0) != 0)
      throw failed ();

    sec_  = static_cast<unsigned long> (tv.tv_sec);
    nsec_ = static_cast<unsigned long> (tv.tv_usec * 1000);
#endif
  }

  std::ostream&
  operator<< (std::ostream& o, time const& t)
  {
    return o << t.sec () << '.'
             << std::setfill ('0') << std::setw (9) << t.nsec ();
  }
}