| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | /*************************************************************************
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |  *									 * | 
					
						
							|  |  |  |  *	 YAP Prolog 							 * | 
					
						
							|  |  |  |  *									 * | 
					
						
							|  |  |  |  *	Yap Prolog was developed at NCCUP - Universidade do Porto	 * | 
					
						
							|  |  |  |  *									 * | 
					
						
							|  |  |  |  * Copyright L.Damas, V.S.Costa and Universidade do Porto 1985-1997	 * | 
					
						
							|  |  |  |  *									 * | 
					
						
							|  |  |  |  ************************************************************************** | 
					
						
							|  |  |  |  *									 * | 
					
						
							|  |  |  |  * File:		sysbits.c						 * | 
					
						
							|  |  |  |  * Last rev:	4/03/88							 * | 
					
						
							|  |  |  |  * mods:									 * | 
					
						
							|  |  |  |  * comments:	very much machine dependent routines			 * | 
					
						
							|  |  |  |  *									 * | 
					
						
							|  |  |  |  *************************************************************************/ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #ifdef SCCS
 | 
					
						
							|  |  |  | static char SccsId[] = "%W% %G%"; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-04 23:58:23 +00:00
										 |  |  | // @{
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-11 14:06:57 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  |    @addtogroup YAPOS | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * In this routine we shall try to include the inevitably machine dependant | 
					
						
							| 
									
										
										
										
											2001-11-26 16:05:19 +00:00
										 |  |  |  * routines. These include, for the moment : Time, A rudimentary form of | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |  * signal handling, OS calls, | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Vitor Santos Costa, February 1987 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-10-17 03:42:14 +00:00
										 |  |  | /* windows.h does not like absmi.h, this
 | 
					
						
							|  |  |  |    should fix it for now */ | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | #if _WIN32 || __MINGW32__
 | 
					
						
							|  |  |  | #include <winsock2.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2002-10-17 03:42:14 +00:00
										 |  |  | #include "absmi.h"
 | 
					
						
							|  |  |  | #include "yapio.h"
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #include "alloc.h"
 | 
					
						
							|  |  |  | #include <math.h>
 | 
					
						
							|  |  |  | #if STDC_HEADERS
 | 
					
						
							|  |  |  | #include <stdlib.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | #if HAVE_WINDOWS_H
 | 
					
						
							|  |  |  | #include <windows.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2007-05-26 08:19:33 +00:00
										 |  |  | #if HAVE_SYS_TIME_H && !_MSC_VER
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #include <sys/time.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_UNISTD_H
 | 
					
						
							|  |  |  | #include <unistd.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_SYS_WAIT_H && !defined(__MINGW32__) && !_MSC_VER
 | 
					
						
							|  |  |  | #include <sys/wait.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_STRING_H
 | 
					
						
							|  |  |  | #include <string.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if !HAVE_STRNCAT
 | 
					
						
							|  |  |  | #define strncat(X,Y,Z) strcat(X,Y)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if !HAVE_STRNCPY
 | 
					
						
							|  |  |  | #define strncpy(X,Y,Z) strcpy(X,Y)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_GETPWNAM
 | 
					
						
							|  |  |  | #include <pwd.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2014-03-04 12:02:26 +00:00
										 |  |  | #include <ctype.h>
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #if HAVE_SYS_STAT_H
 | 
					
						
							|  |  |  | #include <sys/stat.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_SYS_TYPES_H
 | 
					
						
							|  |  |  | #include <sys/types.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_FCNTL_H
 | 
					
						
							|  |  |  | #include <fcntl.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2002-01-19 16:10:53 +00:00
										 |  |  | #if  _MSC_VER || defined(__MINGW32__)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #include <windows.h>
 | 
					
						
							|  |  |  | /* required for DLL compatibility */ | 
					
						
							|  |  |  | #if HAVE_DIRECT_H
 | 
					
						
							|  |  |  | #include <direct.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #include <io.h>
 | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | #include <shlwapi.h>
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #if HAVE_SYS_PARAM_H
 | 
					
						
							|  |  |  | #include <sys/param.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2012-04-18 14:14:56 -05:00
										 |  |  | /* CYGWIN seems to include this automatically */ | 
					
						
							|  |  |  | #if HAVE_FENV_H && !defined(__CYGWIN__)
 | 
					
						
							| 
									
										
										
										
											2009-06-15 14:59:50 -05:00
										 |  |  | #include <fenv.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-15 15:07:04 +01:00
										 |  |  | #if defined(ENABLE_SYSTEM_EXPANSION) && HAVE_WORDEXP_H
 | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | #include <wordexp.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_LIBGEN_H
 | 
					
						
							|  |  |  | #include <libgen.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2009-06-15 14:59:50 -05:00
										 |  |  | #if HAVE_READLINE_READLINE_H
 | 
					
						
							| 
									
										
										
										
											2001-06-12 17:25:28 +00:00
										 |  |  | #include <readline/readline.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | /// File Error Handler
 | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | static void | 
					
						
							|  |  |  | Yap_FileError(yap_error_number type, Term where, const char *format,...) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  |    | 
					
						
							|  |  |  |     if ( trueLocalPrologFlag(FILEERRORS_FLAG) ) { | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |       va_list ap; | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |       va_start (ap, format); | 
					
						
							|  |  |  |       /* now build the error string */ | 
					
						
							|  |  |  |       Yap_Error(type, TermNil, format, ap); | 
					
						
							|  |  |  |       va_end (ap); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-25 16:40:36 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-25 17:15:04 -05:00
										 |  |  | static void InitTime(int); | 
					
						
							|  |  |  | static void InitWTime(void); | 
					
						
							|  |  |  | static Int p_sh( USES_REGS1 ); | 
					
						
							|  |  |  | static Int p_shell( USES_REGS1 ); | 
					
						
							|  |  |  | static Int p_system( USES_REGS1 ); | 
					
						
							|  |  |  | static Int p_mv( USES_REGS1 ); | 
					
						
							|  |  |  | static Int p_dir_sp( USES_REGS1 ); | 
					
						
							|  |  |  | static void InitRandom(void); | 
					
						
							|  |  |  | static Int p_alarm( USES_REGS1 ); | 
					
						
							|  |  |  | static Int p_getenv( USES_REGS1 ); | 
					
						
							|  |  |  | static Int p_putenv( USES_REGS1 ); | 
					
						
							| 
									
										
										
										
											2014-10-14 01:13:31 +01:00
										 |  |  | static bool set_fpu_exceptions(bool); | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  | static char *expandVars(const char *pattern, char *expanded, int maxlen); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #ifdef MACYAP
 | 
					
						
							| 
									
										
										
										
											2013-04-25 17:15:04 -05:00
										 |  |  | static int chdir(char *); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | /* #define signal	skel_signal */ | 
					
						
							|  |  |  | #endif /* MACYAP */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-01-23 02:28:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-25 17:15:04 -05:00
										 |  |  | void exit(int); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-05 07:45:36 +00:00
										 |  |  | #ifdef __WINDOWS__
 | 
					
						
							| 
									
										
										
										
											2010-04-07 01:35:44 +01:00
										 |  |  | void | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_WinError(char *yap_error) | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   char msg[256]; | 
					
						
							|  |  |  |   /* Error, we could not read time */ | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS, | 
					
						
							|  |  |  | 		NULL, GetLastError(), | 
					
						
							|  |  |  | 		MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), msg, 256, | 
					
						
							|  |  |  | 		NULL); | 
					
						
							|  |  |  |   Yap_Error(OPERATING_SYSTEM_ERROR, TermNil, "%s at %s", msg, yap_error); | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2014-11-09 12:06:40 +00:00
										 |  |  | #endif /* __WINDOWS__ */
 | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #define is_valid_env_char(C) ( ((C) >= 'a' && (C) <= 'z') || ((C) >= 'A' && \
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 							      (C) <= 'Z') || (C) == '_' ) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | #if __ANDROID__
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | AAssetManager * Yap_assetManager; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void * | 
					
						
							|  |  |  | Yap_openAssetFile( const char *path ) { | 
					
						
							|  |  |  |   const char * p = path+8; | 
					
						
							|  |  |  |   AAsset* asset = AAssetManager_open(Yap_assetManager, p, AASSET_MODE_UNKNOWN); | 
					
						
							|  |  |  |   return asset; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool | 
					
						
							|  |  |  | Yap_isAsset( const char *path ) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2015-04-15 11:21:15 +01:00
										 |  |  |   if (Yap_assetManager == NULL) | 
					
						
							|  |  |  |     return false; | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |   return path[0] == '/'&& | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     path[1] == 'a'&& | 
					
						
							|  |  |  |     path[2] == 's'&& | 
					
						
							|  |  |  |     path[3] == 's'&& | 
					
						
							|  |  |  |     path[4] == 'e'&& | 
					
						
							|  |  |  |     path[5] == 't'&& | 
					
						
							|  |  |  |     path[6] == 's'&& | 
					
						
							|  |  |  |     (path[7] == '/' || path[7] == '\0'); | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool | 
					
						
							|  |  |  | Yap_AccessAsset( const char *name, int mode ) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   AAssetManager* mgr = Yap_assetManager; | 
					
						
							|  |  |  |   const char *bufp=name+7; | 
					
						
							| 
									
										
										
										
											2015-04-15 11:21:15 +01:00
										 |  |  |      | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   if (bufp[0] == '/') | 
					
						
							|  |  |  |     bufp++; | 
					
						
							|  |  |  |   if ((mode & W_OK) == W_OK) { | 
					
						
							|  |  |  |     return false; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   // directory works if file exists
 | 
					
						
							|  |  |  |   AAssetDir *assetDir = AAssetManager_openDir(mgr, bufp); | 
					
						
							|  |  |  |   if (assetDir) { | 
					
						
							|  |  |  |     AAssetDir_close(assetDir); | 
					
						
							|  |  |  |     return true; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return false; | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool | 
					
						
							|  |  |  | Yap_AssetIsFile( const char *name ) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   AAssetManager* mgr = Yap_assetManager; | 
					
						
							|  |  |  |   const char *bufp=name+7; | 
					
						
							|  |  |  |   if (bufp[0] == '/') | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |     bufp++; | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   // check if file is a directory.
 | 
					
						
							|  |  |  |   AAsset *asset = AAssetManager_open(mgr, bufp, AASSET_MODE_UNKNOWN); | 
					
						
							|  |  |  |   if (!asset) | 
					
						
							|  |  |  |     return false; | 
					
						
							|  |  |  |   AAsset_close(asset); | 
					
						
							|  |  |  |   return true; | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool | 
					
						
							|  |  |  | Yap_AssetIsDir( const char *name ) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   AAssetManager* mgr = Yap_assetManager; | 
					
						
							|  |  |  |   const char *bufp=name+7; | 
					
						
							|  |  |  |   if (bufp[0] == '/') | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |     bufp++; | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   // check if file is a directory.
 | 
					
						
							|  |  |  |   AAssetDir *assetDir = AAssetManager_openDir(mgr, bufp); | 
					
						
							|  |  |  |   if (!assetDir) { | 
					
						
							|  |  |  |     return false; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   AAssetDir_close(assetDir); | 
					
						
							|  |  |  |   AAsset *asset = AAssetManager_open(mgr, bufp, AASSET_MODE_UNKNOWN); | 
					
						
							|  |  |  |   if (!asset) | 
					
						
							|  |  |  |     return true; | 
					
						
							|  |  |  |   AAsset_close(asset); | 
					
						
							|  |  |  |   return false; | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int64_t | 
					
						
							|  |  |  | Yap_AssetSize( const char *name ) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   AAssetManager* mgr = Yap_assetManager; | 
					
						
							|  |  |  |   const char *bufp=name+7; | 
					
						
							|  |  |  |   if (bufp[0] == '/') | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |     bufp++; | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   AAsset *asset = AAssetManager_open(mgr, bufp, AASSET_MODE_UNKNOWN); | 
					
						
							|  |  |  |   if (!asset) | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |     return -1; | 
					
						
							|  |  |  |   off64_t len = AAsset_getLength64(asset); | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   AAsset_close(asset); | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |   return len; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | /// is_directory: verifies whether an expanded file name
 | 
					
						
							|  |  |  | /// points at a readable directory
 | 
					
						
							|  |  |  | static bool | 
					
						
							| 
									
										
										
										
											2014-11-09 12:06:40 +00:00
										 |  |  | is_directory(const char *FileName) | 
					
						
							| 
									
										
										
										
											2006-05-17 18:38:11 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | #ifdef __ANDROID__
 | 
					
						
							|  |  |  |   if (Yap_isAsset(FileName)) { | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     return Yap_AssetIsDir(FileName); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-09 12:06:40 +00:00
										 |  |  | #ifdef __WINDOWS__
 | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |   DWORD dwAtts = GetFileAttributes( FileName ); | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   if (dwAtts == INVALID_FILE_ATTRIBUTES) | 
					
						
							|  |  |  |     return false; | 
					
						
							|  |  |  |   return (dwAtts & FILE_ATTRIBUTE_DIRECTORY); | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | #elif HAVE_LSTAT
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   struct stat buf; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (lstat(FileName, &buf) == -1) { | 
					
						
							|  |  |  |     /* return an error number */ | 
					
						
							|  |  |  |     return false; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return S_ISDIR(buf.st_mode); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |   Yap_Error(SYSTEM_ERROR, TermNil, | 
					
						
							|  |  |  | 	    "stat not available in this configuration"); | 
					
						
							|  |  |  |   return false; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2014-11-09 12:06:40 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | /// has_access just calls access
 | 
					
						
							|  |  |  | /// it uses F_OK, R_OK and friend
 | 
					
						
							|  |  |  | static bool | 
					
						
							|  |  |  | has_access(const char *FileName, int mode) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | #ifdef __ANDROID__
 | 
					
						
							|  |  |  |   if (Yap_isAsset(FileName)) { | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     return Yap_AccessAsset(FileName, mode); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_ACCESS
 | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |   if (access( FileName, mode ) == 0) | 
					
						
							|  |  |  |     return true; | 
					
						
							|  |  |  |   if (errno == EINVAL) { | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |     Yap_Error(SYSTEM_ERROR, TermNil, | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |               "bad flags to access"); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return false; | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |   Yap_Error(SYSTEM_ERROR, TermNil, | 
					
						
							|  |  |  |             "access not available in this configuration"); | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |   return false; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static bool | 
					
						
							|  |  |  | exists( const char *f) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return has_access( f, F_OK ); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-15 11:21:15 +01:00
										 |  |  | static int | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | dir_separator (int ch) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #ifdef MAC
 | 
					
						
							|  |  |  |   return (ch == ':'); | 
					
						
							|  |  |  | #elif ATARI || _MSC_VER
 | 
					
						
							|  |  |  |   return (ch == '\\'); | 
					
						
							|  |  |  | #elif defined(__MINGW32__) || defined(__CYGWIN__)
 | 
					
						
							|  |  |  |   return (ch == '\\' || ch == '/'); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |   return (ch == '/'); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int | 
					
						
							|  |  |  | Yap_dir_separator (int ch) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return dir_separator (ch); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2014-11-09 12:06:40 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #if __WINDOWS__
 | 
					
						
							| 
									
										
										
										
											2014-11-28 02:30:58 +00:00
										 |  |  | #include <psapi.h>
 | 
					
						
							| 
									
										
										
										
											2014-11-09 12:06:40 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-28 02:30:58 +00:00
										 |  |  | char *libdir = NULL; | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2014-11-09 12:06:40 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  | bool | 
					
						
							|  |  |  | Yap_IsAbsolutePath(const char *p0) | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  |   // verify first if expansion is needed: ~/ or $HOME/
 | 
					
						
							|  |  |  |   char c[MAXPATHLEN+1]; | 
					
						
							|  |  |  |   char *p = expandVars( p0, c, MAXPATHLEN ); | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | #if _WIN32 || __MINGW32__
 | 
					
						
							|  |  |  |   return !PathIsRelative(p); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |   return p[0] == '/'; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | #define isValidEnvChar(C) ( ((C) >= 'a' && (C) <= 'z') || ((C) >= 'A' && \
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 							   (C) <= 'Z') || (C) == '_' ) | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | // this is necessary because
 | 
					
						
							|  |  |  | // support for ~expansion at the beginning
 | 
					
						
							|  |  |  | // systems like Android do not do this.
 | 
					
						
							|  |  |  | static char * | 
					
						
							|  |  |  | yapExpandVars (const char *source, char *result) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   const char *src = source; | 
					
						
							|  |  |  |   char *res = result; | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   if(result == NULL) | 
					
						
							|  |  |  |     result = malloc( YAP_FILENAME_MAX+1); | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |   if (strlen(source) >= YAP_FILENAME_MAX) { | 
					
						
							|  |  |  |     Yap_Error(OPERATING_SYSTEM_ERROR, TermNil, "%s in true_file-name is larger than the buffer size (%d bytes)", source, strlen(source)); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   /* step 1: eating home information */ | 
					
						
							|  |  |  |   if (source[0] == '~') { | 
					
						
							|  |  |  |     if (dir_separator(source[1]) || source[1] == '\0') | 
					
						
							|  |  |  |       { | 
					
						
							|  |  |  | 	char *s; | 
					
						
							|  |  |  | 	src++; | 
					
						
							|  |  |  | #if defined(_WIN32)
 | 
					
						
							|  |  |  | 	s = getenv("HOMEDRIVE"); | 
					
						
							|  |  |  | 	if (s != NULL) | 
					
						
							|  |  |  | 	  strncpy (result, getenv ("HOMEDRIVE"), YAP_FILENAME_MAX); | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	//s = getenv("HOMEPATH");
 | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | #else
 | 
					
						
							|  |  |  | 	s = getenv ("HOME"); | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | 	if (s != NULL) | 
					
						
							|  |  |  | 	  strncpy (result, s, YAP_FILENAME_MAX); | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	strcat(result,src); | 
					
						
							|  |  |  | 	return result; | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |       } else { | 
					
						
							|  |  |  | #if HAVE_GETPWNAM
 | 
					
						
							|  |  |  |       struct passwd *user_passwd; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       src++; | 
					
						
							|  |  |  |       while (!dir_separator((*res = *src)) && *res != '\0') | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	res++, src++; | 
					
						
							|  |  |  |       res[0] = '\0'; | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |       if ((user_passwd = getpwnam (result)) == NULL) { | 
					
						
							|  |  |  |         Yap_FileError(OPERATING_SYSTEM_ERROR, MkAtomTerm(Yap_LookupAtom(source)),"User %s does not exist in %s", result, source); | 
					
						
							|  |  |  | 	return NULL; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       strncpy (result, user_passwd->pw_dir, YAP_FILENAME_MAX); | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       strcat(result, src); | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | #else
 | 
					
						
							|  |  |  |       Yap_FileError(OPERATING_SYSTEM_ERROR, MkAtomTerm(Yap_LookupAtom(source)),"User %s cannot be found in %s, missing getpwnam", result, source); | 
					
						
							|  |  |  |       return NULL; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return result; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   // do VARIABLE expansion
 | 
					
						
							|  |  |  |   else if (source[0] == '$') { | 
					
						
							|  |  |  |     /* follow SICStus expansion rules */ | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |        char v[YAP_FILENAME_MAX+1]; | 
					
						
							|  |  |  |    int ch; | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |     char *s; | 
					
						
							|  |  |  |     src = source+1; | 
					
						
							|  |  |  |     if (src[0] == '{') { | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       res = v; | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |       src++; | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       while ((*res = (ch = *src++)) && isValidEnvChar (ch) && ch != '}') { | 
					
						
							|  |  |  | 	res++; | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |       } | 
					
						
							|  |  |  |       if (ch == '}') { | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	// {...}
 | 
					
						
							|  |  |  | 	// done
 | 
					
						
							|  |  |  |      res[0] = '\0'; | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |      } else { | 
					
						
							|  |  |  |        res = v; | 
					
						
							|  |  |  |       while ((*res = (ch = *src++)) && isValidEnvChar (ch) && ch != '}') { | 
					
						
							|  |  |  | 	res++; | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |       } | 
					
						
							|  |  |  |       src--; | 
					
						
							|  |  |  |     res[0] = '\0'; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     if ((s = (char *) getenv (v))) { | 
					
						
							|  |  |  |       strcpy (result, s); | 
					
						
							|  |  |  |       strcat (result, src); | 
					
						
							|  |  |  |     } else | 
					
						
							|  |  |  |       strcpy( result, src); | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							|  |  |  |     strncpy (result, source, YAP_FILENAME_MAX); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return result; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  | static char * | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | expandVars(const char *pattern, char *expanded, int maxlen) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   return yapExpandVars(pattern, expanded); | 
					
						
							| 
									
										
										
										
											2015-04-15 15:07:04 +01:00
										 |  |  | #if ( __WIN32 || __MINGW32__ ) && defined(ENABLE_SYSTEM_EXPANSION)
 | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |   DWORD  retval=0; | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  |   // notice that the file does not need to exist
 | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |   if (ini == NULL) { | 
					
						
							|  |  |  |     ini = malloc(strlen(w)+1); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |   retval = ExpandEnvironmentStrings(pattern, | 
					
						
							|  |  |  | 				    expanded, | 
					
						
							|  |  |  | 				    maxlen); | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |   if (retval == 0) | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |     { | 
					
						
							|  |  |  |       Yap_WinError("Generating a full path name for a file" ); | 
					
						
							|  |  |  |       return NULL; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |   return expanded; | 
					
						
							| 
									
										
										
										
											2015-04-15 15:07:04 +01:00
										 |  |  | #elif HAVE_WORDEXP && defined(ENABLE_SYSTEM_EXPANSION)
 | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |   wordexp_t result; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |   /* Expand the string for the program to run.  */ | 
					
						
							|  |  |  |   switch (wordexp (pattern, &result, 0)) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     case 0:                     /* Successful.  */ | 
					
						
							|  |  |  |       if (result.we_wordv[1]) { | 
					
						
							|  |  |  | 	wordfree (&result); | 
					
						
							|  |  |  | 	return NULL; | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  | 	char *w = result.we_wordv[0]; | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	if (expanded == NULL) { | 
					
						
							|  |  |  | 	  expanded = malloc(strlen(w)+1); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | 	strncpy( expanded, w, maxlen ); | 
					
						
							|  |  |  | 	wordfree (&result); | 
					
						
							|  |  |  | 	return expanded; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       break; | 
					
						
							|  |  |  |     case WRDE_NOSPACE: | 
					
						
							|  |  |  |       /* If the error was WRDE_NOSPACE,
 | 
					
						
							|  |  |  |          then perhaps part of the result was allocated.  */ | 
					
						
							|  |  |  |       wordfree (&result); | 
					
						
							|  |  |  |     default:                    /* Some other error.  */ | 
					
						
							|  |  |  |       return NULL; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | #else
 | 
					
						
							|  |  |  |   // just use basic
 | 
					
						
							|  |  |  |   if (expanded == NULL) { | 
					
						
							|  |  |  |     expanded = malloc(strlen(pattern)+1); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   strcpy(expanded, pattern); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |   return expanded; | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if _WIN32 || defined(__MINGW32__)
 | 
					
						
							|  |  |  | // straightforward conversion from Unix style to WIN style
 | 
					
						
							|  |  |  | // check cygwin path.cc for possible improvements
 | 
					
						
							|  |  |  | static char * | 
					
						
							|  |  |  | unix2win( const char *source, char *target, int max) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   char *s = target; | 
					
						
							|  |  |  |   const char *s0 = source; | 
					
						
							|  |  |  |   char *s1; | 
					
						
							|  |  |  |   int ch; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (s == NULL) | 
					
						
							|  |  |  |     s = malloc(YAP_FILENAME_MAX+1); | 
					
						
							|  |  |  |   s1 = s; | 
					
						
							|  |  |  |   // win32 syntax
 | 
					
						
							|  |  |  |   // handle drive notation, eg //a/
 | 
					
						
							|  |  |  |   if (s0[0] == '\0') { | 
					
						
							|  |  |  |     s[0] = '.'; | 
					
						
							|  |  |  |     s[1] = '\0'; | 
					
						
							|  |  |  |     return s; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (s0[0] == '/' &&  s0[1] == '/' && isalpha(s0[2]) && s0[3] == '/') | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |       s1[0] = s0[2]; | 
					
						
							|  |  |  |       s1[1] = ':'; | 
					
						
							|  |  |  |       s1[2] = '\\'; | 
					
						
							|  |  |  |       s0+=4; | 
					
						
							|  |  |  |       s1+=3; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   while ((ch = *s1++ = *s0++)) { | 
					
						
							|  |  |  |     if (ch == '$') { | 
					
						
							|  |  |  |       s1[-1] = '%'; | 
					
						
							|  |  |  |       ch = *s0; | 
					
						
							|  |  |  |       // handle $(....)
 | 
					
						
							|  |  |  |       if (ch == '{') { | 
					
						
							|  |  |  |         s0++; | 
					
						
							|  |  |  |         while ((ch = *s0++) != '}') { | 
					
						
							|  |  |  |           *s1++ = ch; | 
					
						
							|  |  |  |           if (ch == '\0') return FALSE; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         *s1++ = '%'; | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  |         while (((ch = *s1++ = *s0++) >= 'A' && ch <= 'Z') || (ch >= 'a' && ch <= 'z') || (ch == '-') || (ch >= '0' && ch <= '9') || (ch == '_')); | 
					
						
							|  |  |  |         s1[-1] = '%'; | 
					
						
							|  |  |  |         *s1++ = ch; | 
					
						
							|  |  |  |         if (ch == '\0') { s1--; s0--; } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } else if (ch == '/') | 
					
						
							|  |  |  |       s1[-1] = '\\'; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return s; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if O_XOS
 | 
					
						
							|  |  |  | char * | 
					
						
							|  |  |  | PrologPath(const char *p, char *buf, size_t len) | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  | {  | 
					
						
							|  |  |  |   int flags = (trueGlobalPrologFlag(PLFLAG_FILE_CASE) ? 0 : XOS_DOWNCASE); | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   return _xos_canonical_filename(p, buf, len, flags); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  | static char * | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | OsPath(const char *p, char *buf) | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | { | 
					
						
							|  |  |  |   if()z | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	trcpy(buf, p); | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   return buf; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  | static char * | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | OsPath(const char *X, char *Y) { | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   if (X!=Y && Y) strcpy(Y,X); | 
					
						
							|  |  |  |   return (char *)Y  ; | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | } | 
					
						
							|  |  |  | #endif /* O_XOS */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if _WIN32
 | 
					
						
							|  |  |  | #define HAVE_BASENAME 1
 | 
					
						
							|  |  |  | #define HAVE_REALPATH 1
 | 
					
						
							|  |  |  | #define HAVE_WORDEXP 1
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  | static bool ChDir(const char *path) { | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |   bool rc = false; | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  |   char *qpath = Yap_AbsoluteFile(path, NULL); | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef __ANDROID__
 | 
					
						
							|  |  |  |   if (GLOBAL_AssetsWD) { | 
					
						
							|  |  |  |     free( GLOBAL_AssetsWD ); | 
					
						
							|  |  |  |     GLOBAL_AssetsWD = NULL; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (Yap_isAsset(qpath) ) { | 
					
						
							|  |  |  |     AAssetManager* mgr = Yap_assetManager; | 
					
						
							|  |  |  |     const char *ptr = qpath+8; | 
					
						
							|  |  |  |     AAssetDir* d; | 
					
						
							|  |  |  |     if (ptr[0] == '/') | 
					
						
							|  |  |  |       ptr++; | 
					
						
							|  |  |  |     d = AAssetManager_openDir(mgr, ptr); | 
					
						
							|  |  |  |     if (d) { | 
					
						
							|  |  |  |       GLOBAL_AssetsWD = malloc( strlen(qpath) + 1 ); | 
					
						
							|  |  |  |       strcpy( GLOBAL_AssetsWD, qpath ); | 
					
						
							|  |  |  |       AAssetDir_close( d ); | 
					
						
							|  |  |  |       return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return false; | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     GLOBAL_AssetsWD = NULL; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | #if _WIN32 || defined(__MINGW32__)
 | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  |    | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |     if ((rc = (SetCurrentDirectory(qpath) != 0)) == 0) | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       { | 
					
						
							|  |  |  | 	Yap_WinError("SetCurrentDirectory failed" ); | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  |   rc = (chdir(qpath) == 0); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |   free( qpath ); | 
					
						
							|  |  |  |   return rc; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #if _WIN32 || defined(__MINGW32__)
 | 
					
						
							|  |  |  | char * | 
					
						
							|  |  |  | BaseName(const char *X) { | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |   char *qpath = unix2win(X, NULL, YAP_FILENAME_MAX); | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |   char base[YAP_FILENAME_MAX], ext[YAP_FILENAME_MAX]; | 
					
						
							|  |  |  |   _splitpath(qpath, NULL, NULL, base, ext); | 
					
						
							|  |  |  |   strcpy(qpath, base); | 
					
						
							|  |  |  |   strcat(qpath, ext); | 
					
						
							|  |  |  |   return qpath; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | char * | 
					
						
							|  |  |  | DirName(const char *X) { | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |   char dir[YAP_FILENAME_MAX]; | 
					
						
							|  |  |  |   char drive[YAP_FILENAME_MAX]; | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |   char *o = unix2win(X, NULL, YAP_FILENAME_MAX); | 
					
						
							|  |  |  |   int err; | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |   if (!o) | 
					
						
							|  |  |  |     return NULL; | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |   if (( err = _splitpath_s(o, drive, YAP_FILENAME_MAX-1, dir, YAP_FILENAME_MAX-1,NULL, 0, NULL, 0) ) != 0) { | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |     Yap_FileError(OPERATING_SYSTEM_ERROR, TermNil, "could not perform _splitpath %s: %s", X, strerror(errno)); | 
					
						
							|  |  |  |     return NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   strncpy(o, drive, YAP_FILENAME_MAX-1); | 
					
						
							|  |  |  |   strncat(o, dir, YAP_FILENAME_MAX-1); | 
					
						
							|  |  |  |   return o; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static char *myrealpath( const char *path, char *out) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #if _WIN32 || defined(__MINGW32__)
 | 
					
						
							|  |  |  |   DWORD  retval=0; | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |   // notice that the file does not need to exist
 | 
					
						
							|  |  |  |   retval = GetFullPathName(path, | 
					
						
							|  |  |  | 			   YAP_FILENAME_MAX, | 
					
						
							|  |  |  |                            out, | 
					
						
							|  |  |  |                            NULL); | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |   if (retval == 0) | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |     { | 
					
						
							|  |  |  |       Yap_WinError("Generating a full path name for a file" ); | 
					
						
							|  |  |  |       return NULL; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   return out; | 
					
						
							|  |  |  | #elif HAVE_REALPATH
 | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     char *rc = realpath(path,out); | 
					
						
							|  |  |  |     char *s0; | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |     if (rc == NULL && (errno == ENOENT|| errno == EACCES)) { | 
					
						
							|  |  |  |       char *s = basename((char *)path); | 
					
						
							|  |  |  |       s0 = malloc(strlen(s)+1); | 
					
						
							|  |  |  |       strcpy(s0, s); | 
					
						
							|  |  |  |       if ((rc = myrealpath(dirname((char *)path), out))==NULL) { | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | 	Yap_FileError(OPERATING_SYSTEM_ERROR, TermNil, "could not find file %s: %s", path, strerror(errno)); | 
					
						
							|  |  |  | 	return NULL; | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |       } | 
					
						
							|  |  |  |       if(rc[strlen(rc)-1] != '/' ) | 
					
						
							|  |  |  | 	strcat(rc, "/"); | 
					
						
							|  |  |  |       strcat(rc, s0); | 
					
						
							|  |  |  |       free(s0); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     return rc; | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |   } | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |   return NULL; | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | char * | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  | Yap_AbsoluteFile(const char *spec, char *tmp) | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  |    | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |     char *rc; | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |   char o[YAP_FILENAME_MAX+1]; | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | #if _WIN32 || defined(__MINGW32__)
 | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |   char u[YAP_FILENAME_MAX+1]; | 
					
						
							|  |  |  |   // first pass, remove Unix style stuff
 | 
					
						
							|  |  |  |   if (unix2win(spec, u, YAP_FILENAME_MAX) == NULL) | 
					
						
							|  |  |  |     return NULL; | 
					
						
							|  |  |  |   spec = (const char *)u; | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |   if (tmp == NULL) { | 
					
						
							|  |  |  |     tmp = malloc(YAP_FILENAME_MAX+1); | 
					
						
							|  |  |  |     if (tmp == NULL) { | 
					
						
							|  |  |  |       return NULL; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  |   if ( 1 || trueGlobalPrologFlag(FILE_NAME_VARIABLES_FLAG) ) | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |       spec=expandVars(spec,o,YAP_FILENAME_MAX); | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | #if HAVE_REALPATH
 | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |   rc =  myrealpath(spec, tmp); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |   return rc; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  | /*
 | 
					
						
							|  |  |  | static char *canoniseFileName( char *path) { | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | #if HAVE_REALPATH && HAVE_BASENAME
 | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | #if _WIN32 || defined(__MINGW32__)
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   char *o = malloc(YAP_FILENAME_MAX+1); | 
					
						
							|  |  |  |   if (!o) | 
					
						
							|  |  |  |     return NULL; | 
					
						
							|  |  |  |   // first pass, remove Unix style stuff
 | 
					
						
							|  |  |  |   if (unix2win(path, o, YAP_FILENAME_MAX) == NULL) | 
					
						
							|  |  |  |     return NULL; | 
					
						
							|  |  |  |   path = o; | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |   char *rc, *tmp = malloc(PATH_MAX); | 
					
						
							|  |  |  |   if (tmp == NULL) return NULL; | 
					
						
							|  |  |  |   rc = myrealpath(path, tmp); | 
					
						
							|  |  |  |   if (rc != tmp) | 
					
						
							|  |  |  |     free(tmp); | 
					
						
							|  |  |  | #if _WIN32 || defined(__MINGW32__)
 | 
					
						
							|  |  |  |   free(o); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |   return rc; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  | */ | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  | static Int | 
					
						
							|  |  |  | absolute_file_name( USES_REGS1 ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   Term t = Deref(ARG1); | 
					
						
							|  |  |  |   const char *fp; | 
					
						
							|  |  |  |   bool rc; | 
					
						
							|  |  |  |   char s[MAXPATHLEN+1]; | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  |   if (IsVarTerm(t)) { | 
					
						
							|  |  |  |     Yap_Error(INSTANTIATION_ERROR, t, "absolute_file_name"); | 
					
						
							|  |  |  |     return false; | 
					
						
							|  |  |  |   } else if (!IsAtomTerm(t)) { | 
					
						
							|  |  |  |     Yap_Error(TYPE_ERROR_ATOM, t, "absolute_file_name"); | 
					
						
							|  |  |  |     return false; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (!(fp = Yap_AbsoluteFile( RepAtom(AtomOfTerm(t))->StrOfAE, s))) | 
					
						
							|  |  |  |     return false; | 
					
						
							|  |  |  |   rc = Yap_unify(MkAtomTerm(Yap_LookupAtom(fp)), ARG2); | 
					
						
							|  |  |  |   if (fp != s) | 
					
						
							|  |  |  |     free( (void *)fp ); | 
					
						
							|  |  |  |   return rc; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static Int | 
					
						
							|  |  |  | prolog_to_os_filename( USES_REGS1 ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   Term t = Deref(ARG1); | 
					
						
							|  |  |  |   const char *fp; | 
					
						
							|  |  |  |   char out[MAXPATHLEN+1]; | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  |   if (IsVarTerm(t)) { | 
					
						
							|  |  |  |     Yap_Error(INSTANTIATION_ERROR, t, "absolute_file_name"); | 
					
						
							|  |  |  |     return false; | 
					
						
							|  |  |  |   } else if (!IsAtomTerm(t)) { | 
					
						
							|  |  |  |     Yap_Error(TYPE_ERROR_ATOM, t, "absolute_file_name"); | 
					
						
							|  |  |  |     return false; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (!(fp = OsPath( RepAtom(AtomOfTerm(t))->StrOfAE, out))) | 
					
						
							|  |  |  |     return false; | 
					
						
							|  |  |  |   return Yap_unify(MkAtomTerm(Yap_LookupAtom(fp)), ARG2); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Atom Yap_TemporaryFile( const char *prefix, int *fd) { | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | #if HAVE_MKSTEMP
 | 
					
						
							|  |  |  |   char *tmp = malloc(PATH_MAX); | 
					
						
							|  |  |  |   int n; | 
					
						
							|  |  |  |   int f; | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  |   if (tmp == NULL) return NIL; | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |   strncpy(tmp, prefix, PATH_MAX-1); | 
					
						
							|  |  |  |   n = strlen( tmp ); | 
					
						
							|  |  |  |   if (n >= 6 && | 
					
						
							|  |  |  |       tmp[n-1] == 'X' && | 
					
						
							|  |  |  |       tmp[n-2] == 'X' && | 
					
						
							|  |  |  |       tmp[n-3] == 'X' && | 
					
						
							|  |  |  |       tmp[n-4] == 'X' && | 
					
						
							|  |  |  |       tmp[n-5] == 'X' && | 
					
						
							|  |  |  |       tmp[n-6] == 'X') | 
					
						
							|  |  |  |     f = mkstemp(tmp); | 
					
						
							|  |  |  |   else { | 
					
						
							|  |  |  |     strncat(tmp, "XXXXXX", PATH_MAX-1); | 
					
						
							|  |  |  |     f = mkstemp(tmp); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (fd) *fd = f; | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  |   return  Yap_LookupAtom(tmp); | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  |   return AtomNil; | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static bool | 
					
						
							| 
									
										
										
										
											2014-11-28 03:21:32 +00:00
										 |  |  | initSysPath(Term tlib, Term tcommons, bool dir_done, bool commons_done) { | 
					
						
							| 
									
										
										
										
											2014-11-28 02:30:58 +00:00
										 |  |  |   CACHE_REGS | 
					
						
							|  |  |  |     int len; | 
					
						
							| 
									
										
										
										
											2014-11-09 12:06:40 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-16 11:43:42 +00:00
										 |  |  | #if __WINDOWS__
 | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     char *dir; | 
					
						
							|  |  |  |     if ((dir = Yap_RegistryGetString("library")) && | 
					
						
							|  |  |  |         is_directory(dir)) { | 
					
						
							|  |  |  |       if (! Yap_unify( tlib, | 
					
						
							|  |  |  |                        MkAtomTerm(Yap_LookupAtom(dir))) ) | 
					
						
							|  |  |  |         return FALSE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     dir_done = true; | 
					
						
							|  |  |  |     if ((dir = Yap_RegistryGetString("prolog_commons")) && | 
					
						
							|  |  |  |         is_directory(dir)) { | 
					
						
							|  |  |  |       if (! Yap_unify( tcommons, | 
					
						
							|  |  |  |                        MkAtomTerm(Yap_LookupAtom(dir))) ) | 
					
						
							|  |  |  |         return FALSE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     commons_done = true; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (dir_done && commons_done) | 
					
						
							|  |  |  |     return TRUE; | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2014-11-28 02:30:58 +00:00
										 |  |  |   strncpy(LOCAL_FileNameBuf, YAP_SHAREDIR, YAP_FILENAME_MAX); | 
					
						
							|  |  |  |   strncat(LOCAL_FileNameBuf,"/", YAP_FILENAME_MAX); | 
					
						
							|  |  |  |   len = strlen(LOCAL_FileNameBuf); | 
					
						
							|  |  |  |   if (!dir_done) { | 
					
						
							|  |  |  |     strncat(LOCAL_FileNameBuf, "Yap", YAP_FILENAME_MAX); | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  |     if (is_directory(LOCAL_FileNameBuf)) | 
					
						
							| 
									
										
										
										
											2014-11-28 02:30:58 +00:00
										 |  |  |       { | 
					
						
							|  |  |  |         if (! Yap_unify( tlib, | 
					
						
							|  |  |  |                          MkAtomTerm(Yap_LookupAtom(LOCAL_FileNameBuf))) ) | 
					
						
							|  |  |  |           return FALSE; | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  | 	dir_done = true; | 
					
						
							| 
									
										
										
										
											2014-11-28 02:30:58 +00:00
										 |  |  |       } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (!commons_done) { | 
					
						
							|  |  |  |     LOCAL_FileNameBuf[len] = '\0'; | 
					
						
							|  |  |  |     strncat(LOCAL_FileNameBuf, "PrologCommons", YAP_FILENAME_MAX); | 
					
						
							|  |  |  |     if (is_directory(LOCAL_FileNameBuf)) { | 
					
						
							|  |  |  |       if (! Yap_unify( tcommons, | 
					
						
							|  |  |  |                        MkAtomTerm(Yap_LookupAtom(LOCAL_FileNameBuf))) ) | 
					
						
							|  |  |  |         return FALSE; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2014-11-28 03:21:32 +00:00
										 |  |  |     commons_done = true; | 
					
						
							| 
									
										
										
										
											2014-11-28 02:30:58 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (dir_done && commons_done) | 
					
						
							|  |  |  |     return TRUE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-28 02:30:58 +00:00
										 |  |  | #if __WINDOWS__
 | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     size_t buflen; | 
					
						
							|  |  |  |     char *pt; | 
					
						
							|  |  |  |     /* couldn't find it where it was supposed to be,
 | 
					
						
							|  |  |  |        let's try using the executable */ | 
					
						
							|  |  |  |     if (!GetModuleFileName( NULL, LOCAL_FileNameBuf, YAP_FILENAME_MAX)) { | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  |       Yap_WinError( "could not find executable name" ); | 
					
						
							| 
									
										
										
										
											2014-11-28 02:30:58 +00:00
										 |  |  |       /* do nothing */ | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     buflen = strlen(LOCAL_FileNameBuf); | 
					
						
							|  |  |  |     pt = LOCAL_FileNameBuf+buflen; | 
					
						
							|  |  |  |     while (*--pt != '\\') { | 
					
						
							|  |  |  |       /* skip executable */ | 
					
						
							|  |  |  |       if (pt == LOCAL_FileNameBuf) { | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |         Yap_FileError(OPERATING_SYSTEM_ERROR, TermNil, "could not find executable name"); | 
					
						
							| 
									
										
										
										
											2014-11-28 02:30:58 +00:00
										 |  |  |         /* do nothing */ | 
					
						
							|  |  |  |         return FALSE; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     while (*--pt != '\\') { | 
					
						
							|  |  |  |       /* skip parent directory "bin\\" */ | 
					
						
							|  |  |  |       if (pt == LOCAL_FileNameBuf) { | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  |         Yap_FileError(OPERATING_SYSTEM_ERROR, TermNil, "could not find executable name"); | 
					
						
							| 
									
										
										
										
											2014-11-28 02:30:58 +00:00
										 |  |  |         /* do nothing */ | 
					
						
							|  |  |  |         return FALSE; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     /* now, this is a possible location for the ROOT_DIR, let's look for a share directory here */ | 
					
						
							|  |  |  |     pt[1] = '\0'; | 
					
						
							|  |  |  |     /* grosse */ | 
					
						
							|  |  |  |     strncat(LOCAL_FileNameBuf,"lib\\Yap",YAP_FILENAME_MAX); | 
					
						
							|  |  |  |     libdir = Yap_AllocCodeSpace(strlen(LOCAL_FileNameBuf)+1); | 
					
						
							|  |  |  |     strncpy(libdir, LOCAL_FileNameBuf, strlen(LOCAL_FileNameBuf)+1); | 
					
						
							|  |  |  |     pt[1] = '\0'; | 
					
						
							|  |  |  |     strncat(LOCAL_FileNameBuf,"share",YAP_FILENAME_MAX); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   strncat(LOCAL_FileNameBuf,"\\", YAP_FILENAME_MAX); | 
					
						
							|  |  |  |   len = strlen(LOCAL_FileNameBuf); | 
					
						
							|  |  |  |   strncat(LOCAL_FileNameBuf, "Yap", YAP_FILENAME_MAX); | 
					
						
							|  |  |  |   if (!dir_done && is_directory(LOCAL_FileNameBuf)) { | 
					
						
							|  |  |  |     if (! Yap_unify( tlib, | 
					
						
							|  |  |  |                      MkAtomTerm(Yap_LookupAtom(LOCAL_FileNameBuf))) ) | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2014-11-28 03:21:32 +00:00
										 |  |  |   dir_done = true; | 
					
						
							| 
									
										
										
										
											2014-11-28 02:30:58 +00:00
										 |  |  |   LOCAL_FileNameBuf[len] = '\0'; | 
					
						
							|  |  |  |   strncat(LOCAL_FileNameBuf, "PrologCommons", YAP_FILENAME_MAX); | 
					
						
							|  |  |  |   if (!commons_done && is_directory(LOCAL_FileNameBuf)) { | 
					
						
							|  |  |  |     if (! Yap_unify( tcommons, | 
					
						
							|  |  |  |                      MkAtomTerm(Yap_LookupAtom(LOCAL_FileNameBuf))) ) | 
					
						
							| 
									
										
										
										
											2014-11-09 12:06:40 +00:00
										 |  |  |       return FALSE; | 
					
						
							| 
									
										
										
										
											2014-03-04 12:02:26 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2014-11-28 03:21:32 +00:00
										 |  |  |   commons_done = true; | 
					
						
							| 
									
										
										
										
											2014-11-28 02:30:58 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  |   return dir_done && commons_done; | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-28 02:30:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-05 07:45:36 +00:00
										 |  |  | static Int | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  | libraries_directories( USES_REGS1 ) | 
					
						
							| 
									
										
										
										
											2014-11-09 12:06:40 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2014-11-28 03:21:32 +00:00
										 |  |  |   return initSysPath( ARG1, ARG2 , false, false ); | 
					
						
							| 
									
										
										
										
											2014-11-09 12:06:40 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-28 02:30:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-09 12:06:40 +00:00
										 |  |  | static Int | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  | system_library( USES_REGS1 ) | 
					
						
							| 
									
										
										
										
											2014-11-09 12:06:40 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2014-11-28 03:21:32 +00:00
										 |  |  |   return initSysPath( ARG1, MkVarTerm(), false, true ); | 
					
						
							| 
									
										
										
										
											2014-11-05 07:45:36 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static Int | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  | commons_library( USES_REGS1 ) | 
					
						
							| 
									
										
										
										
											2014-11-05 07:45:36 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2014-11-28 03:21:32 +00:00
										 |  |  |   return initSysPath( MkVarTerm(), ARG1, true, false ); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static Int | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | p_dir_sp ( USES_REGS1 ) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  | #ifdef MAC
 | 
					
						
							|  |  |  |   Term t = MkIntTerm(':'); | 
					
						
							| 
									
										
										
										
											2011-03-22 11:07:17 +00:00
										 |  |  |   Term t2 = MkIntTerm('/'); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #elif ATARI || _MSC_VER || defined(__MINGW32__)
 | 
					
						
							|  |  |  |   Term t = MkIntTerm('\\'); | 
					
						
							| 
									
										
										
										
											2011-03-22 11:07:17 +00:00
										 |  |  |   Term t2 = MkIntTerm('/'); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  |   Term t = MkIntTerm('/'); | 
					
						
							| 
									
										
										
										
											2011-03-22 11:07:17 +00:00
										 |  |  |   Term t2 = MkIntTerm('/'); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-22 11:07:17 +00:00
										 |  |  |   return Yap_unify_constant(ARG1,t) || Yap_unify_constant(ARG1,t2) ; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-25 16:40:36 +01:00
										 |  |  | void | 
					
						
							|  |  |  | Yap_InitPageSize(void) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  | #ifdef _WIN32
 | 
					
						
							|  |  |  |   SYSTEM_INFO si; | 
					
						
							|  |  |  |   GetSystemInfo(&si); | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   Yap_page_size = si.dwPageSize; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #elif HAVE_UNISTD_H
 | 
					
						
							| 
									
										
										
										
											2010-10-27 10:11:19 +01:00
										 |  |  | #if defined(__FreeBSD__) || defined(__DragonFly__)
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   Yap_page_size = getpagesize(); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #elif defined(_AIX)
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   Yap_page_size = sysconf(_SC_PAGE_SIZE); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #elif !defined(_SC_PAGESIZE)
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   Yap_page_size = getpagesize(); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   Yap_page_size = sysconf(_SC_PAGESIZE); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   bla bla | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef SIMICS
 | 
					
						
							|  |  |  | #ifdef HAVE_GETRUSAGE
 | 
					
						
							|  |  |  | #undef HAVE_GETRUSAGE
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef HAVE_TIMES
 | 
					
						
							|  |  |  | #undef HAVE_TIMES
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #endif /* SIMICS */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef _WIN32
 | 
					
						
							|  |  |  | #if HAVE_GETRUSAGE
 | 
					
						
							|  |  |  | #undef HAVE_GETRUSAGE
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if HAVE_GETRUSAGE
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if HAVE_SYS_TIMES_H
 | 
					
						
							|  |  |  | #include <sys/times.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_SYS_RESOURCE_H
 | 
					
						
							|  |  |  | #include <sys/resource.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-03-02 16:44:58 +00:00
										 |  |  | #if THREADS
 | 
					
						
							| 
									
										
										
										
											2011-05-09 19:55:06 +01:00
										 |  |  | #define StartOfTimes (*(LOCAL_ThreadHandle.start_of_timesp))
 | 
					
						
							|  |  |  | #define last_time    (*(LOCAL_ThreadHandle.last_timep))
 | 
					
						
							| 
									
										
										
										
											2008-02-12 21:50:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-11 22:07:10 +00:00
										 |  |  | #define StartOfTimes_sys (*(LOCAL_ThreadHandle.start_of_times_sysp))
 | 
					
						
							|  |  |  | #define last_time_sys    (*(LOCAL_ThreadHandle.last_time_sysp))
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-03-02 16:44:58 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | /* since the point YAP was started */ | 
					
						
							|  |  |  | static struct timeval StartOfTimes; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* since last call to runtime */ | 
					
						
							|  |  |  | static struct timeval last_time; | 
					
						
							| 
									
										
										
										
											2012-12-11 22:07:10 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* same for system time */ | 
					
						
							| 
									
										
										
										
											2009-02-09 21:56:40 +00:00
										 |  |  | static struct timeval last_time_sys; | 
					
						
							|  |  |  | static struct timeval StartOfTimes_sys; | 
					
						
							| 
									
										
										
										
											2012-12-11 22:07:10 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* store user time in this variable */ | 
					
						
							|  |  |  | static void | 
					
						
							| 
									
										
										
										
											2012-12-11 22:07:10 +00:00
										 |  |  | InitTime (int wid) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   struct rusage   rusage; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-03-02 16:44:58 +00:00
										 |  |  | #if THREADS
 | 
					
						
							| 
									
										
										
										
											2012-12-11 22:07:10 +00:00
										 |  |  |   REMOTE_ThreadHandle(wid).start_of_timesp = (struct timeval *)malloc(sizeof(struct timeval)); | 
					
						
							|  |  |  |   REMOTE_ThreadHandle(wid).last_timep = (struct timeval *)malloc(sizeof(struct timeval)); | 
					
						
							|  |  |  |   REMOTE_ThreadHandle(wid).start_of_times_sysp = (struct timeval *)malloc(sizeof(struct timeval)); | 
					
						
							|  |  |  |   REMOTE_ThreadHandle(wid).last_time_sysp = (struct timeval *)malloc(sizeof(struct timeval)); | 
					
						
							|  |  |  |   getrusage(RUSAGE_SELF, &rusage); | 
					
						
							|  |  |  |   (*REMOTE_ThreadHandle(wid).last_timep).tv_sec = | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  |     (*REMOTE_ThreadHandle(wid).start_of_timesp).tv_sec = | 
					
						
							| 
									
										
										
										
											2012-12-11 22:07:10 +00:00
										 |  |  |     rusage.ru_utime.tv_sec; | 
					
						
							|  |  |  |   (*REMOTE_ThreadHandle(wid).last_timep).tv_usec = | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  |     (*REMOTE_ThreadHandle(wid).start_of_timesp).tv_usec = | 
					
						
							| 
									
										
										
										
											2012-12-11 22:07:10 +00:00
										 |  |  |     rusage.ru_utime.tv_usec; | 
					
						
							|  |  |  |   (*REMOTE_ThreadHandle(wid).last_time_sysp).tv_sec = | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  |     (*REMOTE_ThreadHandle(wid).start_of_times_sysp).tv_sec = | 
					
						
							| 
									
										
										
										
											2012-12-11 22:07:10 +00:00
										 |  |  |     rusage.ru_stime.tv_sec; | 
					
						
							|  |  |  |   (*REMOTE_ThreadHandle(wid).last_time_sysp).tv_usec = | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  |     (*REMOTE_ThreadHandle(wid).start_of_times_sysp).tv_usec = | 
					
						
							| 
									
										
										
										
											2012-12-11 22:07:10 +00:00
										 |  |  |     rusage.ru_stime.tv_usec; | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   getrusage(RUSAGE_SELF, &rusage); | 
					
						
							| 
									
										
										
										
											2012-12-11 22:07:10 +00:00
										 |  |  |   last_time.tv_sec = | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  |     StartOfTimes.tv_sec = | 
					
						
							| 
									
										
										
										
											2012-12-11 22:07:10 +00:00
										 |  |  |     rusage.ru_utime.tv_sec; | 
					
						
							|  |  |  |   last_time.tv_usec = | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  |     StartOfTimes.tv_usec = | 
					
						
							| 
									
										
										
										
											2012-12-11 22:07:10 +00:00
										 |  |  |     rusage.ru_utime.tv_usec; | 
					
						
							|  |  |  |   last_time_sys.tv_sec = | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  |     StartOfTimes_sys.tv_sec = | 
					
						
							| 
									
										
										
										
											2012-12-11 22:07:10 +00:00
										 |  |  |     rusage.ru_stime.tv_sec; | 
					
						
							|  |  |  |   last_time_sys.tv_usec = | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  |     StartOfTimes_sys.tv_usec = | 
					
						
							|  |  |  |     rusage.ru_stime.tv_usec; | 
					
						
							| 
									
										
										
										
											2012-12-11 22:07:10 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-03-02 16:44:58 +00:00
										 |  |  | UInt | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | Yap_cputime ( void ) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     struct rusage   rusage; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   getrusage(RUSAGE_SELF, &rusage); | 
					
						
							|  |  |  |   return((rusage.ru_utime.tv_sec - StartOfTimes.tv_sec)) * 1000 + | 
					
						
							|  |  |  |     ((rusage.ru_utime.tv_usec - StartOfTimes.tv_usec) / 1000); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | void Yap_cputime_interval(Int *now,Int *interval) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     struct rusage   rusage; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   getrusage(RUSAGE_SELF, &rusage); | 
					
						
							|  |  |  |   *now = (rusage.ru_utime.tv_sec - StartOfTimes.tv_sec) * 1000 + | 
					
						
							|  |  |  |     (rusage.ru_utime.tv_usec - StartOfTimes.tv_usec) / 1000; | 
					
						
							|  |  |  |   *interval = (rusage.ru_utime.tv_sec - last_time.tv_sec) * 1000 + | 
					
						
							|  |  |  |     (rusage.ru_utime.tv_usec - last_time.tv_usec) / 1000; | 
					
						
							|  |  |  |   last_time.tv_usec = rusage.ru_utime.tv_usec; | 
					
						
							|  |  |  |   last_time.tv_sec = rusage.ru_utime.tv_sec; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-09 21:56:40 +00:00
										 |  |  | void Yap_systime_interval(Int *now,Int *interval) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-12-11 22:07:10 +00:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     struct rusage   rusage; | 
					
						
							| 
									
										
										
										
											2009-02-09 21:56:40 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   getrusage(RUSAGE_SELF, &rusage); | 
					
						
							|  |  |  |   *now = (rusage.ru_stime.tv_sec - StartOfTimes_sys.tv_sec) * 1000 + | 
					
						
							|  |  |  |     (rusage.ru_stime.tv_usec - StartOfTimes_sys.tv_usec) / 1000; | 
					
						
							|  |  |  |   *interval = (rusage.ru_stime.tv_sec - last_time_sys.tv_sec) * 1000 + | 
					
						
							|  |  |  |     (rusage.ru_stime.tv_usec - last_time_sys.tv_usec) / 1000; | 
					
						
							|  |  |  |   last_time_sys.tv_usec = rusage.ru_stime.tv_usec; | 
					
						
							|  |  |  |   last_time_sys.tv_sec = rusage.ru_stime.tv_sec; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #elif defined(_WIN32)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  | #ifdef __GNUC__
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* This is stolen from the Linux kernel.
 | 
					
						
							|  |  |  |    The problem is that mingw32 does not seem to have acces to div */ | 
					
						
							|  |  |  | #ifndef do_div
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | #define do_div(n,base) ({						\
 | 
					
						
							|  |  |  |       unsigned long __upper, __low, __high, __mod;			\ | 
					
						
							|  |  |  |       asm("":"=a" (__low), "=d" (__high):"A" (n));			\ | 
					
						
							|  |  |  |       __upper = __high;							\ | 
					
						
							|  |  |  |       if (__high) {							\ | 
					
						
							|  |  |  | 	__upper = __high % (base);					\ | 
					
						
							|  |  |  | 	__high = __high / (base);					\ | 
					
						
							|  |  |  |       }									\ | 
					
						
							|  |  |  |       asm("divl %2":"=a" (__low), "=d" (__mod):"rm" (base), "0" (__low), "1" (__upper)); \ | 
					
						
							|  |  |  |       asm("":"=A" (n):"a" (__low),"d" (__high));			\ | 
					
						
							|  |  |  |       __mod;								\ | 
					
						
							|  |  |  |     }) | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #include <time.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   static FILETIME StartOfTimes, last_time; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-09 21:56:40 +00:00
										 |  |  | static FILETIME StartOfTimes_sys, last_time_sys; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  | static clock_t TimesStartOfTimes, Times_last_time; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | /* store user time in this variable */ | 
					
						
							|  |  |  | static void | 
					
						
							| 
									
										
										
										
											2012-12-19 00:48:43 +00:00
										 |  |  | InitTime (int wid) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  |   HANDLE hProcess = GetCurrentProcess(); | 
					
						
							|  |  |  |   FILETIME CreationTime, ExitTime, KernelTime, UserTime; | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  |   if (!GetProcessTimes(hProcess, &CreationTime, &ExitTime, &KernelTime, &UserTime)) { | 
					
						
							|  |  |  |     /* WIN98 */ | 
					
						
							|  |  |  |     clock_t t; | 
					
						
							|  |  |  |     t = clock (); | 
					
						
							|  |  |  |     Times_last_time = TimesStartOfTimes = t; | 
					
						
							|  |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2012-12-19 00:48:43 +00:00
										 |  |  | #if THREADS
 | 
					
						
							| 
									
										
										
										
											2012-12-20 21:13:20 +00:00
										 |  |  |     REMOTE_ThreadHandle(wid).start_of_timesp = (struct _FILETIME *)malloc(sizeof(FILETIME)); | 
					
						
							|  |  |  |     REMOTE_ThreadHandle(wid).last_timep = (struct _FILETIME *)malloc(sizeof(FILETIME)); | 
					
						
							|  |  |  |     REMOTE_ThreadHandle(wid).start_of_times_sysp = (struct _FILETIME *)malloc(sizeof(FILETIME)); | 
					
						
							|  |  |  |     REMOTE_ThreadHandle(wid).last_time_sysp = (struct _FILETIME *)malloc(sizeof(FILETIME)); | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  |     (*REMOTE_ThreadHandle(wid).last_timep).dwLowDateTime = | 
					
						
							| 
									
										
										
										
											2012-12-20 21:13:20 +00:00
										 |  |  |       UserTime.dwLowDateTime; | 
					
						
							| 
									
										
										
										
											2012-12-11 22:07:10 +00:00
										 |  |  |     (*REMOTE_ThreadHandle(wid).last_timep).dwHighDateTime = | 
					
						
							|  |  |  |       UserTime.dwHighDateTime; | 
					
						
							|  |  |  |     (*REMOTE_ThreadHandle(wid).start_of_timesp).dwLowDateTime = | 
					
						
							|  |  |  |       UserTime.dwLowDateTime; | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  |     (*REMOTE_ThreadHandle(wid).start_of_timesp).dwHighDateTime = | 
					
						
							| 
									
										
										
										
											2012-12-11 22:07:10 +00:00
										 |  |  |       UserTime.dwHighDateTime; | 
					
						
							|  |  |  |     (*REMOTE_ThreadHandle(wid).last_time_sysp).dwLowDateTime = | 
					
						
							|  |  |  |       KernelTime.dwLowDateTime; | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  |     (*REMOTE_ThreadHandle(wid).last_time_sysp).dwHighDateTime = | 
					
						
							| 
									
										
										
										
											2012-12-11 22:07:10 +00:00
										 |  |  |       KernelTime.dwHighDateTime; | 
					
						
							| 
									
										
										
										
											2012-12-19 00:48:43 +00:00
										 |  |  |     (*REMOTE_ThreadHandle(wid).start_of_times_sysp).dwLowDateTime = | 
					
						
							| 
									
										
										
										
											2012-12-11 22:07:10 +00:00
										 |  |  |       KernelTime.dwLowDateTime; | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  |     (*REMOTE_ThreadHandle(wid).start_of_times_sysp).dwHighDateTime = | 
					
						
							| 
									
										
										
										
											2012-12-11 22:07:10 +00:00
										 |  |  |       KernelTime.dwHighDateTime; | 
					
						
							| 
									
										
										
										
											2012-12-19 00:48:43 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  |     last_time.dwLowDateTime = | 
					
						
							| 
									
										
										
										
											2012-12-19 00:48:43 +00:00
										 |  |  |       UserTime.dwLowDateTime; | 
					
						
							|  |  |  |     last_time.dwHighDateTime = | 
					
						
							|  |  |  |       UserTime.dwHighDateTime; | 
					
						
							|  |  |  |     StartOfTimes.dwLowDateTime = | 
					
						
							|  |  |  |       UserTime.dwLowDateTime; | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  |     StartOfTimes.dwHighDateTime = | 
					
						
							| 
									
										
										
										
											2012-12-19 00:48:43 +00:00
										 |  |  |       UserTime.dwHighDateTime; | 
					
						
							|  |  |  |     last_time_sys.dwLowDateTime = | 
					
						
							|  |  |  |       KernelTime.dwLowDateTime; | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  |     last_time_sys.dwHighDateTime = | 
					
						
							| 
									
										
										
										
											2012-12-19 00:48:43 +00:00
										 |  |  |       KernelTime.dwHighDateTime; | 
					
						
							|  |  |  |     StartOfTimes_sys.dwLowDateTime = | 
					
						
							|  |  |  |       KernelTime.dwLowDateTime; | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  |     StartOfTimes_sys.dwHighDateTime = | 
					
						
							| 
									
										
										
										
											2012-12-19 00:48:43 +00:00
										 |  |  |       KernelTime.dwHighDateTime; | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-05-26 08:19:33 +00:00
										 |  |  | #ifdef __GNUC__
 | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  | static unsigned long long int | 
					
						
							| 
									
										
										
										
											2007-05-26 08:19:33 +00:00
										 |  |  | sub_utime(FILETIME t1, FILETIME t2) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   ULARGE_INTEGER u[2]; | 
					
						
							|  |  |  |   memcpy((void *)u,(void *)&t1,sizeof(FILETIME)); | 
					
						
							|  |  |  |   memcpy((void *)(u+1),(void *)&t2,sizeof(FILETIME)); | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  |   return | 
					
						
							| 
									
										
										
										
											2007-05-26 08:19:33 +00:00
										 |  |  |     u[0].QuadPart - u[1].QuadPart; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-03-02 16:44:58 +00:00
										 |  |  | UInt | 
					
						
							| 
									
										
										
										
											2012-06-29 15:37:11 -05:00
										 |  |  | Yap_cputime ( void ) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  |   HANDLE hProcess = GetCurrentProcess(); | 
					
						
							|  |  |  |   FILETIME CreationTime, ExitTime, KernelTime, UserTime; | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  |   if (!GetProcessTimes(hProcess, &CreationTime, &ExitTime, &KernelTime, &UserTime)) { | 
					
						
							|  |  |  |     clock_t t; | 
					
						
							|  |  |  |     t = clock (); | 
					
						
							|  |  |  |     return(((t - TimesStartOfTimes)*1000) / CLOCKS_PER_SEC); | 
					
						
							|  |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  | #ifdef __GNUC__
 | 
					
						
							|  |  |  |     unsigned long long int t = | 
					
						
							| 
									
										
										
										
											2007-05-26 08:19:33 +00:00
										 |  |  |       sub_utime(UserTime,StartOfTimes); | 
					
						
							| 
									
										
										
										
											2002-01-17 17:16:22 +00:00
										 |  |  |     do_div(t,10000); | 
					
						
							|  |  |  |     return((Int)t); | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef _MSC_VER
 | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  |     __int64 t = *(__int64 *)&UserTime - *(__int64 *)&StartOfTimes; | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  |     return((Int)(t/10000)); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | void Yap_cputime_interval(Int *now,Int *interval) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  |   HANDLE hProcess = GetCurrentProcess(); | 
					
						
							|  |  |  |   FILETIME CreationTime, ExitTime, KernelTime, UserTime; | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  |   if (!GetProcessTimes(hProcess, &CreationTime, &ExitTime, &KernelTime, &UserTime)) { | 
					
						
							|  |  |  |     clock_t t; | 
					
						
							|  |  |  |     t = clock (); | 
					
						
							|  |  |  |     *now = ((t - TimesStartOfTimes)*1000) / CLOCKS_PER_SEC; | 
					
						
							|  |  |  |     *interval = (t - Times_last_time) * 1000 / CLOCKS_PER_SEC; | 
					
						
							|  |  |  |     Times_last_time = t; | 
					
						
							|  |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  | #ifdef __GNUC__
 | 
					
						
							|  |  |  |     unsigned long long int t1 = | 
					
						
							| 
									
										
										
										
											2007-05-26 08:19:33 +00:00
										 |  |  |       sub_utime(UserTime, StartOfTimes); | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  |     unsigned long long int t2 = | 
					
						
							| 
									
										
										
										
											2007-05-26 08:19:33 +00:00
										 |  |  |       sub_utime(UserTime, last_time); | 
					
						
							| 
									
										
										
										
											2002-01-17 17:16:22 +00:00
										 |  |  |     do_div(t1,10000); | 
					
						
							|  |  |  |     *now = (Int)t1; | 
					
						
							|  |  |  |     do_div(t2,10000); | 
					
						
							|  |  |  |     *interval = (Int)t2; | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef _MSC_VER
 | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  |     __int64 t1 = *(__int64 *)&UserTime - *(__int64 *)&StartOfTimes; | 
					
						
							|  |  |  |     __int64 t2 = *(__int64 *)&UserTime - *(__int64 *)&last_time; | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  |     *now = (Int)(t1/10000); | 
					
						
							|  |  |  |     *interval = (Int)(t2/10000); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |     last_time.dwLowDateTime = UserTime.dwLowDateTime; | 
					
						
							|  |  |  |     last_time.dwHighDateTime = UserTime.dwHighDateTime; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-09 21:56:40 +00:00
										 |  |  | void Yap_systime_interval(Int *now,Int *interval) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   HANDLE hProcess = GetCurrentProcess(); | 
					
						
							|  |  |  |   FILETIME CreationTime, ExitTime, KernelTime, UserTime; | 
					
						
							|  |  |  |   if (!GetProcessTimes(hProcess, &CreationTime, &ExitTime, &KernelTime, &UserTime)) { | 
					
						
							|  |  |  |     *now = *interval = 0; /* not available */ | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  | #ifdef __GNUC__
 | 
					
						
							|  |  |  |     unsigned long long int t1 = | 
					
						
							|  |  |  |       sub_utime(KernelTime, StartOfTimes_sys); | 
					
						
							|  |  |  |     unsigned long long int t2 = | 
					
						
							|  |  |  |       sub_utime(KernelTime, last_time_sys); | 
					
						
							|  |  |  |     do_div(t1,10000); | 
					
						
							|  |  |  |     *now = (Int)t1; | 
					
						
							|  |  |  |     do_div(t2,10000); | 
					
						
							|  |  |  |     *interval = (Int)t2; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef _MSC_VER
 | 
					
						
							|  |  |  |     __int64 t1 = *(__int64 *)&KernelTime - *(__int64 *)&StartOfTimes_sys; | 
					
						
							|  |  |  |     __int64 t2 = *(__int64 *)&KernelTime - *(__int64 *)&last_time_sys; | 
					
						
							|  |  |  |     *now = (Int)(t1/10000); | 
					
						
							|  |  |  |     *interval = (Int)(t2/10000); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |     last_time_sys.dwLowDateTime = KernelTime.dwLowDateTime; | 
					
						
							|  |  |  |     last_time_sys.dwHighDateTime = KernelTime.dwHighDateTime; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #elif HAVE_TIMES
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if defined(_WIN32)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <time.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define TicksPerSec     CLOCKS_PER_SEC
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if HAVE_SYS_TIMES_H
 | 
					
						
							|  |  |  | #include <sys/times.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-09-24 18:07:16 +00:00
										 |  |  | #if defined(__sun__) && (defined(__svr4__) || defined(__SVR4))
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #if HAVE_LIMITS_H
 | 
					
						
							|  |  |  | #include <limits.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define TicksPerSec	CLK_TCK
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-27 10:11:19 +01:00
										 |  |  | #if defined(__alpha) || defined(__FreeBSD__) || defined(__linux__) || defined(__DragonFly__)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #if HAVE_TIME_H
 | 
					
						
							|  |  |  | #include <time.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define TicksPerSec	sysconf(_SC_CLK_TCK)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if !TMS_IN_SYS_TIME
 | 
					
						
							|  |  |  | #if HAVE_SYS_TIMES_H
 | 
					
						
							|  |  |  | #include <sys/times.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static clock_t StartOfTimes, last_time; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-09 21:56:40 +00:00
										 |  |  | static clock_t StartOfTimes_sys, last_time_sys; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | /* store user time in this variable */ | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | InitTime (void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   struct tms t; | 
					
						
							|  |  |  |   times (&t); | 
					
						
							| 
									
										
										
										
											2012-12-11 22:07:10 +00:00
										 |  |  |   (*REMOTE_ThreadHandle(wid).last_timep) = StartOfTimes = t.tms_utime; | 
					
						
							| 
									
										
										
										
											2009-02-09 21:56:40 +00:00
										 |  |  |   last_time_sys = StartOfTimes_sys = t.tms_stime; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-03-02 16:44:58 +00:00
										 |  |  | UInt | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_cputime (void) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   struct tms t; | 
					
						
							|  |  |  |   times(&t); | 
					
						
							|  |  |  |   return((t.tms_utime - StartOfTimes)*1000 / TicksPerSec); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | void Yap_cputime_interval(Int *now,Int *interval) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   struct tms t; | 
					
						
							|  |  |  |   times (&t); | 
					
						
							|  |  |  |   *now = ((t.tms_utime - StartOfTimes)*1000) / TicksPerSec; | 
					
						
							|  |  |  |   *interval = (t.tms_utime - last_time) * 1000 / TicksPerSec; | 
					
						
							| 
									
										
										
										
											2001-04-26 17:53:37 +00:00
										 |  |  |   last_time = t.tms_utime; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-09 21:56:40 +00:00
										 |  |  | void Yap_systime_interval(Int *now,Int *interval) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   struct tms t; | 
					
						
							|  |  |  |   times (&t); | 
					
						
							|  |  |  |   *now = ((t.tms_stime - StartOfTimes_sys)*1000) / TicksPerSec; | 
					
						
							|  |  |  |   *interval = (t.tms_stime - last_time_sys) * 1000 / TicksPerSec; | 
					
						
							|  |  |  |   last_time_sys = t.tms_stime; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else /* HAVE_TIMES */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef SIMICS
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <sys/time.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* since the point YAP was started */ | 
					
						
							|  |  |  | static struct timeval StartOfTimes; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* since last call to runtime */ | 
					
						
							|  |  |  | static struct timeval last_time; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* store user time in this variable */ | 
					
						
							|  |  |  | static void | 
					
						
							| 
									
										
										
										
											2012-12-11 22:07:10 +00:00
										 |  |  | InitTime (int wid) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   struct timeval   tp; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   gettimeofday(&tp,NULL); | 
					
						
							| 
									
										
										
										
											2012-12-11 22:07:10 +00:00
										 |  |  |   (*REMOTE_ThreadHandle(wid).last_timep).tv_sec = (*REMOTE_ThreadHandle.start_of_timesp(wid)).tv_sec = tp.tv_sec; | 
					
						
							|  |  |  |   (*REMOTE_ThreadHandle(wid).last_timep).tv_usec = (*REMOTE_ThreadHandle.start_of_timesp(wid)).tv_usec = tp.tv_usec; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-03-02 16:44:58 +00:00
										 |  |  | UInt | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_cputime (void) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   struct timeval   tp; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   gettimeofday(&tp,NULL); | 
					
						
							|  |  |  |   if (StartOfTimes.tv_usec > tp.tv_usec) | 
					
						
							|  |  |  |     return((tp.tv_sec - StartOfTimes.tv_sec - 1) * 1000 + | 
					
						
							|  |  |  | 	   (StartOfTimes.tv_usec - tp.tv_usec) /1000); | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     return((tp.tv_sec - StartOfTimes.tv_sec)) * 1000 + | 
					
						
							|  |  |  |       ((tp.tv_usec - StartOfTimes.tv_usec) / 1000); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | void Yap_cputime_interval(Int *now,Int *interval) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   struct timeval   tp; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   gettimeofday(&tp,NULL); | 
					
						
							|  |  |  |   *now = (tp.tv_sec - StartOfTimes.tv_sec) * 1000 + | 
					
						
							|  |  |  |     (tp.tv_usec - StartOfTimes.tv_usec) / 1000; | 
					
						
							|  |  |  |   *interval = (tp.tv_sec - last_time.tv_sec) * 1000 + | 
					
						
							|  |  |  |     (tp.tv_usec - last_time.tv_usec) / 1000; | 
					
						
							|  |  |  |   last_time.tv_usec = tp.tv_usec; | 
					
						
							|  |  |  |   last_time.tv_sec = tp.tv_sec; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-09 21:56:40 +00:00
										 |  |  | void Yap_systime_interval(Int *now,Int *interval) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   *now =  *interval = 0; /* not available */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif /* SIMICS */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef COMMENTED_OUT
 | 
					
						
							|  |  |  | /* This code is not working properly. I left it here to help future ports */ | 
					
						
							|  |  |  | #ifdef MPW
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <files.h>
 | 
					
						
							|  |  |  | #include <Events.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define TicksPerSec 60.0
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static double | 
					
						
							|  |  |  | real_cputime () | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (((double) TickCount ()) / TicksPerSec); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* MPW */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef LATTICE
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "osbind.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static long *ptime; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | gettime () | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   *ptime = *(long *) 0x462; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static double | 
					
						
							|  |  |  | real_cputime () | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   long thetime; | 
					
						
							|  |  |  |   ptime = &thetime; | 
					
						
							|  |  |  |   xbios (38, gettime); | 
					
						
							|  |  |  |   return (((double) thetime) / (Getrez () == 2 ? 70 : 60)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* LATTICE */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef M_WILLIAMS
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <osbind.h>
 | 
					
						
							|  |  |  | #include <xbios.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static long *ptime; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static long | 
					
						
							|  |  |  | readtime () | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (*((long *) 0x4ba)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static double | 
					
						
							|  |  |  | real_cputime () | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   long time; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   time = Supexec (readtime); | 
					
						
							|  |  |  |   return (time / 200.0); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* M_WILLIAMS */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef LIGHT
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #undef FALSE
 | 
					
						
							|  |  |  | #undef TRUE
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <FileMgr.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define TicksPerSec 60.0
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static double | 
					
						
							|  |  |  | real_cputime () | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (((double) TickCount ()) / TicksPerSec); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* LIGHT */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* COMMENTED_OUT */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* HAVE_GETRUSAGE */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if HAVE_GETHRTIME
 | 
					
						
							| 
									
										
										
										
											2002-06-13 18:24:04 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #if HAVE_TIME_H
 | 
					
						
							|  |  |  | #include <time.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | /* since the point YAP was started */ | 
					
						
							|  |  |  | static hrtime_t StartOfWTimes; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* since last call to walltime */ | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  | #define  LastWtime (*(hrtime_t *)ALIGN_BY_TYPE(GLOBAL_LastWtimePtr,hrtime_t))
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | InitWTime (void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   StartOfWTimes = gethrtime(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | InitLastWtime(void) { | 
					
						
							|  |  |  |   /* ask for twice the space in order to guarantee alignment */ | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  |   GLOBAL_LastWtimePtr = (void *)Yap_AllocCodeSpace(2*sizeof(hrtime_t)); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   LastWtime = StartOfWTimes; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Int | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_walltime (void) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   hrtime_t tp = gethrtime(); | 
					
						
							|  |  |  |   /* return time in milliseconds */ | 
					
						
							|  |  |  |   return((Int)((tp-StartOfWTimes)/((hrtime_t)1000000))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | void Yap_walltime_interval(Int *now,Int *interval) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   hrtime_t tp = gethrtime(); | 
					
						
							|  |  |  |   /* return time in milliseconds */ | 
					
						
							|  |  |  |   *now = (Int)((tp-StartOfWTimes)/((hrtime_t)1000000)); | 
					
						
							|  |  |  |   *interval = (Int)((tp-LastWtime)/((hrtime_t)1000000)); | 
					
						
							|  |  |  |   LastWtime = tp; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #elif HAVE_GETTIMEOFDAY
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* since the point YAP was started */ | 
					
						
							|  |  |  | static struct timeval StartOfWTimes; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* since last call to walltime */ | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  | #define LastWtime (*(struct timeval *)GLOBAL_LastWtimePtr)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* store user time in this variable */ | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | InitWTime (void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   gettimeofday(&StartOfWTimes,NULL); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | InitLastWtime(void) { | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  |   GLOBAL_LastWtimePtr = (void *)Yap_AllocCodeSpace(sizeof(struct timeval)); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   LastWtime.tv_usec = StartOfWTimes.tv_usec; | 
					
						
							|  |  |  |   LastWtime.tv_sec = StartOfWTimes.tv_sec; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Int | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_walltime (void) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   struct timeval   tp; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   gettimeofday(&tp,NULL); | 
					
						
							|  |  |  |   if (StartOfWTimes.tv_usec > tp.tv_usec) | 
					
						
							|  |  |  |     return((tp.tv_sec - StartOfWTimes.tv_sec - 1) * 1000 + | 
					
						
							|  |  |  | 	   (StartOfWTimes.tv_usec - tp.tv_usec) /1000); | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     return((tp.tv_sec - StartOfWTimes.tv_sec)) * 1000 + | 
					
						
							|  |  |  |       ((tp.tv_usec - LastWtime.tv_usec) / 1000); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | void Yap_walltime_interval(Int *now,Int *interval) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   struct timeval   tp; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   gettimeofday(&tp,NULL); | 
					
						
							|  |  |  |   *now = (tp.tv_sec - StartOfWTimes.tv_sec) * 1000 + | 
					
						
							|  |  |  |     (tp.tv_usec - StartOfWTimes.tv_usec) / 1000; | 
					
						
							|  |  |  |   *interval = (tp.tv_sec - LastWtime.tv_sec) * 1000 + | 
					
						
							|  |  |  |     (tp.tv_usec - LastWtime.tv_usec) / 1000; | 
					
						
							|  |  |  |   LastWtime.tv_usec = tp.tv_usec; | 
					
						
							|  |  |  |   LastWtime.tv_sec = tp.tv_sec; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #elif defined(_WIN32)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <sys/timeb.h>
 | 
					
						
							|  |  |  | #include <time.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* since the point YAP was started */ | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  | static struct _timeb StartOfWTimes; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* since last call to walltime */ | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  | #define LastWtime (*(struct timeb *)GLOBAL_LastWtimePtr)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* store user time in this variable */ | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | InitWTime (void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  |   _ftime(&StartOfWTimes); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | InitLastWtime(void) { | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  |   GLOBAL_LastWtimePtr = (void *)Yap_AllocCodeSpace(sizeof(struct timeb)); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   LastWtime.time = StartOfWTimes.time; | 
					
						
							|  |  |  |   LastWtime.millitm = StartOfWTimes.millitm; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Int | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_walltime (void) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  |   struct _timeb   tp; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  |   _ftime(&tp); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   if (StartOfWTimes.millitm > tp.millitm) | 
					
						
							|  |  |  |     return((tp.time - StartOfWTimes.time - 1) * 1000 + | 
					
						
							|  |  |  | 	   (StartOfWTimes.millitm - tp.millitm)); | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     return((tp.time - StartOfWTimes.time)) * 1000 + | 
					
						
							|  |  |  |       ((tp.millitm - LastWtime.millitm) / 1000); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | void Yap_walltime_interval(Int *now,Int *interval) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  |   struct _timeb   tp; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  |   _ftime(&tp); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   *now = (tp.time - StartOfWTimes.time) * 1000 + | 
					
						
							|  |  |  |     (tp.millitm - StartOfWTimes.millitm); | 
					
						
							|  |  |  |   *interval = (tp.time - LastWtime.time) * 1000 + | 
					
						
							|  |  |  |     (tp.millitm - LastWtime.millitm) ; | 
					
						
							|  |  |  |   LastWtime.millitm = tp.millitm; | 
					
						
							|  |  |  |   LastWtime.time = tp.time; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #elif HAVE_TIMES
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static clock_t StartOfWTimes; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  | #define LastWtime (*(clock_t *)GLOBAL_LastWtimePtr)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* store user time in this variable */ | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | InitWTime (void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   StartOfWTimes = times(NULL); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | InitLastWtime(void) { | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  |   GLOBAL_LastWtimePtr = (void *)Yap_AllocCodeSpace(sizeof(clock_t)); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   LastWtime = StartOfWTimes; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Int | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_walltime (void) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   clock_t t; | 
					
						
							|  |  |  |   t = times(NULL); | 
					
						
							|  |  |  |   return ((t - StartOfWTimes)*1000 / TicksPerSec)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | void Yap_walltime_interval(Int *now,Int *interval) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   clock_t t; | 
					
						
							|  |  |  |   t = times(NULL); | 
					
						
							|  |  |  |   *now = ((t - StartOfWTimes)*1000) / TicksPerSec; | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  |   *interval = (t - GLOBAL_LastWtime) * 1000 / TicksPerSec; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* HAVE_TIMES */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if HAVE_TIME_H
 | 
					
						
							|  |  |  | #include <time.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | unsigned int current_seed; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | InitRandom (void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   current_seed = (unsigned int) time (NULL); | 
					
						
							| 
									
										
										
										
											2015-04-15 11:21:15 +01:00
										 |  |  | #if HAVE_SRAND48
 | 
					
						
							|  |  |  |   srand48 (current_seed); | 
					
						
							|  |  |  | #elif HAVE_SRANDOM
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   srandom (current_seed); | 
					
						
							| 
									
										
										
										
											2015-04-15 11:21:15 +01:00
										 |  |  | #elif HAVE_SRAND
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   srand (current_seed); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-25 17:15:04 -05:00
										 |  |  | extern int rand(void); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | double | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_random (void) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2015-04-15 11:21:15 +01:00
										 |  |  | #if HAVE_DRAND48
 | 
					
						
							|  |  |  |   return drand48(); | 
					
						
							|  |  |  | #elif HAVE_RANDOM
 | 
					
						
							|  |  |  |   /*  extern long random (); */ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   return (((double) random ()) / 0x7fffffffL /* 2**31-1 */); | 
					
						
							|  |  |  | #elif HAVE_RAND
 | 
					
						
							|  |  |  |   return (((double) (rand ()) / RAND_MAX)); | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |   Yap_Error(SYSTEM_ERROR, TermNil, | 
					
						
							|  |  |  |             "random not available in this configuration"); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   return (0.0); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-28 01:12:51 +01:00
										 |  |  | #if HAVE_RANDOM
 | 
					
						
							|  |  |  | static Int | 
					
						
							|  |  |  | p_init_random_state ( USES_REGS1 ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   register Term t0 = Deref (ARG1); | 
					
						
							| 
									
										
										
										
											2014-06-14 10:27:39 +01:00
										 |  |  |   char *old, *new; | 
					
						
							| 
									
										
										
										
											2014-05-28 01:12:51 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |   if (IsVarTerm (t0)) { | 
					
						
							|  |  |  |     return(Yap_unify(ARG1,MkIntegerTerm((Int)current_seed))); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if(!IsNumTerm (t0)) | 
					
						
							|  |  |  |     return (FALSE); | 
					
						
							|  |  |  |   if (IsIntTerm (t0)) | 
					
						
							|  |  |  |     current_seed = (unsigned int) IntOfTerm (t0); | 
					
						
							|  |  |  |   else if (IsFloatTerm (t0)) | 
					
						
							|  |  |  |     current_seed  = (unsigned int) FloatOfTerm (t0); | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     current_seed  = (unsigned int) LongIntOfTerm (t0); | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-14 10:27:39 +01:00
										 |  |  |   new = (char *) malloc(256); | 
					
						
							| 
									
										
										
										
											2014-05-28 01:12:51 +01:00
										 |  |  |   old = initstate(random(), new, 256); | 
					
						
							|  |  |  |   return Yap_unify(ARG2, MkIntegerTerm((Int)old)) && | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     Yap_unify(ARG3, MkIntegerTerm((Int)new)); | 
					
						
							| 
									
										
										
										
											2014-05-28 01:12:51 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static Int | 
					
						
							|  |  |  | p_set_random_state ( USES_REGS1 ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   register Term t0 = Deref (ARG1); | 
					
						
							| 
									
										
										
										
											2014-05-28 01:54:28 +01:00
										 |  |  |   char *old, * new; | 
					
						
							| 
									
										
										
										
											2014-05-28 01:12:51 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |   if (IsVarTerm (t0)) { | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (IsIntegerTerm (t0)) | 
					
						
							|  |  |  |     new = (char *) IntegerOfTerm (t0); | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							| 
									
										
										
										
											2014-05-28 01:40:03 +01:00
										 |  |  |   old = setstate( new ); | 
					
						
							| 
									
										
										
										
											2014-05-28 01:12:51 +01:00
										 |  |  |   return Yap_unify(ARG2, MkIntegerTerm((Int)old)); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2014-05-28 01:54:28 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | static Int | 
					
						
							|  |  |  | p_release_random_state ( USES_REGS1 ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   register Term t0 = Deref (ARG1); | 
					
						
							|  |  |  |   char *old; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (IsVarTerm (t0)) { | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (IsIntegerTerm (t0)) | 
					
						
							|  |  |  |     old = (char *) IntegerOfTerm (t0); | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							|  |  |  |   free( old ); | 
					
						
							|  |  |  |   return TRUE; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2014-05-28 01:12:51 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | static Int | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  | Srandom ( USES_REGS1 ) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   register Term t0 = Deref (ARG1); | 
					
						
							|  |  |  |   if (IsVarTerm (t0)) { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     return(Yap_unify(ARG1,MkIntegerTerm((Int)current_seed))); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   if(!IsNumTerm (t0)) | 
					
						
							|  |  |  |     return (FALSE); | 
					
						
							|  |  |  |   if (IsIntTerm (t0)) | 
					
						
							|  |  |  |     current_seed = (unsigned int) IntOfTerm (t0); | 
					
						
							|  |  |  |   else if (IsFloatTerm (t0)) | 
					
						
							|  |  |  |     current_seed  = (unsigned int) FloatOfTerm (t0); | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     current_seed  = (unsigned int) LongIntOfTerm (t0); | 
					
						
							| 
									
										
										
										
											2015-04-15 11:21:15 +01:00
										 |  |  | #if HAVE_SRAND48  
 | 
					
						
							|  |  |  |   srand48(current_seed);   | 
					
						
							|  |  |  | #elif HAVE_SRANDOM  
 | 
					
						
							|  |  |  |   srandom(current_seed);   | 
					
						
							|  |  |  | #elif HAVE_SRAND
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   srand(current_seed); | 
					
						
							| 
									
										
										
										
											2002-08-18 23:18:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  |   return (TRUE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-15 23:47:29 +00:00
										 |  |  | #if HAVE_SIGNAL_H
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include <signal.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef MPW
 | 
					
						
							|  |  |  | #define signal	sigset
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef MSH
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define SIGFPE	SIGDIV
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-25 17:15:04 -05:00
										 |  |  | static void InitSignals(void); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #define PLSIG_PREPARED 0x01		/* signal is prepared */
 | 
					
						
							|  |  |  | #define PLSIG_THROW    0x02		/* throw signal(num, name) */
 | 
					
						
							|  |  |  | #define PLSIG_SYNC     0x04		/* call synchronously */
 | 
					
						
							|  |  |  | #define PLSIG_NOFRAME  0x08		/* Do not create a Prolog frame */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define SIG_PROLOG_OFFSET	32	/* Start of Prolog signals */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define SIG_EXCEPTION	  (SIG_PROLOG_OFFSET+0)
 | 
					
						
							|  |  |  | #ifdef O_ATOMGC
 | 
					
						
							|  |  |  | #define SIG_ATOM_GC	  (SIG_PROLOG_OFFSET+1)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #define SIG_GC		  (SIG_PROLOG_OFFSET+2)
 | 
					
						
							|  |  |  | #ifdef O_PLMT
 | 
					
						
							|  |  |  | #define SIG_THREAD_SIGNAL (SIG_PROLOG_OFFSET+3)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #define SIG_FREECLAUSES	  (SIG_PROLOG_OFFSET+4)
 | 
					
						
							|  |  |  | #define SIG_PLABORT	  (SIG_PROLOG_OFFSET+5)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static struct signame | 
					
						
							|  |  |  | { int 	      sig; | 
					
						
							|  |  |  |   const char *name; | 
					
						
							|  |  |  |   int	      flags; | 
					
						
							|  |  |  | } signames[] = | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   { | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #ifdef SIGHUP
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGHUP,	"hup",    0}, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGINT,	"int",    0}, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #ifdef SIGQUIT
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGQUIT,	"quit",   0}, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGILL,	"ill",    0}, | 
					
						
							|  |  |  |     { SIGABRT,	"abrt",   0}, | 
					
						
							| 
									
										
										
										
											2014-03-15 23:47:29 +00:00
										 |  |  | #if HAVE_SIGFPE
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGFPE,	"fpe",    PLSIG_THROW}, | 
					
						
							| 
									
										
										
										
											2014-03-15 23:47:29 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #ifdef SIGKILL
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGKILL,	"kill",   0}, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGSEGV,	"segv",   0}, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #ifdef SIGPIPE
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGPIPE,	"pipe",   0}, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef SIGALRM
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGALRM,	"alrm",   PLSIG_THROW}, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGTERM,	"term",   0}, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #ifdef SIGUSR1
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGUSR1,	"usr1",   0}, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef SIGUSR2
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGUSR2,	"usr2",   0}, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef SIGCHLD
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGCHLD,	"chld",   0}, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef SIGCONT
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGCONT,	"cont",   0}, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef SIGSTOP
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGSTOP,	"stop",   0}, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef SIGTSTP
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGTSTP,	"tstp",   0}, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef SIGTTIN
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGTTIN,	"ttin",   0}, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef SIGTTOU
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGTTOU,	"ttou",   0}, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef SIGTRAP
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGTRAP,	"trap",   0}, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef SIGBUS
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGBUS,	"bus",    0}, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef SIGSTKFLT
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGSTKFLT,	"stkflt", 0}, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef SIGURG
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGURG,	"urg",    0}, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef SIGIO
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGIO,	"io",     0}, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef SIGPOLL
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGPOLL,	"poll",   0}, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef SIGXCPU
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGXCPU,	"xcpu",   PLSIG_THROW}, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef SIGXFSZ
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGXFSZ,	"xfsz",   PLSIG_THROW}, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef SIGVTALRM
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGVTALRM,	"vtalrm", PLSIG_THROW}, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef SIGPROF
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGPROF,	"prof",   0}, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef SIGPWR
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIGPWR,	"pwr",    0}, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIG_EXCEPTION,     "prolog:exception",     0 }, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #ifdef SIG_ATOM_GC
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIG_ATOM_GC,   "prolog:atom_gc",       0 }, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIG_GC,	       "prolog:gc",	       0 }, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #ifdef SIG_THREAD_SIGNAL
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { SIG_THREAD_SIGNAL, "prolog:thread_signal", 0 }, | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { -1,		NULL,     0} | 
					
						
							|  |  |  |   }; | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* SWI emulation */ | 
					
						
							|  |  |  | int | 
					
						
							|  |  |  | Yap_signal_index(const char *name) | 
					
						
							|  |  |  | { struct signame *sn = signames; | 
					
						
							|  |  |  |   char tmp[12]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  |   if ( strncmp(name, "SIG", 3) == 0 && strlen(name) < 12 ) | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  |     { char *p = (char *)name+3, *q = tmp; | 
					
						
							|  |  |  |       while ((*q++ = tolower(*p++))) {}; | 
					
						
							|  |  |  |       name = tmp; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   for( ; sn->name; sn++ ) | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { if ( !strcmp(sn->name, name) ) | 
					
						
							|  |  |  | 	return sn->sig; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2010-06-17 08:20:34 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |   return -1; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #if HAVE_SIGINFO_H
 | 
					
						
							|  |  |  | #include <siginfo.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_SYS_UCONTEXT_H
 | 
					
						
							|  |  |  | #include <sys/ucontext.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-15 23:47:29 +00:00
										 |  |  | #if HAVE_SIGSEGV
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | SearchForTrailFault(void *ptr, int sure) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* If the TRAIL is very close to the top of mmaped allocked space,
 | 
					
						
							|  |  |  |      then we can try increasing the TR space and restarting the | 
					
						
							|  |  |  |      instruction. In the worst case, the system will | 
					
						
							|  |  |  |      crash again | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   */ | 
					
						
							| 
									
										
										
										
											2014-03-15 23:47:29 +00:00
										 |  |  | #if  OS_HANDLES_TR_OVERFLOW && !USE_SYSTEM_MALLOC
 | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  |   if ((ptr > (void *)LOCAL_TrailTop-1024  && | 
					
						
							| 
									
										
										
										
											2014-03-15 23:47:29 +00:00
										 |  |  |        TR < (tr_fr_ptr) LOCAL_TrailTop+(64*1024))) { | 
					
						
							|  |  |  |     if (!Yap_growtrail(64*1024, TRUE)) { | 
					
						
							|  |  |  |       Yap_Error(OUT_OF_TRAIL_ERROR, TermNil, "YAP failed to reserve %ld bytes in growtrail", K64); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     /* just in case, make sure the OS keeps the signal handler. */ | 
					
						
							|  |  |  |     /*    my_signal_info(SIGSEGV, HandleSIGSEGV); */ | 
					
						
							|  |  |  |   } else | 
					
						
							|  |  |  | #endif /* OS_HANDLES_TR_OVERFLOW */
 | 
					
						
							|  |  |  |     if (sure) | 
					
						
							|  |  |  |       Yap_Error(FATAL_ERROR, TermNil, | 
					
						
							|  |  |  | 		"tried to access illegal address %p!!!!", ptr); | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |       Yap_Error(FATAL_ERROR, TermNil, | 
					
						
							|  |  |  | 		"likely bug in YAP, segmentation violation"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* This routine believes there is a continuous space starting from the
 | 
					
						
							|  |  |  |    HeapBase and ending on TrailTop */ | 
					
						
							|  |  |  | static void | 
					
						
							| 
									
										
										
										
											2014-03-15 23:47:29 +00:00
										 |  |  | HandleSIGSEGV(int   sig,   void   *sipv, void *uap) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2014-03-16 00:52:43 +00:00
										 |  |  |   CACHE_REGS | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     void *ptr = TR; | 
					
						
							| 
									
										
										
										
											2014-03-15 23:47:29 +00:00
										 |  |  |   int sure = FALSE; | 
					
						
							|  |  |  |   if (LOCAL_PrologMode & ExtendStackMode) { | 
					
						
							|  |  |  |     Yap_Error(FATAL_ERROR, TermNil, "OS memory allocation crashed at address %p, bailing out\n",LOCAL_TrailTop); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | #if (defined(__svr4__) || defined(__SVR4))
 | 
					
						
							|  |  |  |   siginfo_t *sip = sipv; | 
					
						
							| 
									
										
										
										
											2005-02-08 04:05:39 +00:00
										 |  |  |   if ( | 
					
						
							|  |  |  |       sip->si_code != SI_NOINFO && | 
					
						
							| 
									
										
										
										
											2014-03-15 23:47:29 +00:00
										 |  |  |       sip->si_code == SEGV_MAPERR) { | 
					
						
							|  |  |  |     ptr = sip->si_addr; | 
					
						
							|  |  |  |     sure = TRUE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2014-03-15 23:47:29 +00:00
										 |  |  | #elif __linux__
 | 
					
						
							|  |  |  |   siginfo_t *sip = sipv; | 
					
						
							|  |  |  |   ptr = sip->si_addr; | 
					
						
							|  |  |  |   sure = TRUE; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |   SearchForTrailFault( ptr, sure ); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2014-03-15 23:47:29 +00:00
										 |  |  | #endif /* SIGSEGV */
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-15 11:06:07 +01:00
										 |  |  | yap_error_number | 
					
						
							|  |  |  | Yap_MathException__( USES_REGS1 ) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2014-10-24 15:18:32 +01:00
										 |  |  | #if HAVE_FETESTEXCEPT
 | 
					
						
							| 
									
										
										
										
											2014-10-15 11:06:07 +01:00
										 |  |  |   int raised; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-19 11:27:53 +01:00
										 |  |  |   // #pragma STDC FENV_ACCESS ON
 | 
					
						
							| 
									
										
										
										
											2014-10-15 11:06:07 +01:00
										 |  |  |   if ((raised = fetestexcept( FE_DIVBYZERO | FE_OVERFLOW | FE_UNDERFLOW)) ) { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     feclearexcept(FE_ALL_EXCEPT); | 
					
						
							|  |  |  |     if (raised & FE_OVERFLOW) { | 
					
						
							|  |  |  |       return  EVALUATION_ERROR_FLOAT_OVERFLOW; | 
					
						
							|  |  |  |     } else if (raised & FE_DIVBYZERO) { | 
					
						
							|  |  |  |       return  EVALUATION_ERROR_ZERO_DIVISOR; | 
					
						
							|  |  |  |     } else if (raised & FE_UNDERFLOW) { | 
					
						
							|  |  |  |       return  EVALUATION_ERROR_FLOAT_UNDERFLOW; | 
					
						
							|  |  |  |       //} else if (raised & (FE_INVALID|FE_INEXACT)) {
 | 
					
						
							|  |  |  |       //    return  EVALUATION_ERROR_UNDEFINED;
 | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       return  EVALUATION_ERROR_UNDEFINED; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2014-10-24 15:18:32 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2014-10-28 12:56:26 +00:00
										 |  |  | #elif _WIN32 && FALSE
 | 
					
						
							| 
									
										
										
										
											2014-10-24 15:18:32 +01:00
										 |  |  |   unsigned int raised; | 
					
						
							|  |  |  |   int err; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   // Show original FP control word and do calculation.
 | 
					
						
							|  |  |  |   err = _controlfp_s(&raised, 0, 0); | 
					
						
							|  |  |  |   if (err) { | 
					
						
							|  |  |  |     return  EVALUATION_ERROR_UNDEFINED; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (raised ) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     feclearexcept(FE_ALL_EXCEPT); | 
					
						
							|  |  |  |     if (raised & FE_OVERFLOW) { | 
					
						
							|  |  |  |       return  EVALUATION_ERROR_FLOAT_OVERFLOW; | 
					
						
							|  |  |  |     } else if (raised & FE_DIVBYZERO) { | 
					
						
							|  |  |  |       return  EVALUATION_ERROR_ZERO_DIVISOR; | 
					
						
							|  |  |  |     } else if (raised & FE_UNDERFLOW) { | 
					
						
							|  |  |  |       return  EVALUATION_ERROR_FLOAT_UNDERFLOW; | 
					
						
							|  |  |  |       //} else if (raised & (FE_INVALID|FE_INEXACT)) {
 | 
					
						
							|  |  |  |       //    return  EVALUATION_ERROR_UNDEFINED;
 | 
					
						
							|  |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2014-10-24 15:18:32 +01:00
										 |  |  |       return  EVALUATION_ERROR_UNDEFINED; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2014-10-15 11:06:07 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2014-10-14 01:13:31 +01:00
										 |  |  | #elif (defined(__svr4__) || defined(__SVR4))
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   switch(sip->si_code) { | 
					
						
							|  |  |  |   case FPE_INTDIV: | 
					
						
							| 
									
										
										
										
											2014-10-16 10:49:11 +01:00
										 |  |  |     return EVALUATION_ERROR_ZERO_DIVISOR; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     break; | 
					
						
							|  |  |  |   case FPE_INTOVF: | 
					
						
							| 
									
										
										
										
											2014-10-16 10:49:11 +01:00
										 |  |  |     return EVALUATION_ERROR_INT_OVERFLOW; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     break; | 
					
						
							|  |  |  |   case FPE_FLTDIV: | 
					
						
							| 
									
										
										
										
											2014-10-16 10:49:11 +01:00
										 |  |  |     return EVALUATION_ERROR_ZERO_DIVISOR; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     break; | 
					
						
							|  |  |  |   case FPE_FLTOVF: | 
					
						
							| 
									
										
										
										
											2014-10-16 10:49:11 +01:00
										 |  |  |     return EVALUATION_ERROR_FLOAT_OVERFLOW; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     break; | 
					
						
							|  |  |  |   case FPE_FLTUND: | 
					
						
							| 
									
										
										
										
											2014-10-16 10:49:11 +01:00
										 |  |  |     return EVALUATION_ERROR_FLOAT_UNDERFLOW; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     break; | 
					
						
							|  |  |  |   case FPE_FLTRES: | 
					
						
							|  |  |  |   case FPE_FLTINV: | 
					
						
							|  |  |  |   case FPE_FLTSUB: | 
					
						
							|  |  |  |   default: | 
					
						
							| 
									
										
										
										
											2014-10-16 10:49:11 +01:00
										 |  |  |     return EVALUATION_ERROR_UNDEFINED; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  |   set_fpu_exceptions(0); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2014-10-15 11:06:07 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |   return LOCAL_matherror; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static Int | 
					
						
							|  |  |  | p_fpe_error( USES_REGS1 ) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2014-10-16 10:49:11 +01:00
										 |  |  |   Yap_Error(LOCAL_matherror, LOCAL_mathtt, LOCAL_mathstring); | 
					
						
							| 
									
										
										
										
											2014-10-15 11:06:07 +01:00
										 |  |  |   LOCAL_matherror = YAP_NO_ERROR; | 
					
						
							| 
									
										
										
										
											2014-10-16 10:49:11 +01:00
										 |  |  |   LOCAL_mathtt = TermNil; | 
					
						
							|  |  |  |   LOCAL_mathstring = NULL; | 
					
						
							| 
									
										
										
										
											2014-10-15 11:06:07 +01:00
										 |  |  |   return FALSE; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if HAVE_SIGFPE
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | HandleMatherr(int  sig, void *sipv, void *uapv) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     LOCAL_matherror = Yap_MathException( ); | 
					
						
							| 
									
										
										
										
											2014-10-15 11:06:07 +01:00
										 |  |  |   /* reset the registers so that we don't have trash in abstract machine */ | 
					
						
							|  |  |  |   Yap_external_signal( worker_id, YAP_FPE_SIGNAL ); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-15 23:47:29 +00:00
										 |  |  | #endif /* SIGFPE */
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-15 11:06:07 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | typedef void (*signal_handler_t)(int, void *, void *); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  | #if HAVE_SIGACTION
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | static void | 
					
						
							| 
									
										
										
										
											2014-10-15 11:06:07 +01:00
										 |  |  | my_signal_info(int sig, void * handler) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   struct sigaction sigact; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-15 11:06:07 +01:00
										 |  |  |   sigact.sa_handler = handler; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   sigemptyset(&sigact.sa_mask); | 
					
						
							| 
									
										
										
										
											2002-05-26 04:03:56 +00:00
										 |  |  |   sigact.sa_flags = SA_SIGINFO; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   sigaction(sig,&sigact,NULL); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							| 
									
										
										
										
											2014-10-15 11:06:07 +01:00
										 |  |  | my_signal(int sig, void * handler) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   struct sigaction sigact; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-15 23:47:29 +00:00
										 |  |  |   sigact.sa_handler= (void *)handler; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   sigemptyset(&sigact.sa_mask); | 
					
						
							| 
									
										
										
										
											2002-05-26 04:03:56 +00:00
										 |  |  |   sigact.sa_flags = 0; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   sigaction(sig,&sigact,NULL); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							| 
									
										
										
										
											2014-10-15 11:06:07 +01:00
										 |  |  | my_signal(int sig, void *handler) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2014-10-24 15:18:32 +01:00
										 |  |  |   signal(sig,  handler); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							| 
									
										
										
										
											2014-10-15 11:06:07 +01:00
										 |  |  | my_signal_info(int sig, void *handler) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2014-03-15 23:47:29 +00:00
										 |  |  |   if(signal(sig, (void *)handler) == SIG_ERR) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     exit(1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-15 23:47:29 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  | #if !defined(LIGHT) && !_MSC_VER && !defined(__MINGW32__) && !defined(LIGHT)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | static RETSIGTYPE | 
					
						
							| 
									
										
										
										
											2014-03-15 23:47:29 +00:00
										 |  |  | ReceiveSignal (int s, void *x, void *y) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2014-09-02 14:19:23 -05:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     LOCAL_PrologMode |= InterruptMode; | 
					
						
							| 
									
										
										
										
											2014-09-02 22:24:01 -05:00
										 |  |  |   my_signal (s, ReceiveSignal); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   switch (s) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     case SIGINT: | 
					
						
							| 
									
										
										
										
											2014-09-02 14:19:23 -05:00
										 |  |  |       // always direct SIGINT to console
 | 
					
						
							|  |  |  |       Yap_external_signal( 0, YAP_INT_SIGNAL ); | 
					
						
							|  |  |  |       break; | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     case SIGALRM: | 
					
						
							| 
									
										
										
										
											2014-09-02 14:19:23 -05:00
										 |  |  |       Yap_external_signal( worker_id, YAP_ALARM_SIGNAL ); | 
					
						
							|  |  |  |       break; | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     case SIGVTALRM: | 
					
						
							| 
									
										
										
										
											2014-09-02 14:19:23 -05:00
										 |  |  |       Yap_external_signal( worker_id, YAP_VTALARM_SIGNAL ); | 
					
						
							|  |  |  |       break; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #ifndef MPW
 | 
					
						
							| 
									
										
										
										
											2014-03-15 23:47:29 +00:00
										 |  |  | #ifdef HAVE_SIGFPE
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     case SIGFPE: | 
					
						
							| 
									
										
										
										
											2014-10-15 11:06:07 +01:00
										 |  |  |       Yap_external_signal( worker_id, YAP_FPE_SIGNAL ); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |       break; | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2014-03-15 23:47:29 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #if !defined(LIGHT) && !defined(_WIN32)
 | 
					
						
							|  |  |  |       /* These signals are not handled by WIN32 and not the Macintosh */ | 
					
						
							|  |  |  |     case SIGQUIT: | 
					
						
							|  |  |  |     case SIGKILL: | 
					
						
							| 
									
										
										
										
											2014-09-02 14:19:23 -05:00
										 |  |  |       LOCAL_PrologMode &= ~InterruptMode; | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |       Yap_Error(INTERRUPT_ERROR,MkIntTerm(s),NULL); | 
					
						
							| 
									
										
										
										
											2014-09-02 14:19:23 -05:00
										 |  |  |       break; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2008-05-23 10:02:13 +00:00
										 |  |  | #ifdef SIGUSR1
 | 
					
						
							| 
									
										
										
										
											2002-01-11 15:54:17 +00:00
										 |  |  |     case SIGUSR1: | 
					
						
							|  |  |  |       /* force the system to creep */ | 
					
						
							| 
									
										
										
										
											2014-09-02 14:19:23 -05:00
										 |  |  |       Yap_external_signal ( worker_id, YAP_USR1_SIGNAL); | 
					
						
							| 
									
										
										
										
											2002-01-11 15:54:17 +00:00
										 |  |  |       break; | 
					
						
							| 
									
										
										
										
											2002-01-15 15:44:57 +00:00
										 |  |  | #endif /* defined(SIGUSR1) */
 | 
					
						
							| 
									
										
										
										
											2008-05-23 10:02:13 +00:00
										 |  |  | #ifdef SIGUSR2
 | 
					
						
							| 
									
										
										
										
											2002-01-11 15:54:17 +00:00
										 |  |  |     case SIGUSR2: | 
					
						
							|  |  |  |       /* force the system to creep */ | 
					
						
							| 
									
										
										
										
											2014-09-02 14:19:23 -05:00
										 |  |  |       Yap_external_signal ( worker_id, YAP_USR2_SIGNAL); | 
					
						
							| 
									
										
										
										
											2002-01-11 15:54:17 +00:00
										 |  |  |       break; | 
					
						
							| 
									
										
										
										
											2002-01-15 15:44:57 +00:00
										 |  |  | #endif /* defined(SIGUSR2) */
 | 
					
						
							| 
									
										
										
										
											2008-05-23 10:02:13 +00:00
										 |  |  | #ifdef SIGPIPE
 | 
					
						
							|  |  |  |     case SIGPIPE: | 
					
						
							|  |  |  |       /* force the system to creep */ | 
					
						
							| 
									
										
										
										
											2014-09-02 14:19:23 -05:00
										 |  |  |       Yap_external_signal ( worker_id, YAP_PIPE_SIGNAL); | 
					
						
							| 
									
										
										
										
											2008-05-23 10:02:13 +00:00
										 |  |  |       break; | 
					
						
							|  |  |  | #endif /* defined(SIGPIPE) */
 | 
					
						
							|  |  |  | #ifdef SIGHUP
 | 
					
						
							| 
									
										
										
										
											2002-01-11 15:54:17 +00:00
										 |  |  |     case SIGHUP: | 
					
						
							|  |  |  |       /* force the system to creep */ | 
					
						
							| 
									
										
										
										
											2013-03-03 20:29:02 -06:00
										 |  |  |       /* Just ignore SUGHUP Yap_signal (YAP_HUP_SIGNAL); */ | 
					
						
							| 
									
										
										
										
											2002-01-11 15:54:17 +00:00
										 |  |  |       break; | 
					
						
							| 
									
										
										
										
											2002-01-15 15:44:57 +00:00
										 |  |  | #endif /* defined(SIGHUP) */
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     default: | 
					
						
							| 
									
										
										
										
											2014-03-04 12:02:26 +00:00
										 |  |  |       fprintf(stderr, "\n[ Unexpected signal ]\n"); | 
					
						
							| 
									
										
										
										
											2014-09-02 14:19:23 -05:00
										 |  |  |       exit (s); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2014-09-02 22:24:01 -05:00
										 |  |  |   LOCAL_PrologMode &= ~InterruptMode; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  | #if (_MSC_VER || defined(__MINGW32__))
 | 
					
						
							|  |  |  | static BOOL WINAPI | 
					
						
							|  |  |  | MSCHandleSignal(DWORD dwCtrlType) { | 
					
						
							| 
									
										
										
										
											2014-05-29 11:30:09 +02:00
										 |  |  | #if THREADS
 | 
					
						
							|  |  |  |   if (REMOTE_InterruptsDisabled(0)) { | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     if (LOCAL_InterruptsDisabled) { | 
					
						
							| 
									
										
										
										
											2014-05-29 11:30:09 +02:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       return FALSE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     switch(dwCtrlType) { | 
					
						
							|  |  |  |     case CTRL_C_EVENT: | 
					
						
							|  |  |  |     case CTRL_BREAK_EVENT: | 
					
						
							| 
									
										
										
										
											2014-05-29 11:30:09 +02:00
										 |  |  | #if THREADS
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       Yap_external_signal(0, YAP_WINTIMER_SIGNAL); | 
					
						
							|  |  |  |       REMOTE_PrologMode(0) |= InterruptMode; | 
					
						
							| 
									
										
										
										
											2014-05-29 11:30:09 +02:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       Yap_signal(YAP_WINTIMER_SIGNAL); | 
					
						
							|  |  |  |       LOCAL_PrologMode |= InterruptMode; | 
					
						
							| 
									
										
										
										
											2014-05-29 11:30:09 +02:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       return(TRUE); | 
					
						
							|  |  |  |     default: | 
					
						
							|  |  |  |       return(FALSE); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   /* SIGINT can cause problems, if caught before full initialization */ | 
					
						
							|  |  |  |   static void | 
					
						
							|  |  |  |     InitSignals (void) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     if (GLOBAL_PrologShouldHandleInterrupts) { | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  | #if !defined(LIGHT) && !_MSC_VER && !defined(__MINGW32__) && !defined(LIGHT)
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       my_signal (SIGQUIT, ReceiveSignal); | 
					
						
							|  |  |  |       my_signal (SIGKILL, ReceiveSignal); | 
					
						
							|  |  |  |       my_signal (SIGUSR1, ReceiveSignal); | 
					
						
							|  |  |  |       my_signal (SIGUSR2, ReceiveSignal); | 
					
						
							|  |  |  |       my_signal (SIGHUP,  ReceiveSignal); | 
					
						
							|  |  |  |       my_signal (SIGALRM, ReceiveSignal); | 
					
						
							|  |  |  |       my_signal (SIGVTALRM, ReceiveSignal); | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2008-05-23 10:02:13 +00:00
										 |  |  | #ifdef SIGPIPE
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       my_signal (SIGPIPE, ReceiveSignal); | 
					
						
							| 
									
										
										
										
											2008-05-23 10:02:13 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #if _MSC_VER || defined(__MINGW32__)
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       signal (SIGINT, SIG_IGN); | 
					
						
							|  |  |  |       SetConsoleCtrlHandler(MSCHandleSignal,TRUE); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       my_signal (SIGINT, ReceiveSignal); | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2014-03-15 23:47:29 +00:00
										 |  |  | #ifdef HAVE_SIGFPE
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       my_signal (SIGFPE, HandleMatherr); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2014-03-16 00:52:43 +00:00
										 |  |  | #if HAVE_SIGSEGV
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       my_signal_info (SIGSEGV, HandleSIGSEGV); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2011-03-30 16:39:09 +01:00
										 |  |  | #ifdef YAPOR_COW
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       signal(SIGCHLD, SIG_IGN);  /* avoid ghosts */ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2004-11-18 22:32:40 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #endif /* HAVE_SIGNAL */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   /* TrueFileName -> Finds the true name of a file */ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef __MINGW32__
 | 
					
						
							|  |  |  | #include <ctype.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   static int | 
					
						
							|  |  |  |     volume_header(char *file) | 
					
						
							|  |  |  |   { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #if _MSC_VER || defined(__MINGW32__)
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     char *ch = file; | 
					
						
							|  |  |  |     int c; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     while ((c = ch[0]) != '\0') { | 
					
						
							|  |  |  |       if (isalnum(c)) ch++; | 
					
						
							|  |  |  |       else return(c == ':'); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     return(FALSE); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   int | 
					
						
							|  |  |  |     Yap_volume_header(char *file) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     return volume_header(file); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   const char * Yap_getcwd(const char *cwd, size_t cwdlen) | 
					
						
							|  |  |  |   { | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | #if _WIN32 || defined(__MINGW32__)
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     if (GetCurrentDirectory(cwdlen, (char *)cwd) == 0) | 
					
						
							|  |  |  |       { | 
					
						
							|  |  |  | 	Yap_WinError("GetCurrentDirectory failed" ); | 
					
						
							|  |  |  | 	return NULL; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     return (char *)cwd; | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  | #elif __ANDROID__
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     if (GLOBAL_AssetsWD) { | 
					
						
							|  |  |  |       return strncpy( (char *)cwd, (const char *)GLOBAL_AssetsWD, cwdlen); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |     return getcwd((char *)cwd, cwdlen); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  |   static Int | 
					
						
							|  |  |  |   working_directory(USES_REGS1) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     char dir[YAP_FILENAME_MAX+1]; | 
					
						
							|  |  |  |     Term t1 = Deref(ARG1), t2; | 
					
						
							|  |  |  |     if ( !IsVarTerm( t1 ) && !IsAtomTerm(t1) ) { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_ATOM, t1, "working_directory"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!Yap_unify( t1, MkAtomTerm(Yap_LookupAtom(Yap_getcwd(dir,YAP_FILENAME_MAX )))) ) | 
					
						
							|  |  |  |       return false; | 
					
						
							|  |  |  |     t2 = Deref(ARG2); | 
					
						
							|  |  |  |     if ( IsVarTerm( t2 ) ) { | 
					
						
							|  |  |  |       Yap_Error(INSTANTIATION_ERROR, t2, "working_directory"); | 
					
						
							|  |  |  |     }     | 
					
						
							|  |  |  |    if ( !IsAtomTerm(t2) ) { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_ATOM, t2, "working_directory"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |    ChDir(RepAtom(AtomOfTerm(t2))->StrOfAE); | 
					
						
							|  |  |  |    return true; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  |   static char * | 
					
						
							|  |  |  |     expandWithPrefix(const char *source, const char *root, char *result) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     char *work; | 
					
						
							|  |  |  |     char ares1[YAP_FILENAME_MAX+1]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     work = expandVars( source, ares1, YAP_FILENAME_MAX); | 
					
						
							|  |  |  |     // expand names first
 | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  |     if (root && !Yap_IsAbsolutePath( source ) ) { | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       char ares2[YAP_FILENAME_MAX+1]; | 
					
						
							|  |  |  |       strncpy( ares2, root, YAP_FILENAME_MAX ); | 
					
						
							|  |  |  |       strncat( ares2, "/", YAP_FILENAME_MAX ); | 
					
						
							|  |  |  |       strncat( ares2, work, YAP_FILENAME_MAX ); | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  |       return Yap_AbsoluteFile( ares2, result ); | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     } else { | 
					
						
							|  |  |  |       // expand path
 | 
					
						
							|  |  |  |       return myrealpath( work, result); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** Yap_trueFileName: tries to generate the true name of  file
 | 
					
						
							|  |  |  |    *  | 
					
						
							|  |  |  |    *  | 
					
						
							|  |  |  |    * @param isource the proper file | 
					
						
							|  |  |  |    * @param idef the default name fo rthe file, ie, startup.yss | 
					
						
							|  |  |  |    * @param root the prefix | 
					
						
							|  |  |  |    * @param result the output | 
					
						
							|  |  |  |    * @param access verify whether the file has access permission | 
					
						
							|  |  |  |    * @param ftype saved state, object, saved file, prolog file | 
					
						
							|  |  |  |    * @param expand_root expand $ ~, etc | 
					
						
							|  |  |  |    * @param in_lib library file | 
					
						
							|  |  |  |    *  | 
					
						
							|  |  |  |    * @return  | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   bool | 
					
						
							|  |  |  |     Yap_trueFileName (const char *isource, const char * idef,  const char *iroot, char *result, bool access, file_type_t ftype, bool expand_root, bool in_lib) | 
					
						
							|  |  |  |   { | 
					
						
							| 
									
										
										
										
											2015-04-15 11:21:15 +01:00
										 |  |  |    | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     char save_buffer[YAP_FILENAME_MAX+1];     | 
					
						
							| 
									
										
										
										
											2015-04-15 11:21:15 +01:00
										 |  |  |     const char *root, *source = isource; | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     int rc = FAIL_RESTORE; | 
					
						
							|  |  |  |     int try       = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     while ( rc == FAIL_RESTORE) { | 
					
						
							|  |  |  |       bool done = false; | 
					
						
							|  |  |  |       // { CACHE_REGS __android_log_print(ANDROID_LOG_ERROR,  __FUNCTION__, "try=%d %s %s", try, isource, iroot) ; }        
 | 
					
						
							|  |  |  |       switch (try++) { | 
					
						
							|  |  |  |       case 0:  // path or file name is given;
 | 
					
						
							|  |  |  | 	root = iroot;       | 
					
						
							|  |  |  | 	if (iroot || isource) {     | 
					
						
							|  |  |  | 	  source = ( isource ? isource : idef ) ;	   | 
					
						
							| 
									
										
										
										
											2015-04-15 11:21:15 +01:00
										 |  |  | 	} else { | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	  done = true; | 
					
						
							| 
									
										
										
										
											2015-04-15 11:21:15 +01:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	break; | 
					
						
							|  |  |  |       case 1: // library directory is given in command line
 | 
					
						
							|  |  |  | 	if ( in_lib && ftype == YAP_SAVED_STATE) { | 
					
						
							|  |  |  | 	  root = iroot; | 
					
						
							|  |  |  | 	  source = ( isource ? isource : idef ) ;      | 
					
						
							|  |  |  | 	} else | 
					
						
							|  |  |  | 	  done = true; | 
					
						
							|  |  |  | 	break; | 
					
						
							|  |  |  |       case 2: // use environment variable YAPLIBDIR
 | 
					
						
							|  |  |  | #if HAVE_GETENV
 | 
					
						
							|  |  |  | 	if ( in_lib) { | 
					
						
							|  |  |  | 	  if (ftype == YAP_SAVED_STATE || ftype == YAP_OBJ) { | 
					
						
							|  |  |  | 	    root = getenv("YAPLIBDIR");      | 
					
						
							|  |  |  | 	  } else { | 
					
						
							|  |  |  | 	    root = getenv("YAPSHAREDIR"); | 
					
						
							|  |  |  | 	  } | 
					
						
							|  |  |  | 	  source = ( isource ? isource : idef ) ;      | 
					
						
							|  |  |  | 	} else | 
					
						
							|  |  |  | 	  done = true; | 
					
						
							|  |  |  | 	break; | 
					
						
							| 
									
										
										
										
											2015-04-15 11:21:15 +01:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	done = true; | 
					
						
							| 
									
										
										
										
											2015-04-15 11:21:15 +01:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	break; | 
					
						
							|  |  |  |       case 3: // use compilation variable YAPLIBDIR
 | 
					
						
							|  |  |  | 	if ( in_lib) { | 
					
						
							|  |  |  | 	  source = ( isource ? isource : idef ) ;            | 
					
						
							|  |  |  | 	  if (ftype == YAP_PL || ftype == YAP_QLY) { | 
					
						
							|  |  |  | 	    root = YAP_SHAREDIR; | 
					
						
							|  |  |  | 	  } else { | 
					
						
							|  |  |  | 	    root = YAP_LIBDIR; | 
					
						
							|  |  |  | 	  } | 
					
						
							|  |  |  | 	} else | 
					
						
							|  |  |  | 	  done = true; | 
					
						
							|  |  |  | 	break; | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       case 4: // WIN stuff: registry
 | 
					
						
							| 
									
										
										
										
											2015-04-15 11:21:15 +01:00
										 |  |  | #if __WINDOWS__
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	if ( in_lib) {       | 
					
						
							|  |  |  | 	  source = ( ftype == YAP_PL || ftype == YAP_QLY ? "library" : "startup" ) ; | 
					
						
							|  |  |  | 	  source = Yap_RegistryGetString( source ); | 
					
						
							|  |  |  | 	  root = NULL; | 
					
						
							|  |  |  | 	} else | 
					
						
							| 
									
										
										
										
											2015-04-15 11:21:15 +01:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	  done = true; | 
					
						
							|  |  |  | 	break; | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       case 5: // search from the binary
 | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2015-04-15 11:21:15 +01:00
										 |  |  | #ifndef __ANDROID__
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	  done = true; | 
					
						
							|  |  |  | 	  break; | 
					
						
							| 
									
										
										
										
											2015-04-15 11:21:15 +01:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	  const char *pt = Yap_FindExecutable(); | 
					
						
							| 
									
										
										
										
											2015-04-15 11:21:15 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	  if (pt) { | 
					
						
							|  |  |  | 	    source = ( ftype == YAP_SAVED_STATE || ftype == YAP_OBJ ? "../../lib/Yap" : "../../share/Yap" ) ; | 
					
						
							|  |  |  | 	    if (Yap_trueFileName(source, NULL, pt, save_buffer, access, ftype, expand_root, in_lib) ) | 
					
						
							|  |  |  | 	      root = save_buffer; | 
					
						
							|  |  |  | 	    else  | 
					
						
							|  |  |  | 	      done = true; | 
					
						
							|  |  |  | 	  } else { | 
					
						
							|  |  |  | 	    done = true; | 
					
						
							|  |  |  | 	  } | 
					
						
							|  |  |  | 	  source = ( isource ? isource : idef ) ; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	break; | 
					
						
							|  |  |  |       case 6: // default, try current directory
 | 
					
						
							|  |  |  | 	if (!isource && ftype == YAP_SAVED_STATE) | 
					
						
							|  |  |  | 	  source = idef; | 
					
						
							|  |  |  | 	root = NULL; | 
					
						
							|  |  |  | 	break; | 
					
						
							|  |  |  |       default: | 
					
						
							|  |  |  | 	return false; | 
					
						
							| 
									
										
										
										
											2015-04-15 11:21:15 +01:00
										 |  |  |       } | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       if (done) | 
					
						
							|  |  |  | 	continue; | 
					
						
							|  |  |  |       if (expand_root && root) { | 
					
						
							|  |  |  | 	root = expandWithPrefix( root, NULL, save_buffer ); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       //    { CACHE_REGS __android_log_print(ANDROID_LOG_ERROR,  __FUNCTION__, "root= %s %s ", root, source) ; }
 | 
					
						
							|  |  |  |       char *work = expandWithPrefix( source, root, result ); | 
					
						
							| 
									
										
										
										
											2015-04-15 11:21:15 +01:00
										 |  |  |    | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       // expand names in case you have
 | 
					
						
							|  |  |  |       // to add a prefix
 | 
					
						
							|  |  |  |       if ( !access || exists( work ) ) | 
					
						
							|  |  |  | 	return true; // done
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return false; | 
					
						
							| 
									
										
										
										
											2006-05-17 18:38:11 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   int | 
					
						
							|  |  |  |     Yap_TrueFileName (const char *source, char *result, int in_lib) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     return Yap_trueFileName (source, NULL, NULL, result, true, YAP_PL, true, in_lib);   | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   int | 
					
						
							|  |  |  |     Yap_TruePrefixedFileName (const char *source, const char *root, char *result, int in_lib) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     return Yap_trueFileName (source, NULL, root, result, true, YAP_PL, true, in_lib);   | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-04-15 11:21:15 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   static Int | 
					
						
							|  |  |  |     p_true_file_name ( USES_REGS1 ) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     Term t = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     if (IsVarTerm(t)) { | 
					
						
							|  |  |  |       Yap_Error(INSTANTIATION_ERROR,t,"argument to true_file_name unbound"); | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!IsAtomTerm(t)) { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_ATOM,t,"argument to true_file_name"); | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!Yap_trueFileName (RepAtom(AtomOfTerm(t))->StrOfAE, NULL, NULL, LOCAL_FileNameBuf, true, YAP_PL, false, false))   | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							|  |  |  |     return Yap_unify(ARG2, MkAtomTerm(Yap_LookupAtom(LOCAL_FileNameBuf))); | 
					
						
							| 
									
										
										
										
											2006-05-17 18:38:11 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2013-11-08 12:43:07 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   static Int | 
					
						
							|  |  |  |     p_expand_file_name ( USES_REGS1 ) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     Term t = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     if (IsVarTerm(t)) { | 
					
						
							|  |  |  |       Yap_Error(INSTANTIATION_ERROR,t,"argument to true_file_name unbound"); | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!IsAtomTerm(t)) { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_ATOM,t,"argument to true_file_name"); | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!Yap_trueFileName (RepAtom(AtomOfTerm(t))->StrOfAE, NULL, NULL, LOCAL_FileNameBuf, true, YAP_PL, true, false))   | 
					
						
							|  |  |  |       return false; | 
					
						
							|  |  |  |     return Yap_unify(ARG2, MkAtomTerm(Yap_LookupAtom(LOCAL_FileNameBuf))); | 
					
						
							| 
									
										
										
										
											2013-11-08 12:43:07 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2006-05-17 18:38:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   static Int | 
					
						
							|  |  |  |     p_true_file_name3 ( USES_REGS1 ) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     Term t = Deref(ARG1), t2 = Deref(ARG2); | 
					
						
							|  |  |  |     char *root = NULL; | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     if (IsVarTerm(t)) { | 
					
						
							|  |  |  |       Yap_Error(INSTANTIATION_ERROR,t,"argument to true_file_name unbound"); | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2007-09-27 22:40:22 +00:00
										 |  |  |     if (!IsAtomTerm(t)) { | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       Yap_Error(TYPE_ERROR_ATOM,t,"argument to true_file_name"); | 
					
						
							| 
									
										
										
										
											2007-09-27 22:40:22 +00:00
										 |  |  |       return FALSE; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     if (!IsVarTerm(t2)) { | 
					
						
							|  |  |  |       if (!IsAtomTerm(t)) { | 
					
						
							|  |  |  | 	Yap_Error(TYPE_ERROR_ATOM,t2,"argument to true_file_name"); | 
					
						
							|  |  |  | 	return FALSE; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       root = RepAtom(AtomOfTerm(t2))->StrOfAE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!Yap_trueFileName (RepAtom(AtomOfTerm(t))->StrOfAE, NULL, root, LOCAL_FileNameBuf, true, YAP_PL, false, false))   | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							|  |  |  |     return Yap_unify(ARG3, MkAtomTerm(Yap_LookupAtom(LOCAL_FileNameBuf))); | 
					
						
							| 
									
										
										
										
											2007-09-27 22:40:22 +00:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   /* Executes $SHELL under Prolog */ | 
					
						
							|  |  |  |   /** @pred  sh
 | 
					
						
							| 
									
										
										
										
											2014-09-15 13:10:49 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       Creates a new shell interaction. | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   */ | 
					
						
							|  |  |  |   static Int | 
					
						
							|  |  |  |     p_sh ( USES_REGS1 ) | 
					
						
							|  |  |  |   {				/* sh				 */ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #ifdef HAVE_SYSTEM
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     char *shell; | 
					
						
							|  |  |  |     shell = (char *) getenv ("SHELL"); | 
					
						
							|  |  |  |     if (shell == NULL) | 
					
						
							|  |  |  |       shell = "/bin/sh"; | 
					
						
							|  |  |  |     if (system (shell) < 0) { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #if HAVE_STRERROR
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       Yap_Error(OPERATING_SYSTEM_ERROR, TermNil, "%s in sh/0", strerror(errno)); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       Yap_Error(OPERATING_SYSTEM_ERROR, TermNil, "in sh/0"); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       return FALSE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return TRUE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #ifdef MSH
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     register char *shell; | 
					
						
							|  |  |  |     shell = "msh -i"; | 
					
						
							|  |  |  |     system (shell); | 
					
						
							|  |  |  |     return (TRUE); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     Yap_Error(SYSTEM_ERROR,TermNil,"sh not available in this configuration"); | 
					
						
							|  |  |  |     return(FALSE); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif /* MSH */
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   /** shell(+Command:text, -Status:integer) is det.
 | 
					
						
							| 
									
										
										
										
											2014-03-06 02:09:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       Run an external command and wait for its completion. | 
					
						
							|  |  |  |   */ | 
					
						
							|  |  |  |   static Int | 
					
						
							|  |  |  |     p_shell ( USES_REGS1 ) | 
					
						
							|  |  |  |   {				/* '$shell'(+SystCommand)			 */ | 
					
						
							| 
									
										
										
										
											2014-09-15 13:10:49 -05:00
										 |  |  | #if _MSC_VER || defined(__MINGW32__)
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     char *cmd; | 
					
						
							|  |  |  |     term_t A1 = Yap_InitSlot(ARG1); | 
					
						
							|  |  |  |     if ( PL_get_chars(A1, &cmd, CVT_ALL|REP_FN|CVT_EXCEPTION) ) | 
					
						
							|  |  |  |       { int rval = System(cmd); | 
					
						
							| 
									
										
										
										
											2014-03-06 02:09:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	return rval == 0; | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2014-03-06 02:09:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     return FALSE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  | #if HAVE_SYSTEM
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     char *shell; | 
					
						
							|  |  |  |     register int bourne = FALSE; | 
					
						
							|  |  |  |     Term t1 = Deref (ARG1); | 
					
						
							|  |  |  |     const char *cmd; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     shell = (char *) getenv ("SHELL"); | 
					
						
							|  |  |  |     if (!strcmp (shell, "/bin/sh")) | 
					
						
							|  |  |  |       bourne = TRUE; | 
					
						
							|  |  |  |     if (shell == NIL) | 
					
						
							|  |  |  |       bourne = TRUE; | 
					
						
							|  |  |  |     if (IsAtomTerm(t1)) | 
					
						
							|  |  |  |       cmd = RepAtom(AtomOfTerm(t1))->StrOfAE; | 
					
						
							|  |  |  |     else if (IsStringTerm(t1)) | 
					
						
							|  |  |  |       cmd = StringOfTerm(t1); | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							|  |  |  |     /* Yap_CloseStreams(TRUE); */ | 
					
						
							|  |  |  |     if (bourne) | 
					
						
							|  |  |  |       return system( cmd ) == 0; | 
					
						
							|  |  |  |     else { | 
					
						
							|  |  |  |       int status = -1; | 
					
						
							|  |  |  |       int child = fork (); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (child == 0) {			/* let the children go */ | 
					
						
							|  |  |  | 	if (!execl (shell, shell, "-c", cmd , NULL)) { | 
					
						
							|  |  |  | 	  exit(-1); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	exit(TRUE); | 
					
						
							| 
									
										
										
										
											2006-04-25 03:23:40 +00:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       {				/* put the father on wait */ | 
					
						
							|  |  |  | 	int result = child < 0 || | 
					
						
							|  |  |  | 	  /* vsc:I am not sure this is used, Stevens say wait returns an integer.
 | 
					
						
							|  |  |  | 	     #if NO_UNION_WAIT
 | 
					
						
							|  |  |  | 	  */ | 
					
						
							|  |  |  | 	  wait ((&status)) != child || | 
					
						
							|  |  |  | 	  /*
 | 
					
						
							|  |  |  | 	    #else
 | 
					
						
							|  |  |  | 	    wait ((union wait *) (&status)) != child || | 
					
						
							|  |  |  | 	    #endif
 | 
					
						
							|  |  |  | 	  */ | 
					
						
							|  |  |  | 	  status == 0; | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  | 	return result; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | #else /* HAVE_SYSTEM */
 | 
					
						
							|  |  |  | #ifdef MSH
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     register char *shell; | 
					
						
							|  |  |  |     shell = "msh -i"; | 
					
						
							|  |  |  |     /* Yap_CloseStreams(); */ | 
					
						
							|  |  |  |     system (shell); | 
					
						
							|  |  |  |     return TRUE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     Yap_Error (SYSTEM_ERROR,TermNil,"shell not available in this configuration"); | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #endif /* HAVE_SYSTEM */
 | 
					
						
							|  |  |  | #endif /* _MSC_VER */
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   /** system(+Command:text).
 | 
					
						
							| 
									
										
										
										
											2014-09-15 13:10:49 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       Run an external command. | 
					
						
							|  |  |  |   */ | 
					
						
							| 
									
										
										
										
											2014-09-15 13:10:49 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   static Int | 
					
						
							|  |  |  |     p_system ( USES_REGS1 ) | 
					
						
							|  |  |  |   {				/* '$system'(+SystCommand)	       */ | 
					
						
							| 
									
										
										
										
											2014-03-16 00:52:43 +00:00
										 |  |  | #if _MSC_VER || defined(__MINGW32__)
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     char *cmd; | 
					
						
							|  |  |  |     term_t A1 = Yap_InitSlot(ARG1); | 
					
						
							|  |  |  |     if ( PL_get_chars(A1, &cmd, CVT_ALL|REP_FN|CVT_EXCEPTION) ) | 
					
						
							|  |  |  |       { STARTUPINFO si; | 
					
						
							|  |  |  | 	PROCESS_INFORMATION pi; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	ZeroMemory( &si, sizeof(si) ); | 
					
						
							|  |  |  | 	si.cb = sizeof(si); | 
					
						
							|  |  |  | 	ZeroMemory( &pi, sizeof(pi) ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Start the child process.
 | 
					
						
							|  |  |  | 	if( !CreateProcess( NULL,   // No module name (use command line)
 | 
					
						
							|  |  |  | 			    cmd,            // Command line
 | 
					
						
							|  |  |  | 			    NULL,           // Process handle not inheritable
 | 
					
						
							|  |  |  | 			    NULL,           // Thread handle not inheritable
 | 
					
						
							|  |  |  | 			    FALSE,          // Set handle inheritance to FALSE
 | 
					
						
							|  |  |  | 			    0,              // No creation flags
 | 
					
						
							|  |  |  | 			    NULL,           // Use parent's environment block
 | 
					
						
							|  |  |  | 			    NULL,           // Use parent's starting directory
 | 
					
						
							|  |  |  | 			    &si,            // Pointer to STARTUPINFO structure
 | 
					
						
							|  |  |  | 			    &pi )           // Pointer to PROCESS_INFORMATION structure
 | 
					
						
							|  |  |  | 	    ) | 
					
						
							|  |  |  | 	  { | 
					
						
							|  |  |  | 	    Yap_Error( SYSTEM_ERROR, ARG1,  "CreateProcess failed (%d).\n", GetLastError() ); | 
					
						
							|  |  |  | 	    return FALSE; | 
					
						
							|  |  |  | 	  } | 
					
						
							|  |  |  | 	// Wait until child process exits.
 | 
					
						
							|  |  |  | 	WaitForSingleObject( pi.hProcess, INFINITE ); | 
					
						
							| 
									
										
										
										
											2014-03-16 00:52:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	// Close process and thread handles.
 | 
					
						
							|  |  |  | 	CloseHandle( pi.hProcess ); | 
					
						
							|  |  |  | 	CloseHandle( pi.hThread ); | 
					
						
							| 
									
										
										
										
											2014-03-16 00:52:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	return TRUE; | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2014-03-16 00:52:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     return FALSE; | 
					
						
							| 
									
										
										
										
											2014-03-16 00:52:43 +00:00
										 |  |  | #elif HAVE_SYSTEM
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     Term t1 = Deref (ARG1); | 
					
						
							|  |  |  |     const char *s; | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     if (IsVarTerm(t1)) { | 
					
						
							|  |  |  |       Yap_Error(INSTANTIATION_ERROR,t1,"argument to system/1 unbound"); | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |       return FALSE; | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     } else if (IsAtomTerm(t1)) { | 
					
						
							|  |  |  |       s = RepAtom(AtomOfTerm(t1))->StrOfAE; | 
					
						
							|  |  |  |     } else if (IsStringTerm(t1)) { | 
					
						
							|  |  |  |       s = StringOfTerm(t1); | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       if (!Yap_GetName (LOCAL_FileNameBuf, YAP_FILENAME_MAX, t1)) { | 
					
						
							|  |  |  | 	Yap_Error(TYPE_ERROR_ATOM,t1,"argument to system/1"); | 
					
						
							|  |  |  | 	return FALSE; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       s = LOCAL_FileNameBuf; | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     /* Yap_CloseStreams(TRUE); */ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #if _MSC_VER
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     _flushall(); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     if (system (s)) { | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  | #if HAVE_STRERROR
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       Yap_Error(OPERATING_SYSTEM_ERROR,t1,"%s in system(%s)", strerror(errno), s); | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       Yap_Error(OPERATING_SYSTEM_ERROR,t1,"in system(%s)", s); | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       return FALSE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return TRUE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #ifdef MSH
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     register char *shell; | 
					
						
							|  |  |  |     shell = "msh -i"; | 
					
						
							|  |  |  |     /* Yap_CloseStreams(); */ | 
					
						
							|  |  |  |     system (shell); | 
					
						
							|  |  |  |     return (TRUE); | 
					
						
							| 
									
										
										
										
											2002-01-02 05:35:20 +00:00
										 |  |  | #undef command
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     Yap_Error(SYSTEM_ERROR,TermNil,"sh not available in this machine"); | 
					
						
							|  |  |  |     return(FALSE); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #endif /* HAVE_SYSTEM */
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   /* Rename a file */ | 
					
						
							|  |  |  |   /** @pred  rename(+ _F_,+ _G_)
 | 
					
						
							| 
									
										
										
										
											2014-09-15 13:10:49 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       Renames file  _F_ to  _G_. | 
					
						
							|  |  |  |   */ | 
					
						
							|  |  |  |   static Int | 
					
						
							|  |  |  |     p_mv ( USES_REGS1 ) | 
					
						
							|  |  |  |   {				/* rename(+OldName,+NewName)   */ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #if HAVE_LINK
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     int r; | 
					
						
							|  |  |  |     char oldname[YAP_FILENAME_MAX], newname[YAP_FILENAME_MAX]; | 
					
						
							|  |  |  |     Term t1 = Deref (ARG1); | 
					
						
							|  |  |  |     Term t2 = Deref (ARG2); | 
					
						
							|  |  |  |     if (IsVarTerm(t1)) { | 
					
						
							|  |  |  |       Yap_Error(INSTANTIATION_ERROR, t1, "first argument to rename/2 unbound"); | 
					
						
							|  |  |  |     } else if (!IsAtomTerm(t1)) { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_ATOM, t1, "first argument to rename/2 not atom"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (IsVarTerm(t2)) { | 
					
						
							|  |  |  |       Yap_Error(INSTANTIATION_ERROR, t2, "second argument to rename/2 unbound"); | 
					
						
							|  |  |  |     } else if (!IsAtomTerm(t2)) { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_ATOM, t2, "second argument to rename/2 not atom"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!Yap_trueFileName (RepAtom(AtomOfTerm(t1))->StrOfAE, NULL, NULL, oldname, true, YAP_STD, true, false))     | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							|  |  |  |     if (!Yap_trueFileName (RepAtom(AtomOfTerm(t2))->StrOfAE, NULL, NULL, oldname, true, YAP_STD, true, false))   | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							|  |  |  |     if ((r = link (oldname, newname)) == 0 && (r = unlink (oldname)) != 0) | 
					
						
							|  |  |  |       unlink (newname); | 
					
						
							|  |  |  |     if (r != 0) { | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  | #if HAVE_STRERROR
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       Yap_Error(OPERATING_SYSTEM_ERROR,t2,"%s in rename(%s,%s)", strerror(errno),oldname,newname); | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       Yap_Error(OPERATING_SYSTEM_ERROR,t2,"in rename(%s,%s)",oldname,newname); | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       return FALSE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return TRUE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     Yap_Error(SYSTEM_ERROR,TermNil,"rename/2 not available in this machine"); | 
					
						
							|  |  |  |     return (FALSE); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef MAC
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   void | 
					
						
							|  |  |  |     Yap_SetTextFile (name) | 
					
						
							|  |  |  |     char *name; | 
					
						
							|  |  |  |   { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #ifdef MACC
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     SetFileType (name, 'TEXT'); | 
					
						
							|  |  |  |     SetFileSignature (name, 'EDIT'); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     FInfo f; | 
					
						
							|  |  |  |     FInfo *p = &f; | 
					
						
							|  |  |  |     GetFInfo (name, 0, p); | 
					
						
							|  |  |  |     p->fdType = 'TEXT'; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #ifdef MPW
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     if (mpwshell) | 
					
						
							|  |  |  |       p->fdCreator = 'MPS\0'; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef LIGHT
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     else | 
					
						
							|  |  |  |       p->fdCreator = 'EDIT'; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     SetFInfo (name, 0, p); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   /* return YAP's environment */ | 
					
						
							|  |  |  |   static Int p_getenv( USES_REGS1 ) | 
					
						
							|  |  |  |   { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #if HAVE_GETENV
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     Term t1 = Deref(ARG1), to; | 
					
						
							|  |  |  |     char *s, *so; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (IsVarTerm(t1)) { | 
					
						
							|  |  |  |       Yap_Error(INSTANTIATION_ERROR, t1, | 
					
						
							|  |  |  | 		"first arg of getenv/2"); | 
					
						
							|  |  |  |       return(FALSE); | 
					
						
							|  |  |  |     } else if (!IsAtomTerm(t1)) { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_ATOM, t1, | 
					
						
							|  |  |  | 		"first arg of getenv/2"); | 
					
						
							|  |  |  |       return(FALSE); | 
					
						
							|  |  |  |     } else s = RepAtom(AtomOfTerm(t1))->StrOfAE; | 
					
						
							|  |  |  |     if ((so = getenv(s)) == NULL) | 
					
						
							|  |  |  |       return(FALSE); | 
					
						
							|  |  |  |     to = MkAtomTerm(Yap_LookupAtom(so)); | 
					
						
							|  |  |  |     return(Yap_unify_constant(ARG2,to)); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     Yap_Error(SYSTEM_ERROR, TermNil, | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	      "getenv not available in this configuration"); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     return (FALSE); | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   /* set a variable in YAP's environment */ | 
					
						
							|  |  |  |   static Int p_putenv( USES_REGS1 ) | 
					
						
							|  |  |  |   { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #if HAVE_PUTENV
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     Term t1 = Deref(ARG1), t2 = Deref(ARG2); | 
					
						
							|  |  |  |     char *s, *s2, *p0, *p; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (IsVarTerm(t1)) { | 
					
						
							|  |  |  |       Yap_Error(INSTANTIATION_ERROR, t1, | 
					
						
							|  |  |  | 		"first arg to putenv/2"); | 
					
						
							|  |  |  |       return(FALSE); | 
					
						
							|  |  |  |     } else if (!IsAtomTerm(t1)) { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_ATOM, t1, | 
					
						
							|  |  |  | 		"first arg to putenv/2"); | 
					
						
							|  |  |  |       return(FALSE); | 
					
						
							|  |  |  |     } else s = RepAtom(AtomOfTerm(t1))->StrOfAE; | 
					
						
							|  |  |  |     if (IsVarTerm(t2)) { | 
					
						
							|  |  |  |       Yap_Error(INSTANTIATION_ERROR, t1, | 
					
						
							|  |  |  | 		"second arg to putenv/2"); | 
					
						
							|  |  |  |       return(FALSE); | 
					
						
							|  |  |  |     } else if (!IsAtomTerm(t2)) { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_ATOM, t2, | 
					
						
							|  |  |  | 		"second arg to putenv/2"); | 
					
						
							|  |  |  |       return(FALSE); | 
					
						
							|  |  |  |     } else s2 = RepAtom(AtomOfTerm(t2))->StrOfAE; | 
					
						
							|  |  |  |     while (!(p0 = p = Yap_AllocAtomSpace(strlen(s)+strlen(s2)+3))) { | 
					
						
							|  |  |  |       if (!Yap_growheap(FALSE, MinHeapGap, NULL)) { | 
					
						
							|  |  |  | 	Yap_Error(OUT_OF_HEAP_ERROR, TermNil, LOCAL_ErrorMessage); | 
					
						
							|  |  |  | 	return FALSE; | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2007-02-13 11:26:17 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     while ((*p++ = *s++) != '\0'); | 
					
						
							|  |  |  |     p[-1] = '='; | 
					
						
							|  |  |  |     while ((*p++ = *s2++) != '\0'); | 
					
						
							|  |  |  |     if (putenv(p0) == 0) | 
					
						
							|  |  |  |       return TRUE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #if HAVE_STRERROR
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     Yap_Error(OPERATING_SYSTEM_ERROR, TermNil, | 
					
						
							|  |  |  | 	      "in putenv(%s)", strerror(errno), p0); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     Yap_Error(OPERATING_SYSTEM_ERROR, TermNil, | 
					
						
							|  |  |  | 	      "in putenv(%s)", p0); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     return FALSE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     Yap_Error(SYSTEM_ERROR, TermNil, | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	      "putenv not available in this configuration"); | 
					
						
							| 
									
										
										
										
											2007-02-13 11:26:17 +00:00
										 |  |  |     return FALSE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   /* wrapper for alarm system call */ | 
					
						
							| 
									
										
										
										
											2002-01-17 22:12:09 +00:00
										 |  |  | #if _MSC_VER || defined(__MINGW32__)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   static DWORD WINAPI | 
					
						
							|  |  |  |     DoTimerThread(LPVOID targ) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     Int *time = (Int *)targ; | 
					
						
							|  |  |  |     HANDLE htimer; | 
					
						
							|  |  |  |     LARGE_INTEGER liDueTime; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     htimer = CreateWaitableTimer(NULL, FALSE, NULL); | 
					
						
							|  |  |  |     liDueTime.QuadPart =  -10000000; | 
					
						
							|  |  |  |     liDueTime.QuadPart *=  time[0]; | 
					
						
							|  |  |  |     /* add time in usecs */ | 
					
						
							|  |  |  |     liDueTime.QuadPart -=  time[1]*10; | 
					
						
							|  |  |  |     /* 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()); | 
					
						
							|  |  |  |     Yap_signal (YAP_WINTIMER_SIGNAL); | 
					
						
							|  |  |  |     /* now, say what is going on */ | 
					
						
							|  |  |  |     Yap_PutValue(AtomAlarm, MkAtomTerm(AtomTrue)); | 
					
						
							|  |  |  |     ExitThread(1); | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  | #if _MSC_VER
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     return(0L); | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2002-01-21 20:07:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   static Int | 
					
						
							|  |  |  |     p_alarm( USES_REGS1 ) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     Term t = Deref(ARG1); | 
					
						
							|  |  |  |     Term t2 = Deref(ARG2); | 
					
						
							|  |  |  |     Int i1, i2; | 
					
						
							|  |  |  |     if (IsVarTerm(t)) { | 
					
						
							|  |  |  |       Yap_Error(INSTANTIATION_ERROR, t, "alarm/2"); | 
					
						
							|  |  |  |       return(FALSE); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!IsIntegerTerm(t)) { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_INTEGER, t, "alarm/2"); | 
					
						
							|  |  |  |       return(FALSE); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (IsVarTerm(t2)) { | 
					
						
							|  |  |  |       Yap_Error(INSTANTIATION_ERROR, t2, "alarm/2"); | 
					
						
							|  |  |  |       return(FALSE); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!IsIntegerTerm(t2)) { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_INTEGER, t2, "alarm/2"); | 
					
						
							|  |  |  |       return(FALSE); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     i1 = IntegerOfTerm(t); | 
					
						
							|  |  |  |     i2 = IntegerOfTerm(t2); | 
					
						
							|  |  |  |     if (i1 == 0 && i2 == 0) { | 
					
						
							| 
									
										
										
										
											2014-03-04 12:02:26 +00:00
										 |  |  | #if _WIN32
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       Yap_get_signal( YAP_WINTIMER_SIGNAL ); | 
					
						
							| 
									
										
										
										
											2014-03-04 12:02:26 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       Yap_get_signal( YAP_ALARM_SIGNAL ); | 
					
						
							| 
									
										
										
										
											2014-03-04 12:02:26 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #if _MSC_VER || defined(__MINGW32__)
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { | 
					
						
							|  |  |  |       Term tout; | 
					
						
							|  |  |  |       Int time[2]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       time[0] = i1; | 
					
						
							|  |  |  |       time[1] = i2; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (time[0] != 0 && time[1] != 0) { | 
					
						
							|  |  |  | 	DWORD dwThreadId; | 
					
						
							|  |  |  | 	HANDLE hThread; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	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) { | 
					
						
							|  |  |  | 	  Yap_WinError("trying to use alarm"); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2002-01-17 22:12:09 +00:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       tout = MkIntegerTerm(0); | 
					
						
							|  |  |  |       return Yap_unify(ARG3,tout) && Yap_unify(ARG4,MkIntTerm(0)); | 
					
						
							| 
									
										
										
										
											2002-01-17 22:12:09 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2008-02-12 21:50:58 +00:00
										 |  |  | #elif HAVE_SETITIMER && !SUPPORT_CONDOR
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { | 
					
						
							|  |  |  |       struct itimerval new, old; | 
					
						
							| 
									
										
										
										
											2007-05-20 23:00:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       new.it_interval.tv_sec = 0; | 
					
						
							|  |  |  |       new.it_interval.tv_usec = 0; | 
					
						
							|  |  |  |       new.it_value.tv_sec = i1; | 
					
						
							|  |  |  |       new.it_value.tv_usec = i2; | 
					
						
							|  |  |  |       if (setitimer(ITIMER_REAL, &new, &old) < 0) { | 
					
						
							| 
									
										
										
										
											2007-05-20 23:00:38 +00:00
										 |  |  | #if HAVE_STRERROR
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	Yap_Error(OPERATING_SYSTEM_ERROR, ARG1, "setitimer: %s", strerror(errno)); | 
					
						
							| 
									
										
										
										
											2007-05-20 23:00:38 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	Yap_Error(OPERATING_SYSTEM_ERROR, ARG1, "setitimer %d", errno); | 
					
						
							| 
									
										
										
										
											2007-05-20 23:00:38 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	return FALSE; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       return Yap_unify(ARG3,MkIntegerTerm(old.it_value.tv_sec)) && | 
					
						
							|  |  |  | 	Yap_unify(ARG4,MkIntegerTerm(old.it_value.tv_usec)); | 
					
						
							| 
									
										
										
										
											2007-05-20 23:00:38 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2008-02-12 21:50:58 +00:00
										 |  |  | #elif HAVE_ALARM && !SUPPORT_CONDOR
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { | 
					
						
							|  |  |  |       Int left; | 
					
						
							|  |  |  |       Term tout; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       left = alarm(i1); | 
					
						
							|  |  |  |       tout = MkIntegerTerm(left); | 
					
						
							|  |  |  |       return Yap_unify(ARG3,tout) && Yap_unify(ARG4,MkIntTerm(0)) ; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     /* not actually trying to set the alarm */ | 
					
						
							|  |  |  |     if (IntegerOfTerm(t) == 0) | 
					
						
							|  |  |  |       return TRUE; | 
					
						
							|  |  |  |     Yap_Error(SYSTEM_ERROR, TermNil, | 
					
						
							|  |  |  | 	      "alarm not available in this configuration"); | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2009-06-01 19:49:03 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  |   static Int | 
					
						
							|  |  |  |     p_virtual_alarm( USES_REGS1 ) | 
					
						
							| 
									
										
										
										
											2009-06-01 19:49:03 -05:00
										 |  |  |   { | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     Term t = Deref(ARG1); | 
					
						
							|  |  |  |     Term t2 = Deref(ARG2); | 
					
						
							|  |  |  |     if (IsVarTerm(t)) { | 
					
						
							|  |  |  |       Yap_Error(INSTANTIATION_ERROR, t, "alarm/2"); | 
					
						
							|  |  |  |       return(FALSE); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!IsIntegerTerm(t)) { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_INTEGER, t, "alarm/2"); | 
					
						
							|  |  |  |       return(FALSE); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (IsVarTerm(t2)) { | 
					
						
							|  |  |  |       Yap_Error(INSTANTIATION_ERROR, t2, "alarm/2"); | 
					
						
							|  |  |  |       return(FALSE); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!IsIntegerTerm(t2)) { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_INTEGER, t2, "alarm/2"); | 
					
						
							|  |  |  |       return(FALSE); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | #if _MSC_VER || defined(__MINGW32__)
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       Term tout; | 
					
						
							|  |  |  |       Int time[2]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       time[0] = IntegerOfTerm(t); | 
					
						
							|  |  |  |       time[1] = IntegerOfTerm(t2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (time[0] != 0 && time[1] != 0) { | 
					
						
							|  |  |  | 	DWORD dwThreadId; | 
					
						
							|  |  |  | 	HANDLE hThread; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	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) { | 
					
						
							|  |  |  | 	  Yap_WinError("trying to use alarm"); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-06-01 19:49:03 -05:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       tout = MkIntegerTerm(0); | 
					
						
							|  |  |  |       return Yap_unify(ARG3,tout) && Yap_unify(ARG4,MkIntTerm(0)); | 
					
						
							| 
									
										
										
										
											2009-06-01 19:49:03 -05:00
										 |  |  |     } | 
					
						
							|  |  |  | #elif HAVE_SETITIMER && !SUPPORT_CONDOR
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     { | 
					
						
							|  |  |  |       struct itimerval new, old; | 
					
						
							| 
									
										
										
										
											2009-06-01 19:49:03 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       new.it_interval.tv_sec = 0; | 
					
						
							|  |  |  |       new.it_interval.tv_usec = 0; | 
					
						
							|  |  |  |       new.it_value.tv_sec = IntegerOfTerm(t); | 
					
						
							|  |  |  |       new.it_value.tv_usec = IntegerOfTerm(t2); | 
					
						
							|  |  |  |       if (setitimer(ITIMER_VIRTUAL, &new, &old) < 0) { | 
					
						
							| 
									
										
										
										
											2009-06-01 19:49:03 -05:00
										 |  |  | #if HAVE_STRERROR
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	Yap_Error(OPERATING_SYSTEM_ERROR, ARG1, "setitimer: %s", strerror(errno)); | 
					
						
							| 
									
										
										
										
											2009-06-01 19:49:03 -05:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	Yap_Error(OPERATING_SYSTEM_ERROR, ARG1, "setitimer %d", errno); | 
					
						
							| 
									
										
										
										
											2009-06-01 19:49:03 -05:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	return FALSE; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       return Yap_unify(ARG3,MkIntegerTerm(old.it_value.tv_sec)) && | 
					
						
							|  |  |  | 	Yap_unify(ARG4,MkIntegerTerm(old.it_value.tv_usec)); | 
					
						
							| 
									
										
										
										
											2009-06-01 19:49:03 -05:00
										 |  |  |     } | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     /* not actually trying to set the alarm */ | 
					
						
							|  |  |  |     if (IntegerOfTerm(t) == 0) | 
					
						
							|  |  |  |       return TRUE; | 
					
						
							|  |  |  |     Yap_Error(SYSTEM_ERROR, TermNil, | 
					
						
							|  |  |  | 	      "virtual_alarm not available in this configuration"); | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							| 
									
										
										
										
											2009-06-01 19:49:03 -05:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2009-06-01 19:49:03 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #if HAVE_FPU_CONTROL_H
 | 
					
						
							|  |  |  | #include <fpu_control.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   /* by default Linux with glibc is IEEE compliant anyway..., but we will pretend it is not. */ | 
					
						
							|  |  |  |   static bool | 
					
						
							|  |  |  |     set_fpu_exceptions(bool flag) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     if (flag) { | 
					
						
							| 
									
										
										
										
											2014-10-14 01:13:31 +01:00
										 |  |  | #if HAVE_FESETEXCEPTFLAG
 | 
					
						
							|  |  |  |       fexcept_t excepts; | 
					
						
							|  |  |  |       return fesetexceptflag(&excepts, FE_DIVBYZERO| FE_UNDERFLOW|FE_OVERFLOW) == 0; | 
					
						
							|  |  |  | #elif HAVE_FEENABLEEXCEPT
 | 
					
						
							|  |  |  |       /* I shall ignore de-normalization and precision errors */ | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       feenableexcept(FE_DIVBYZERO| FE_INVALID|FE_OVERFLOW); | 
					
						
							| 
									
										
										
										
											2014-10-24 15:18:32 +01:00
										 |  |  | #elif _WIN32
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       // Enable zero-divide, overflow and underflow exception
 | 
					
						
							|  |  |  |       _controlfp_s(0, ~(_EM_ZERODIVIDE|_EM_UNDERFLOW|_EM_OVERFLOW), _MCW_EM); // Line B
 | 
					
						
							| 
									
										
										
										
											2014-10-14 01:13:31 +01:00
										 |  |  | #elif defined(__hpux)
 | 
					
						
							| 
									
										
										
										
											2002-06-13 18:24:04 +00:00
										 |  |  | # if HAVE_FESETTRAPENABLE
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       /* From HP-UX 11.0 onwards: */ | 
					
						
							| 
									
										
										
										
											2014-10-14 01:13:31 +01:00
										 |  |  |       fesettrapenable(FE_INVALID|FE_DIVBYZERO|FE_OVERFLOW|FE_UNDERFLOW); | 
					
						
							| 
									
										
										
										
											2002-06-13 18:24:04 +00:00
										 |  |  | # else
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       /*
 | 
					
						
							|  |  |  | 	Up until HP-UX 10.20: | 
					
						
							|  |  |  | 	FP_X_INV   invalid operation exceptions | 
					
						
							|  |  |  | 	FP_X_DZ    divide-by-zero exception | 
					
						
							|  |  |  | 	FP_X_OFL   overflow exception | 
					
						
							|  |  |  | 	FP_X_UFL   underflow exception | 
					
						
							|  |  |  | 	FP_X_IMP   imprecise (inexact result) | 
					
						
							|  |  |  | 	FP_X_CLEAR simply zero to clear all flags | 
					
						
							|  |  |  |       */ | 
					
						
							| 
									
										
										
										
											2014-10-14 01:13:31 +01:00
										 |  |  |       fpsetmask(FP_X_INV|FP_X_DZ|FP_X_OFL|FP_X_UFL); | 
					
						
							| 
									
										
										
										
											2002-06-13 18:24:04 +00:00
										 |  |  | # endif
 | 
					
						
							|  |  |  | #endif /* __hpux */
 | 
					
						
							| 
									
										
										
										
											2002-02-11 20:22:15 +00:00
										 |  |  | #if HAVE_FPU_CONTROL_H && i386 && defined(__GNUC__)
 | 
					
						
							| 
									
										
										
										
											2014-10-14 01:13:31 +01:00
										 |  |  |       /* I shall ignore denormalization and precision errors */ | 
					
						
							|  |  |  |       int v = _FPU_IEEE & ~(_FPU_MASK_IM|_FPU_MASK_ZM|_FPU_MASK_OM|_FPU_MASK_UM); | 
					
						
							|  |  |  |       _FPU_SETCW(v); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_FETESTEXCEPT
 | 
					
						
							| 
									
										
										
										
											2014-10-14 01:13:31 +01:00
										 |  |  |       feclearexcept(FE_ALL_EXCEPT); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2014-03-15 23:47:29 +00:00
										 |  |  | #ifdef HAVE_SIGFPE
 | 
					
						
							| 
									
										
										
										
											2014-10-14 01:13:31 +01:00
										 |  |  |       my_signal (SIGFPE, HandleMatherr); | 
					
						
							| 
									
										
										
										
											2014-01-19 21:15:05 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     } else { | 
					
						
							|  |  |  |       /* do IEEE arithmetic in the way the big boys do */ | 
					
						
							| 
									
										
										
										
											2014-10-14 01:13:31 +01:00
										 |  |  | #if HAVE_FESETEXCEPTFLAG
 | 
					
						
							|  |  |  |       fexcept_t excepts; | 
					
						
							|  |  |  |       return fesetexceptflag(&excepts, 0) == 0; | 
					
						
							|  |  |  | #elif HAVE_FEENABLEEXCEPT
 | 
					
						
							|  |  |  |       /* I shall ignore de-normalization and precision errors */ | 
					
						
							|  |  |  |       feenableexcept(0); | 
					
						
							| 
									
										
										
										
											2014-10-24 15:18:32 +01:00
										 |  |  | #elif _WIN32
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       // Enable zero-divide, overflow and underflow exception
 | 
					
						
							|  |  |  |       _controlfp_s(0, (_EM_ZERODIVIDE|_EM_UNDERFLOW|_EM_OVERFLOW), _MCW_EM); // Line B
 | 
					
						
							| 
									
										
										
										
											2014-10-14 01:13:31 +01:00
										 |  |  | #elif defined(__hpux)
 | 
					
						
							| 
									
										
										
										
											2002-06-13 18:24:04 +00:00
										 |  |  | # if HAVE_FESETTRAPENABLE
 | 
					
						
							| 
									
										
										
										
											2014-10-14 01:13:31 +01:00
										 |  |  |       fesettrapenable(FE_ALL_EXCEPT); | 
					
						
							| 
									
										
										
										
											2002-06-13 18:24:04 +00:00
										 |  |  | # else
 | 
					
						
							| 
									
										
										
										
											2014-10-14 01:13:31 +01:00
										 |  |  |       fpsetmask(FP_X_CLEAR); | 
					
						
							| 
									
										
										
										
											2002-06-13 18:24:04 +00:00
										 |  |  | # endif
 | 
					
						
							|  |  |  | #endif /* __hpux */
 | 
					
						
							| 
									
										
										
										
											2002-02-11 20:22:15 +00:00
										 |  |  | #if HAVE_FPU_CONTROL_H && i386 && defined(__GNUC__)
 | 
					
						
							| 
									
										
										
										
											2014-10-14 01:13:31 +01:00
										 |  |  |       /* this will probably not work in older releases of Linux */ | 
					
						
							|  |  |  |       int v = _FPU_IEEE; | 
					
						
							|  |  |  |       _FPU_SETCW(v); | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2014-03-15 23:47:29 +00:00
										 |  |  | #ifdef HAVE_SIGFPE
 | 
					
						
							| 
									
										
										
										
											2014-10-14 01:13:31 +01:00
										 |  |  |       my_signal (SIGFPE, SIG_IGN); | 
					
						
							| 
									
										
										
										
											2014-01-19 21:15:05 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     } | 
					
						
							|  |  |  |     return true; | 
					
						
							| 
									
										
										
										
											2002-02-04 16:12:54 +00:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   bool | 
					
						
							|  |  |  |     Yap_set_fpu_exceptions(bool flag) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     return set_fpu_exceptions(flag); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   static Int | 
					
						
							|  |  |  |     p_set_fpu_exceptions( USES_REGS1 ) { | 
					
						
							|  |  |  |     if (Deref(ARG1) == MkAtomTerm(AtomTrue)) { | 
					
						
							|  |  |  |       return set_fpu_exceptions(true); | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       return set_fpu_exceptions( false ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2005-03-13 06:26:13 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   static Int | 
					
						
							|  |  |  |     p_host_type( USES_REGS1 ) { | 
					
						
							|  |  |  |     Term out = MkAtomTerm(Yap_LookupAtom(HOST_ALIAS)); | 
					
						
							|  |  |  |     return(Yap_unify(out,ARG1)); | 
					
						
							| 
									
										
										
										
											2014-12-04 07:59:30 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  |   static Int | 
					
						
							|  |  |  |     p_yap_home( USES_REGS1 ) { | 
					
						
							|  |  |  |     Term out = MkAtomTerm(Yap_LookupAtom(YAP_ROOTDIR)); | 
					
						
							|  |  |  |     return(Yap_unify(out,ARG1)); | 
					
						
							| 
									
										
										
										
											2014-12-04 07:59:30 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  |   static Int | 
					
						
							|  |  |  |     p_yap_paths( USES_REGS1 ) { | 
					
						
							|  |  |  |     Term out1, out2, out3; | 
					
						
							|  |  |  |     const char *env_destdir = getenv("DESTDIR"); | 
					
						
							|  |  |  |     char destdir[YAP_FILENAME_MAX+1]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (env_destdir) { | 
					
						
							|  |  |  |       strncat(destdir, env_destdir, YAP_FILENAME_MAX ); | 
					
						
							|  |  |  |       strncat(destdir, "/" YAP_LIBDIR, YAP_FILENAME_MAX ); | 
					
						
							|  |  |  |       out1 = MkAtomTerm(Yap_LookupAtom(destdir)); | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       out1 = MkAtomTerm(Yap_LookupAtom(YAP_LIBDIR)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (env_destdir) { | 
					
						
							|  |  |  |       strncat(destdir, env_destdir, YAP_FILENAME_MAX ); | 
					
						
							|  |  |  |       strncat(destdir, "/" YAP_SHAREDIR, YAP_FILENAME_MAX ); | 
					
						
							|  |  |  |       out2 = MkAtomTerm(Yap_LookupAtom(destdir)); | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       out2 = MkAtomTerm(Yap_LookupAtom(YAP_SHAREDIR)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (env_destdir) { | 
					
						
							|  |  |  |       strncat(destdir, env_destdir, YAP_FILENAME_MAX ); | 
					
						
							|  |  |  |       strncat(destdir, "/" YAP_BINDIR, YAP_FILENAME_MAX ); | 
					
						
							|  |  |  |       out3 = MkAtomTerm(Yap_LookupAtom(destdir)); | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       out3 = MkAtomTerm(Yap_LookupAtom(YAP_BINDIR)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return(Yap_unify(out1,ARG1) && | 
					
						
							|  |  |  | 	   Yap_unify(out2,ARG2) && | 
					
						
							|  |  |  | 	   Yap_unify(out3,ARG3)); | 
					
						
							| 
									
										
										
										
											2014-03-04 12:02:26 +00:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   static Int | 
					
						
							|  |  |  |     p_log_event( USES_REGS1 ) { | 
					
						
							|  |  |  |     Term in = Deref(ARG1); | 
					
						
							|  |  |  |     Atom at; | 
					
						
							| 
									
										
										
										
											2014-06-22 17:35:05 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     if (IsVarTerm(in)) | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							|  |  |  |     if (!IsAtomTerm(in)) | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							|  |  |  |     at = AtomOfTerm( in ); | 
					
						
							| 
									
										
										
										
											2014-06-22 17:35:05 +01:00
										 |  |  | #if DEBUG
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     if (IsWideAtom(at) ) | 
					
						
							|  |  |  |       fprintf(stderr, "LOG %S\n", RepAtom(at)->WStrOfAE); | 
					
						
							|  |  |  |     else if (IsBlob(at)) | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |       fprintf(stderr, "LOG %s\n", RepAtom(at)->StrOfAE); | 
					
						
							| 
									
										
										
										
											2014-06-22 17:35:05 +01:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     if (IsWideAtom(at) || IsBlob(at)) | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							|  |  |  |     LOG(  " %s ",RepAtom(at)->StrOfAE); | 
					
						
							|  |  |  |     return TRUE; | 
					
						
							| 
									
										
										
										
											2014-06-22 17:35:05 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2014-06-22 17:35:05 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   static Int | 
					
						
							|  |  |  |     p_env_separator( USES_REGS1 ) { | 
					
						
							| 
									
										
										
										
											2005-10-28 17:38:50 +00:00
										 |  |  | #if defined(_WIN32)
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     return Yap_unify(MkIntegerTerm(';'),ARG1); | 
					
						
							| 
									
										
										
										
											2005-10-28 17:38:50 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     return Yap_unify(MkIntegerTerm(':'),ARG1); | 
					
						
							| 
									
										
										
										
											2005-10-28 17:38:50 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2005-10-28 17:38:50 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   /*
 | 
					
						
							|  |  |  |    * This is responsable for the initialization of all machine dependant | 
					
						
							|  |  |  |    * predicates | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   void | 
					
						
							|  |  |  |     Yap_InitSysbits (void) | 
					
						
							| 
									
										
										
										
											2002-01-23 02:28:31 +00:00
										 |  |  |   { | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | #if  __simplescalar__
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       char *pwd = getenv("PWD"); | 
					
						
							|  |  |  |       strncpy(GLOBAL_pwd,pwd,YAP_FILENAME_MAX); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2002-01-23 02:28:31 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     InitWTime (); | 
					
						
							|  |  |  |     InitRandom (); | 
					
						
							|  |  |  |     /* let the caller control signals as it sees fit */ | 
					
						
							|  |  |  |     InitSignals (); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   void | 
					
						
							|  |  |  |     Yap_InitTime( int wid ) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     InitTime( wid ); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2004-03-02 16:44:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   void | 
					
						
							|  |  |  |     Yap_ReInitWallTime (void) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     InitWTime(); | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  |     if (Yap_global->LastWtimePtr_ != NULL) | 
					
						
							|  |  |  |       Yap_FreeCodeSpace(Yap_global->LastWtimePtr_); | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     InitLastWtime(); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   static Int | 
					
						
							|  |  |  |     p_unix( USES_REGS1 ) | 
					
						
							|  |  |  |   { | 
					
						
							| 
									
										
										
										
											2007-09-27 15:25:34 +00:00
										 |  |  | #ifdef unix
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     return TRUE; | 
					
						
							| 
									
										
										
										
											2007-09-27 15:25:34 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #ifdef __unix__
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     return TRUE; | 
					
						
							| 
									
										
										
										
											2008-03-31 19:51:07 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #ifdef __APPLE__
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     return TRUE; | 
					
						
							| 
									
										
										
										
											2007-09-27 15:25:34 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     return FALSE; | 
					
						
							| 
									
										
										
										
											2007-09-27 15:25:34 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2008-03-31 19:51:07 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2007-09-27 15:25:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   static Int | 
					
						
							|  |  |  |     p_win32( USES_REGS1 ) | 
					
						
							|  |  |  |   { | 
					
						
							| 
									
										
										
										
											2007-09-27 15:25:34 +00:00
										 |  |  | #ifdef _WIN32
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     return TRUE; | 
					
						
							| 
									
										
										
										
											2007-09-27 15:25:34 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #ifdef __CYGWIN__
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     return TRUE; | 
					
						
							| 
									
										
										
										
											2007-09-27 15:25:34 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     return FALSE; | 
					
						
							| 
									
										
										
										
											2007-09-27 15:25:34 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2007-09-27 15:25:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-19 23:53:14 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   static Int | 
					
						
							|  |  |  |     p_enable_interrupts( USES_REGS1 ) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     LOCAL_InterruptsDisabled--; | 
					
						
							|  |  |  |     if (LOCAL_Signals && !LOCAL_InterruptsDisabled) { | 
					
						
							|  |  |  |       CreepFlag = Unsigned(LCL0); | 
					
						
							|  |  |  |       if ( !Yap_only_has_signal( YAP_CREEP_SIGNAL ) ) | 
					
						
							|  |  |  | 	EventFlag = Unsigned( LCL0 ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return TRUE; | 
					
						
							| 
									
										
										
										
											2009-05-21 00:38:35 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2009-05-19 23:53:14 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   static Int | 
					
						
							|  |  |  |     p_disable_interrupts( USES_REGS1 ) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     LOCAL_InterruptsDisabled++; | 
					
						
							|  |  |  |     CalculateStackGap( PASS_REGS1 ); | 
					
						
							|  |  |  |     return TRUE; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2009-05-19 23:53:14 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   static Int | 
					
						
							|  |  |  |     p_ld_path( USES_REGS1 ) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     return Yap_unify(ARG1,MkAtomTerm(Yap_LookupAtom(YAP_LIBDIR))); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2007-09-27 15:25:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   static Int | 
					
						
							|  |  |  |     p_address_bits( USES_REGS1 ) | 
					
						
							|  |  |  |   { | 
					
						
							| 
									
										
										
										
											2010-02-23 00:29:17 +00:00
										 |  |  | #if SIZEOF_INT_P==4
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     return Yap_unify(ARG1,MkIntTerm(32)); | 
					
						
							| 
									
										
										
										
											2010-02-23 00:29:17 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     return Yap_unify(ARG1,MkIntTerm(64)); | 
					
						
							| 
									
										
										
										
											2010-02-23 00:29:17 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2010-02-23 00:29:17 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-27 15:25:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-27 00:41:33 +00:00
										 |  |  | #ifdef _WIN32
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   /* This code is from SWI-Prolog by Jan Wielemaker */ | 
					
						
							| 
									
										
										
										
											2008-03-27 00:41:33 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define wstreq(s,q) (wcscmp((s), (q)) == 0)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   static HKEY | 
					
						
							|  |  |  |     reg_open_key(const wchar_t *which, int create) | 
					
						
							|  |  |  |   { HKEY key = HKEY_CURRENT_USER; | 
					
						
							|  |  |  |     DWORD disp; | 
					
						
							|  |  |  |     LONG rval; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     while(*which) | 
					
						
							|  |  |  |       { wchar_t buf[256]; | 
					
						
							|  |  |  | 	wchar_t *s; | 
					
						
							|  |  |  | 	HKEY tmp; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for(s=buf; *which && !(*which == '/' || *which == '\\'); ) | 
					
						
							|  |  |  | 	  *s++ = *which++; | 
					
						
							|  |  |  | 	*s = '\0'; | 
					
						
							|  |  |  | 	if ( *which ) | 
					
						
							|  |  |  | 	  which++; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if ( wstreq(buf, L"HKEY_CLASSES_ROOT") ) | 
					
						
							|  |  |  | 	  { key = HKEY_CLASSES_ROOT; | 
					
						
							|  |  |  | 	    continue; | 
					
						
							|  |  |  | 	  } else if ( wstreq(buf, L"HKEY_CURRENT_USER") ) | 
					
						
							|  |  |  | 	  { key = HKEY_CURRENT_USER; | 
					
						
							|  |  |  | 	    continue; | 
					
						
							|  |  |  | 	  } else if ( wstreq(buf, L"HKEY_LOCAL_MACHINE") ) | 
					
						
							|  |  |  | 	  { key = HKEY_LOCAL_MACHINE; | 
					
						
							|  |  |  | 	    continue; | 
					
						
							|  |  |  | 	  } else if ( wstreq(buf, L"HKEY_USERS") ) | 
					
						
							|  |  |  | 	  { key = HKEY_USERS; | 
					
						
							|  |  |  | 	    continue; | 
					
						
							|  |  |  | 	  } | 
					
						
							| 
									
										
										
										
											2008-03-27 00:41:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	if ( RegOpenKeyExW(key, buf, 0L, KEY_READ, &tmp) == ERROR_SUCCESS ) | 
					
						
							|  |  |  | 	  { RegCloseKey(key); | 
					
						
							|  |  |  | 	    key = tmp; | 
					
						
							|  |  |  | 	    continue; | 
					
						
							|  |  |  | 	  } | 
					
						
							| 
									
										
										
										
											2008-03-27 00:41:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 	if ( !create ) | 
					
						
							|  |  |  | 	  return NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	rval = RegCreateKeyExW(key, buf, 0, L"", 0, | 
					
						
							|  |  |  | 			       KEY_ALL_ACCESS, NULL, &tmp, &disp); | 
					
						
							|  |  |  | 	RegCloseKey(key); | 
					
						
							|  |  |  | 	if ( rval == ERROR_SUCCESS ) | 
					
						
							|  |  |  | 	  key = tmp; | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 	  return NULL; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return key; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2008-03-27 00:41:33 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define MAXREGSTRLEN 1024
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   static void | 
					
						
							|  |  |  |     recover_space(wchar_t *k, Atom At) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     if (At->WStrOfAE != k) | 
					
						
							|  |  |  |       Yap_FreeCodeSpace((char *)k); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2008-03-27 00:41:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   static wchar_t * | 
					
						
							|  |  |  |     WideStringFromAtom(Atom KeyAt USES_REGS) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     if (IsWideAtom(KeyAt)) { | 
					
						
							|  |  |  |       return KeyAt->WStrOfAE; | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       int len = strlen(KeyAt->StrOfAE); | 
					
						
							|  |  |  |       int sz = sizeof(wchar_t)*(len+1); | 
					
						
							|  |  |  |       char *chp = KeyAt->StrOfAE; | 
					
						
							|  |  |  |       wchar_t *kptr, *k; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       k = (wchar_t *)Yap_AllocCodeSpace(sz); | 
					
						
							|  |  |  |       while (k == NULL) { | 
					
						
							|  |  |  | 	if (!Yap_growheap(FALSE, sz, NULL)) { | 
					
						
							|  |  |  | 	  Yap_Error(OUT_OF_HEAP_ERROR, MkIntegerTerm(sz), "generating key in win_registry_get_value/3"); | 
					
						
							|  |  |  | 	  return FALSE; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       kptr = k; | 
					
						
							|  |  |  |       while ((*kptr++ = *chp++)); | 
					
						
							|  |  |  |       return k; | 
					
						
							| 
									
										
										
										
											2008-03-27 00:41:33 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   static Int | 
					
						
							|  |  |  |     p_win_registry_get_value( USES_REGS1 ) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     DWORD type; | 
					
						
							|  |  |  |     BYTE  data[MAXREGSTRLEN]; | 
					
						
							|  |  |  |     DWORD len = sizeof(data); | 
					
						
							|  |  |  |     wchar_t *k, *name; | 
					
						
							|  |  |  |     HKEY key; | 
					
						
							|  |  |  |     Term Key = Deref(ARG1); | 
					
						
							|  |  |  |     Term Name = Deref(ARG2); | 
					
						
							|  |  |  |     Atom KeyAt, NameAt; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (IsVarTerm(Key)) { | 
					
						
							|  |  |  |       Yap_Error(INSTANTIATION_ERROR,Key,"argument to win_registry_get_value unbound"); | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!IsAtomTerm(Key)) { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_ATOM,Key,"argument to win_registry_get_value"); | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     KeyAt = AtomOfTerm(Key); | 
					
						
							|  |  |  |     if (IsVarTerm(Name)) { | 
					
						
							|  |  |  |       Yap_Error(INSTANTIATION_ERROR,Key,"argument to win_registry_get_value unbound"); | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!IsAtomTerm(Name)) { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_ATOM,Key,"argument to win_registry_get_value"); | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     NameAt = AtomOfTerm(Name); | 
					
						
							| 
									
										
										
										
											2008-03-27 00:41:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     k = WideStringFromAtom(KeyAt PASS_REGS); | 
					
						
							|  |  |  |     if ( !(key=reg_open_key(k, FALSE)) ) { | 
					
						
							|  |  |  |       Yap_Error(EXISTENCE_ERROR_KEY, Key, "argument to win_registry_get_value"); | 
					
						
							| 
									
										
										
										
											2008-03-27 00:41:33 +00:00
										 |  |  |       recover_space(k, KeyAt); | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     name = WideStringFromAtom(NameAt PASS_REGS); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if ( RegQueryValueExW(key, name, NULL, &type, data, &len) == ERROR_SUCCESS ) { | 
					
						
							|  |  |  |       RegCloseKey(key); | 
					
						
							|  |  |  |       switch(type) { | 
					
						
							|  |  |  |       case REG_SZ: | 
					
						
							|  |  |  | 	recover_space(k, KeyAt); | 
					
						
							|  |  |  | 	recover_space(name, NameAt); | 
					
						
							|  |  |  | 	((wchar_t *)data)[len] = '\0'; | 
					
						
							|  |  |  | 	return Yap_unify(MkAtomTerm(Yap_LookupMaybeWideAtom((wchar_t *)data)),ARG3); | 
					
						
							|  |  |  |       case REG_DWORD: | 
					
						
							|  |  |  | 	recover_space(k, KeyAt); | 
					
						
							|  |  |  | 	recover_space(name, NameAt); | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 	  DWORD *d = (DWORD *)data; | 
					
						
							|  |  |  | 	  return Yap_unify(MkIntegerTerm((Int)d[0]),ARG3); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  |       default: | 
					
						
							|  |  |  | 	recover_space(k, KeyAt); | 
					
						
							|  |  |  | 	recover_space(name, NameAt); | 
					
						
							|  |  |  | 	return FALSE; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     recover_space(k, KeyAt); | 
					
						
							|  |  |  |     recover_space(name, NameAt); | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							| 
									
										
										
										
											2008-03-27 00:41:33 +00:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   char * | 
					
						
							|  |  |  |     Yap_RegistryGetString(char *name) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     DWORD type; | 
					
						
							|  |  |  |     BYTE  data[MAXREGSTRLEN]; | 
					
						
							|  |  |  |     DWORD len = sizeof(data); | 
					
						
							|  |  |  |     HKEY key; | 
					
						
							|  |  |  |     char *ptr; | 
					
						
							|  |  |  |     int i; | 
					
						
							| 
									
										
										
										
											2008-03-27 00:41:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-21 03:09:49 -05:00
										 |  |  | #if SIZEOF_INT_P == 8
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     if ( !(key=reg_open_key(L"HKEY_LOCAL_MACHINE/SOFTWARE/YAP/Prolog64", FALSE)) ) { | 
					
						
							|  |  |  |       return NULL; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-06-21 03:09:49 -05:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     if ( !(key=reg_open_key(L"HKEY_LOCAL_MACHINE/SOFTWARE/YAP/Prolog", FALSE)) ) { | 
					
						
							|  |  |  |       return NULL; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-06-21 03:09:49 -05:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     if ( RegQueryValueEx(key, name, NULL, &type, data, &len) == ERROR_SUCCESS ) { | 
					
						
							|  |  |  |       RegCloseKey(key); | 
					
						
							|  |  |  |       switch(type) { | 
					
						
							|  |  |  |       case REG_SZ: | 
					
						
							|  |  |  | 	ptr = malloc(len+2); | 
					
						
							|  |  |  | 	if (!ptr) | 
					
						
							|  |  |  | 	  return NULL; | 
					
						
							|  |  |  | 	for (i=0; i<= len; i++) | 
					
						
							|  |  |  | 	  ptr[i] = data[i]; | 
					
						
							|  |  |  | 	ptr[len+1] = '\0'; | 
					
						
							|  |  |  | 	return ptr; | 
					
						
							|  |  |  |       default: | 
					
						
							| 
									
										
										
										
											2008-03-27 00:41:33 +00:00
										 |  |  | 	return NULL; | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2008-03-27 00:41:33 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     return NULL; | 
					
						
							| 
									
										
										
										
											2008-03-27 00:41:33 +00:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   void | 
					
						
							|  |  |  |     Yap_InitSysPreds(void) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     CACHE_REGS | 
					
						
							|  |  |  |       Term cm = CurrentModule; | 
					
						
							| 
									
										
										
										
											2006-05-17 18:38:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     /* can only do after heap is initialised */ | 
					
						
							|  |  |  |     InitLastWtime(); | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  |     Yap_InitCPred ("srandom", 1, Srandom, SafePredFlag); | 
					
						
							| 
									
										
										
										
											2014-05-28 01:12:51 +01:00
										 |  |  | #if HAVE_RANDOM
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     Yap_InitCPred ("init_random_state", 3, p_init_random_state, SafePredFlag); | 
					
						
							|  |  |  |     Yap_InitCPred ("set_random_state", 2, p_set_random_state, SafePredFlag); | 
					
						
							|  |  |  |     Yap_InitCPred ("release_random_state", 1, p_release_random_state, SafePredFlag); | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  |     Yap_InitCPred ("$absolute_file_name", 2, absolute_file_name, SafePredFlag|SyncPredFlag); | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     Yap_InitCPred ("log_event", 1, p_log_event, SafePredFlag|SyncPredFlag); | 
					
						
							|  |  |  |     Yap_InitCPred ("sh", 0, p_sh, SafePredFlag|SyncPredFlag); | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  |     Yap_InitCPred ("$shell", 1, p_shell, SafePredFlag|SyncPredFlag); | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     Yap_InitCPred ("system", 1, p_system, SafePredFlag|SyncPredFlag|UserCPredFlag); | 
					
						
							|  |  |  |     Yap_InitCPred ("rename", 2, p_mv, SafePredFlag|SyncPredFlag); | 
					
						
							|  |  |  |     Yap_InitCPred ("$yap_home", 1, p_yap_home, SafePredFlag); | 
					
						
							|  |  |  |     Yap_InitCPred ("$yap_paths", 3, p_yap_paths, SafePredFlag); | 
					
						
							|  |  |  |     Yap_InitCPred ("$dir_separator", 1, p_dir_sp, SafePredFlag); | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  |     Yap_InitCPred ("libraries_directories",2, libraries_directories, 0); | 
					
						
							|  |  |  |     Yap_InitCPred ("system_library", 1, system_library, 0); | 
					
						
							|  |  |  |     Yap_InitCPred ("commons_library", 1, commons_library, 0); | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     Yap_InitCPred ("$alarm", 4, p_alarm, SafePredFlag|SyncPredFlag); | 
					
						
							|  |  |  |     Yap_InitCPred ("$getenv", 2, p_getenv, SafePredFlag); | 
					
						
							|  |  |  |     Yap_InitCPred ("$putenv", 2, p_putenv, SafePredFlag|SyncPredFlag); | 
					
						
							|  |  |  |     Yap_InitCPred ("$set_fpu_exceptions",1, p_set_fpu_exceptions, SafePredFlag|SyncPredFlag); | 
					
						
							|  |  |  |     Yap_InitCPred ("$host_type", 1, p_host_type, SafePredFlag|SyncPredFlag); | 
					
						
							|  |  |  |     Yap_InitCPred ("$env_separator", 1, p_env_separator, SafePredFlag); | 
					
						
							|  |  |  |     Yap_InitCPred ("$unix", 0, p_unix, SafePredFlag); | 
					
						
							|  |  |  |     Yap_InitCPred ("$win32", 0, p_win32, SafePredFlag); | 
					
						
							|  |  |  |     Yap_InitCPred ("$ld_path", 1, p_ld_path, SafePredFlag); | 
					
						
							|  |  |  |     Yap_InitCPred ("$address_bits", 1, p_address_bits, SafePredFlag); | 
					
						
							|  |  |  |     Yap_InitCPred ("$expand_file_name", 2, p_expand_file_name, SyncPredFlag); | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  |     Yap_InitCPred ("working_directory", 2,working_directory, SyncPredFlag); | 
					
						
							|  |  |  |     Yap_InitCPred ("prolog_to_os_filename", 2, prolog_to_os_filename, SyncPredFlag); | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     Yap_InitCPred ("$fpe_error", 0, p_fpe_error, 0); | 
					
						
							| 
									
										
										
										
											2008-03-27 00:41:33 +00:00
										 |  |  | #ifdef _WIN32
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     Yap_InitCPred ("win_registry_get_value", 3, p_win_registry_get_value,0); | 
					
						
							| 
									
										
										
										
											2008-03-27 00:41:33 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     CurrentModule = HACKS_MODULE; | 
					
						
							|  |  |  |     Yap_InitCPred ("virtual_alarm", 4, p_virtual_alarm, SafePredFlag|SyncPredFlag); | 
					
						
							|  |  |  |     Yap_InitCPred ("enable_interrupts", 0, p_enable_interrupts, SafePredFlag); | 
					
						
							|  |  |  |     Yap_InitCPred ("disable_interrupts", 0, p_disable_interrupts, SafePredFlag); | 
					
						
							|  |  |  |     CurrentModule = OPERATING_SYSTEM_MODULE; | 
					
						
							|  |  |  |     Yap_InitCPred ("true_file_name", 2, p_true_file_name, SyncPredFlag); | 
					
						
							|  |  |  |     Yap_InitCPred ("true_file_name", 3, p_true_file_name3, SyncPredFlag); | 
					
						
							|  |  |  |     CurrentModule = cm; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef VAX
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   /* avoid longjmp botch */ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   int vax_absmi_fp; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   typedef struct | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   { | 
					
						
							|  |  |  |     int eh; | 
					
						
							|  |  |  |     int flgs; | 
					
						
							|  |  |  |     int ap; | 
					
						
							|  |  |  |     int fp; | 
					
						
							|  |  |  |     int pc; | 
					
						
							|  |  |  |     int dummy1; | 
					
						
							|  |  |  |     int dummy2; | 
					
						
							|  |  |  |     int dummy3; | 
					
						
							|  |  |  |     int oldfp; | 
					
						
							|  |  |  |     int dummy4; | 
					
						
							|  |  |  |     int dummy5; | 
					
						
							|  |  |  |     int dummy6; | 
					
						
							|  |  |  |     int oldpc; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   *VaxFramePtr; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   VaxFixFrame (dummy) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     int maxframes = 100; | 
					
						
							|  |  |  |     VaxFramePtr fp = (VaxFramePtr) (((int *) &dummy) - 6); | 
					
						
							|  |  |  |     while (--maxframes) | 
					
						
							|  |  |  |       { | 
					
						
							|  |  |  | 	fp = (VaxFramePtr) fp->fp; | 
					
						
							|  |  |  | 	if (fp->flgs == 0) | 
					
						
							|  |  |  | 	  { | 
					
						
							|  |  |  | 	    if (fp->oldfp >= ®S[6] && fp->oldfp < ®S[REG_SIZE]) | 
					
						
							|  |  |  | 	      fp->oldfp = vax_absmi_fp; | 
					
						
							|  |  |  | 	    return; | 
					
						
							|  |  |  | 	  } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | #if defined(_WIN32)
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-02-22 06:12:18 +00:00
										 |  |  | #include <windows.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   int WINAPI win_yap(HANDLE, DWORD, LPVOID); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   int WINAPI win_yap(HANDLE hinst, DWORD reason, LPVOID reserved) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     switch (reason) | 
					
						
							|  |  |  |       { | 
					
						
							|  |  |  |       case DLL_PROCESS_ATTACH: | 
					
						
							|  |  |  | 	break; | 
					
						
							|  |  |  |       case DLL_PROCESS_DETACH: | 
					
						
							|  |  |  | 	break; | 
					
						
							|  |  |  |       case DLL_THREAD_ATTACH: | 
					
						
							|  |  |  | 	break; | 
					
						
							|  |  |  |       case DLL_THREAD_DETACH: | 
					
						
							|  |  |  | 	break; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     return 1; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2002-02-08 22:19:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-02-12 17:09:17 +00:00
										 |  |  | #if (defined(YAPOR) || defined(THREADS)) && !defined(USE_PTHREAD_LOCKING)
 | 
					
						
							| 
									
										
										
										
											2002-10-21 22:14:29 +00:00
										 |  |  | #ifdef sparc
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   void rw_lock_voodoo(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   void | 
					
						
							|  |  |  |     rw_lock_voodoo(void) { | 
					
						
							|  |  |  |     /* code taken from the Linux kernel, it handles shifting between locks */ | 
					
						
							|  |  |  |     /* Read/writer locks, as usual this is overly clever to make it as fast as possible. */ | 
					
						
							|  |  |  |     /* caches... */ | 
					
						
							|  |  |  |     __asm__ __volatile__( | 
					
						
							|  |  |  | 			 "___rw_read_enter_spin_on_wlock:\n" | 
					
						
							|  |  |  | 			 "	orcc	%g2, 0x0, %g0\n" | 
					
						
							|  |  |  | 			 "	be,a	___rw_read_enter\n" | 
					
						
							|  |  |  | 			 "	 ldstub	[%g1 + 3], %g2\n" | 
					
						
							|  |  |  | 			 "	b	___rw_read_enter_spin_on_wlock\n" | 
					
						
							|  |  |  | 			 "	 ldub	[%g1 + 3], %g2\n" | 
					
						
							|  |  |  | 			 "___rw_read_exit_spin_on_wlock:\n" | 
					
						
							|  |  |  | 			 "	orcc	%g2, 0x0, %g0\n" | 
					
						
							|  |  |  | 			 "	be,a	___rw_read_exit\n" | 
					
						
							|  |  |  | 			 "	 ldstub	[%g1 + 3], %g2\n" | 
					
						
							|  |  |  | 			 "	b	___rw_read_exit_spin_on_wlock\n" | 
					
						
							|  |  |  | 			 "	 ldub	[%g1 + 3], %g2\n" | 
					
						
							|  |  |  | 			 "___rw_write_enter_spin_on_wlock:\n" | 
					
						
							|  |  |  | 			 "	orcc	%g2, 0x0, %g0\n" | 
					
						
							|  |  |  | 			 "	be,a	___rw_write_enter\n" | 
					
						
							|  |  |  | 			 "	 ldstub	[%g1 + 3], %g2\n" | 
					
						
							|  |  |  | 			 "	b	___rw_write_enter_spin_on_wlock\n" | 
					
						
							|  |  |  | 			 "	 ld	[%g1], %g2\n" | 
					
						
							|  |  |  | 			 "\n" | 
					
						
							|  |  |  | 			 "	.globl	___rw_read_enter\n" | 
					
						
							|  |  |  | 			 "___rw_read_enter:\n" | 
					
						
							|  |  |  | 			 "	orcc	%g2, 0x0, %g0\n" | 
					
						
							|  |  |  | 			 "	bne,a	___rw_read_enter_spin_on_wlock\n" | 
					
						
							|  |  |  | 			 "	 ldub	[%g1 + 3], %g2\n" | 
					
						
							|  |  |  | 			 "	ld	[%g1], %g2\n" | 
					
						
							|  |  |  | 			 "	add	%g2, 1, %g2\n" | 
					
						
							|  |  |  | 			 "	st	%g2, [%g1]\n" | 
					
						
							|  |  |  | 			 "	retl\n" | 
					
						
							|  |  |  | 			 "	 mov	%g4, %o7\n" | 
					
						
							|  |  |  | 			 "	.globl	___rw_read_exit\n" | 
					
						
							|  |  |  | 			 "___rw_read_exit:\n" | 
					
						
							|  |  |  | 			 "	orcc	%g2, 0x0, %g0\n" | 
					
						
							|  |  |  | 			 "	bne,a	___rw_read_exit_spin_on_wlock\n" | 
					
						
							|  |  |  | 			 "	 ldub	[%g1 + 3], %g2\n" | 
					
						
							|  |  |  | 			 "	ld	[%g1], %g2\n" | 
					
						
							|  |  |  | 			 "	sub	%g2, 0x1ff, %g2\n" | 
					
						
							|  |  |  | 			 "	st	%g2, [%g1]\n" | 
					
						
							|  |  |  | 			 "	retl\n" | 
					
						
							|  |  |  | 			 "	 mov	%g4, %o7\n" | 
					
						
							|  |  |  | 			 "	.globl	___rw_write_enter\n" | 
					
						
							|  |  |  | 			 "___rw_write_enter:\n" | 
					
						
							|  |  |  | 			 "	orcc	%g2, 0x0, %g0\n" | 
					
						
							|  |  |  | 			 "	bne	___rw_write_enter_spin_on_wlock\n" | 
					
						
							|  |  |  | 			 "	 ld	[%g1], %g2\n" | 
					
						
							|  |  |  | 			 "	andncc	%g2, 0xff, %g0\n" | 
					
						
							|  |  |  | 			 "	bne,a	___rw_write_enter_spin_on_wlock\n" | 
					
						
							|  |  |  | 			 "	 stb	%g0, [%g1 + 3]\n" | 
					
						
							|  |  |  | 			 "	retl\n" | 
					
						
							|  |  |  | 			 "	 mov	%g4, %o7\n" | 
					
						
							|  |  |  | 			 ); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2002-10-21 22:14:29 +00:00
										 |  |  | #endif /* sparc */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* YAPOR || THREADS */
 | 
					
						
							| 
									
										
										
										
											2015-01-04 23:58:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |   //@
 |