BLI_math_rotation: properly name the quaternion power function.
[blender.git] / source / blender / blenlib / intern / time.c
1 /*
2  * ***** BEGIN GPL LICENSE BLOCK *****
3  *
4  * This program is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU General Public License
6  * as published by the Free Software Foundation; either version 2
7  * of the License, or (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software Foundation,
16  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17  *
18  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
19  * All rights reserved.
20  *
21  * The Original Code is: all of this file.
22  *
23  * Contributor(s): none yet.
24  *
25  * ***** END GPL LICENSE BLOCK *****
26  */
27
28 /** \file blender/blenlib/intern/time.c
29  *  \ingroup bli
30  */
31
32
33 #include "PIL_time.h"
34
35 #ifdef WIN32
36 #ifndef _WIN32_WINNT
37 #define _WIN32_WINNT 0x501 /* Windows XP or newer */
38 #endif
39 #define WIN32_LEAN_AND_MEAN
40 #include <windows.h>
41
42 double PIL_check_seconds_timer(void)
43 {
44         static int hasperfcounter = -1; /* (-1 == unknown) */
45         static double perffreq;
46
47         if (hasperfcounter == -1) {
48                 __int64 ifreq;
49                 hasperfcounter = QueryPerformanceFrequency((LARGE_INTEGER *) &ifreq);
50                 perffreq = (double) ifreq;
51         }
52
53         if (hasperfcounter) {
54                 __int64 count;
55
56                 QueryPerformanceCounter((LARGE_INTEGER *) &count);
57
58                 return count / perffreq;
59         }
60         else {
61                 static double accum = 0.0;
62                 static int ltick = 0;
63                 int ntick = GetTickCount();
64
65                 if (ntick < ltick) {
66                         accum += (0xFFFFFFFF - ltick + ntick) / 1000.0;
67                 }
68                 else {
69                         accum += (ntick - ltick) / 1000.0;
70                 }
71
72                 ltick = ntick;
73                 return accum;
74         }
75 }
76
77 long int PIL_check_seconds_timer_i(void)
78 {
79         return (long int)PIL_check_seconds_timer();
80 }
81
82 void PIL_sleep_ms(int ms)
83 {
84         Sleep(ms);
85 }
86
87 #else
88
89 #include <unistd.h>
90 #include <sys/time.h>
91
92 double PIL_check_seconds_timer(void)
93 {
94         struct timeval tv;
95         struct timezone tz;
96
97         gettimeofday(&tv, &tz);
98
99         return ((double) tv.tv_sec + tv.tv_usec / 1000000.0);
100 }
101
102 long int PIL_check_seconds_timer_i(void)
103 {
104         struct timeval tv;
105         struct timezone tz;
106
107         gettimeofday(&tv, &tz);
108
109         return tv.tv_sec;
110 }
111
112 void PIL_sleep_ms(int ms)
113 {
114         if (ms >= 1000) {
115                 sleep(ms / 1000);
116                 ms = (ms % 1000);
117         }
118
119         usleep(ms * 1000);
120 }
121
122 #endif