mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-03-30 20:33:08 +02:00
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:
parent
4a012a9754
commit
9806040455
@ -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
|
||||||
|
@ -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;
|
||||||
|
@ -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) ( \
|
||||||
|
@ -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 */
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
x
Reference in New Issue
Block a user