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