fix alarm in WIN32/cygwin (I hope).

git-svn-id: https://yap.svn.sf.net/svnroot/yap/trunk@314 b08c6af1-5177-4d33-ba66-4b1c6b8b522a
This commit is contained in:
vsc 2002-01-21 20:07:15 +00:00
parent 363a201ad2
commit 04aae3895d
2 changed files with 31 additions and 15 deletions

View File

@ -1940,13 +1940,27 @@ static Int p_file_age(void)
/* wrapper for alarm system call */
#if _MSC_VER || defined(__MINGW32__)
static VOID CALLBACK HandleTimer(LPVOID v, DWORD d1, DWORD d2) {
/* force the system to creep */
exit(0);
static DWORD WINAPI
DoTimerThread(LPVOID targ)
{
Int time = *(Int *)targ;
HANDLE htimer;
LARGE_INTEGER liDueTime;
htimer = CreateWaitableTimer(NULL,FALSE,NULL);
liDueTime.QuadPart = -10000000LL*time;
/* Copy the relative time into a LARGE_INTEGER. */
if (SetWaitableTimer(htimer, &liDueTime,0,NULL,NULL,0) == 0) {
return(FALSE);
}
if (WaitForSingleObject(htimer, INFINITE) != WAIT_OBJECT_0)
fprintf(stderr,"WaitForSingleObject failed (%ld)\n", GetLastError());
p_creep ();
/* now, say what is going on */
PutValue(AtomAlarm, MkAtomTerm(AtomTrue));
ExitThread(1);
}
#endif
static Int
@ -1964,22 +1978,23 @@ p_alarm(void)
#if _MSC_VER || defined(__MINGW32__)
{
Term tout;
HANDLE htimer;
Int time = -IntegerOfTerm(t);
Int time = IntegerOfTerm(t);
if (time != 0) {
__int64 due_time;
LARGE_INTEGER liDueTime;
DWORD dwThreadId;
HANDLE hThread;
htimer = CreateWaitableTimer(NULL,FALSE,NULL);
due_time = time;
due_time *= 10000000;
/* Copy the relative time into a LARGE_INTEGER. */
liDueTime.LowPart = (DWORD) ( due_time & 0xFFFFFFFF );
liDueTime.HighPart = (LONG) ( due_time >> 32 );
if (SetWaitableTimer(htimer, &liDueTime,0,HandleTimer,NULL,0) == 0) {
hThread = CreateThread(
NULL, /* no security attributes */
0, /* use default stack size */
DoTimerThread, /* thread function */
(LPVOID)&time, /* argument to thread function */
0, /* use default creation flags */
&dwThreadId); /* returns the thread identifier */
/* Check the return value for success. */
if (hThread == NULL) {
WinError("trying to use alarm");
return(FALSE);
}
}
tout = MkIntegerTerm(0);

View File

@ -110,6 +110,7 @@ assertz_static(V) :- var(V), !,
throw(error(instantiation_error,assertz_static(V))).
assertz_static(C) :-
'$current_module'(Mod),
(predicate_property(short(_), dynamic) -> write(yes), nl ; write(no),nl),
'$assert_static'(C,Mod,last,_,assertz_static(C)).
'$assert_static'(V,M,_,_,_) :- var(V), !,