Added and Moved checks for includes

Moved checks for G_OS_WIN32 after GLib header includes and added other checks
required for Windows/MSVC builds
This commit is contained in:
Chun-wei Fan 2010-11-09 09:53:12 +08:00
parent 4a012a9754
commit 9806040455
4 changed files with 85 additions and 28 deletions

View File

@ -54,11 +54,6 @@
#include <unistd.h> #include <unistd.h>
#endif #endif
#ifndef G_OS_WIN32
#include <sys/time.h>
#include <time.h>
#endif /* !G_OS_WIN32 */
#include "gdatetime.h" #include "gdatetime.h"
#include "gatomic.h" #include "gatomic.h"
@ -73,6 +68,11 @@
#include "glibintl.h" #include "glibintl.h"
#ifndef G_OS_WIN32
#include <sys/time.h>
#include <time.h>
#endif /* !G_OS_WIN32 */
/** /**
* SECTION:date-time * SECTION:date-time
* @title: GDateTime * @title: GDateTime

View File

@ -41,15 +41,6 @@
#include <locale.h> #include <locale.h>
#include <errno.h> #include <errno.h>
#ifdef G_OS_WIN32
#include <process.h> /* For getpid() */
#include <io.h>
# define STRICT /* Strict typing, please */
# define _WIN32_WINDOWS 0x0401 /* to get IsDebuggerPresent */
# include <windows.h>
# undef STRICT
#endif
#include "gmessages.h" #include "gmessages.h"
#include "gbacktrace.h" #include "gbacktrace.h"
@ -63,6 +54,15 @@
#include "gstrfuncs.h" #include "gstrfuncs.h"
#include "gstring.h" #include "gstring.h"
#ifdef G_OS_WIN32
#include <process.h> /* For getpid() */
#include <io.h>
# define STRICT /* Strict typing, please */
# define _WIN32_WINDOWS 0x0401 /* to get IsDebuggerPresent */
# include <windows.h>
# undef STRICT
#endif
/* --- structures --- */ /* --- structures --- */
typedef struct _GLogDomain GLogDomain; typedef struct _GLogDomain GLogDomain;

View File

@ -42,10 +42,6 @@
#include <unistd.h> #include <unistd.h>
#endif #endif
#ifdef G_OS_WIN32
#include <io.h> /* For _read() */
#endif
#include "gscanner.h" #include "gscanner.h"
#include "gprintfint.h" #include "gprintfint.h"
@ -53,6 +49,10 @@
#include "gstring.h" #include "gstring.h"
#include "gtestutils.h" #include "gtestutils.h"
#ifdef G_OS_WIN32
#include <io.h> /* For _read() */
#endif
/* --- defines --- */ /* --- defines --- */
#define to_lower(c) ( \ #define to_lower(c) ( \
(guchar) ( \ (guchar) ( \

View File

@ -37,7 +37,9 @@
#include <unistd.h> #include <unistd.h>
#endif /* HAVE_UNISTD_H */ #endif /* HAVE_UNISTD_H */
#ifdef HAVE_SYS_TIME_H
#include <sys/time.h> #include <sys/time.h>
#endif
#include <time.h> #include <time.h>
#ifndef G_OS_WIN32 #ifndef G_OS_WIN32
#include <errno.h> #include <errno.h>
@ -52,7 +54,7 @@
#include "gmem.h" #include "gmem.h"
#include "gstrfuncs.h" #include "gstrfuncs.h"
#include "gtestutils.h" #include "gtestutils.h"
#include "gmain.h" #include "gthread.h"
/** /**
* SECTION: timers * SECTION: timers
@ -63,8 +65,19 @@
* that time. This is done somewhat differently on different platforms, * that time. This is done somewhat differently on different platforms,
* and can be tricky to get exactly right, so #GTimer provides a * and can be tricky to get exactly right, so #GTimer provides a
* portable/convenient interface. * portable/convenient interface.
*
* <note><para>
* #GTimer uses a higher-quality clock when thread support is available.
* Therefore, calling g_thread_init() while timers are running may lead to
* unreliable results. It is best to call g_thread_init() before starting any
* timers, if you are using threads at all.
* </para></note>
**/ **/
#define G_NSEC_PER_SEC 1000000000
#define GETTIME(v) (v = g_thread_gettime ())
/** /**
* GTimer: * GTimer:
* *
@ -93,7 +106,7 @@ g_timer_new (void)
timer = g_new (GTimer, 1); timer = g_new (GTimer, 1);
timer->active = TRUE; timer->active = TRUE;
timer->start = g_get_monotonic_time (); GETTIME (timer->start);
return timer; return timer;
} }
@ -128,7 +141,7 @@ g_timer_start (GTimer *timer)
timer->active = TRUE; timer->active = TRUE;
timer->start = g_get_monotonic_time (); GETTIME (timer->start);
} }
/** /**
@ -145,7 +158,7 @@ g_timer_stop (GTimer *timer)
timer->active = FALSE; timer->active = FALSE;
timer->end = g_get_monotonic_time (); GETTIME (timer->end);
} }
/** /**
@ -161,7 +174,7 @@ g_timer_reset (GTimer *timer)
{ {
g_return_if_fail (timer != NULL); g_return_if_fail (timer != NULL);
timer->start = g_get_monotonic_time (); GETTIME (timer->start);
} }
/** /**
@ -189,7 +202,7 @@ g_timer_continue (GTimer *timer)
elapsed = timer->end - timer->start; elapsed = timer->end - timer->start;
timer->start = g_get_monotonic_time (); GETTIME (timer->start);
timer->start -= elapsed; timer->start -= elapsed;
@ -219,7 +232,7 @@ g_timer_continue (GTimer *timer)
**/ **/
gdouble gdouble
g_timer_elapsed (GTimer *timer, g_timer_elapsed (GTimer *timer,
gulong *microseconds) gulong *microseconds)
{ {
gdouble total; gdouble total;
gint64 elapsed; gint64 elapsed;
@ -227,7 +240,7 @@ g_timer_elapsed (GTimer *timer,
g_return_val_if_fail (timer != NULL, 0); g_return_val_if_fail (timer != NULL, 0);
if (timer->active) if (timer->active)
timer->end = g_get_monotonic_time (); GETTIME (timer->end);
elapsed = timer->end - timer->start; elapsed = timer->end - timer->start;
@ -244,13 +257,57 @@ g_usleep (gulong microseconds)
{ {
#ifdef G_OS_WIN32 #ifdef G_OS_WIN32
Sleep (microseconds / 1000); Sleep (microseconds / 1000);
#else #else /* !G_OS_WIN32 */
# ifdef HAVE_NANOSLEEP
struct timespec request, remaining; struct timespec request, remaining;
request.tv_sec = microseconds / G_USEC_PER_SEC; request.tv_sec = microseconds / G_USEC_PER_SEC;
request.tv_nsec = 1000 * (microseconds % G_USEC_PER_SEC); request.tv_nsec = 1000 * (microseconds % G_USEC_PER_SEC);
while (nanosleep (&request, &remaining) == -1 && errno == EINTR) while (nanosleep (&request, &remaining) == -1 && errno == EINTR)
request = remaining; request = remaining;
#endif # else /* !HAVE_NANOSLEEP */
# ifdef HAVE_NSLEEP
/* on AIX, nsleep is analogous to nanosleep */
struct timespec request, remaining;
request.tv_sec = microseconds / G_USEC_PER_SEC;
request.tv_nsec = 1000 * (microseconds % G_USEC_PER_SEC);
while (nsleep (&request, &remaining) == -1 && errno == EINTR)
request = remaining;
# else /* !HAVE_NSLEEP */
if (g_thread_supported ())
{
static GStaticMutex mutex = G_STATIC_MUTEX_INIT;
static GCond* cond = NULL;
GTimeVal end_time;
g_get_current_time (&end_time);
if (microseconds > G_MAXLONG)
{
microseconds -= G_MAXLONG;
g_time_val_add (&end_time, G_MAXLONG);
}
g_time_val_add (&end_time, microseconds);
g_static_mutex_lock (&mutex);
if (!cond)
cond = g_cond_new ();
while (g_cond_timed_wait (cond, g_static_mutex_get_mutex (&mutex),
&end_time))
/* do nothing */;
g_static_mutex_unlock (&mutex);
}
else
{
struct timeval tv;
tv.tv_sec = microseconds / G_USEC_PER_SEC;
tv.tv_usec = microseconds % G_USEC_PER_SEC;
select(0, NULL, NULL, NULL, &tv);
}
# endif /* !HAVE_NSLEEP */
# endif /* !HAVE_NANOSLEEP */
#endif /* !G_OS_WIN32 */
} }
/** /**