| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | /*************************************************************************
 | 
					
						
							| 
									
										
										
										
											2017-09-23 02:17:55 +01: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-11-05 16:47:11 +00:00
										 |  |  | #include "sysbits.h"
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | /// File Error Handler
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static void FileError(yap_error_number type, Term where, const char *format, | 
					
						
							|  |  |  |                       ...) { | 
					
						
							| 
									
										
										
										
											2016-02-11 15:35:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   if (trueLocalPrologFlag(FILEERRORS_FLAG)) { | 
					
						
							|  |  |  |     va_list ap; | 
					
						
							| 
									
										
										
										
											2016-02-11 15:35:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     va_start(ap, format); | 
					
						
							|  |  |  |     /* now build the error string */ | 
					
						
							|  |  |  |     Yap_Error(type, TermNil, format, ap); | 
					
						
							|  |  |  |     va_end(ap); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-02-11 15:35:34 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | 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 Int p_getenv(USES_REGS1); | 
					
						
							|  |  |  | static Int p_putenv(USES_REGS1); | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | static Term do_glob(const char *spec, bool ok_to); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #ifdef MACYAP
 | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | /* #define signal	skel_signal */ | 
					
						
							|  |  |  | #endif /* MACYAP */
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static const char *expandVars(const char *spec, char *u); | 
					
						
							| 
									
										
										
										
											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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-31 10:33:32 +00:00
										 |  |  | #ifdef _WIN32
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | void Yap_WinError(char *yap_error) { | 
					
						
							|  |  |  |   char msg[256]; | 
					
						
							|  |  |  |   /* Error, we could not read time */ | 
					
						
							|  |  |  |   FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS, | 
					
						
							|  |  |  |                 NULL, GetLastError(), MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), | 
					
						
							| 
									
										
										
										
											2017-02-20 14:21:46 +00:00
										 |  |  |                 msg, 255, NULL); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   Yap_Error(SYSTEM_ERROR_OPERATING_SYSTEM, 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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | #define is_valid_env_char(C)                                                   \
 | 
					
						
							|  |  |  |   (((C) >= 'a' && (C) <= 'z') || ((C) >= 'A' && (C) <= 'Z') || (C) == '_') | 
					
						
							| 
									
										
										
										
											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
 | 
					
						
							| 
									
										
										
										
											2017-12-10 01:22:45 +00:00
										 |  |  | bool Yap_isDirectory(const char *FileName) { | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-31 09:55:50 -05:00
										 |  |  |   VFS_t *vfs; | 
					
						
							|  |  |  |   if ((vfs = vfs_owner(FileName))) { | 
					
						
							| 
									
										
										
										
											2017-12-10 01:22:45 +00:00
										 |  |  |     return vfs->isdir(vfs, FileName); | 
					
						
							| 
									
										
										
										
											2016-07-31 09:55:50 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2017-02-20 14:21:46 +00:00
										 |  |  | #ifdef _WIN32
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   DWORD dwAtts = GetFileAttributes(FileName); | 
					
						
							|  |  |  |   if (dwAtts == INVALID_FILE_ATTRIBUTES) | 
					
						
							|  |  |  |     return false; | 
					
						
							|  |  |  |   return (dwAtts & FILE_ATTRIBUTE_DIRECTORY); | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | #elif HAVE_LSTAT
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   struct stat buf; | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   if (lstat(FileName, &buf) == -1) { | 
					
						
							|  |  |  |     /* return an error number */ | 
					
						
							| 
									
										
										
										
											2016-02-11 15:35:34 +00:00
										 |  |  |     return false; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   return S_ISDIR(buf.st_mode); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |   Yap_Error(SYSTEM_ERROR_INTERNAL, TermNil, | 
					
						
							|  |  |  |             "stat not available in this configuration"); | 
					
						
							|  |  |  |   return false; | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2014-11-09 12:06:40 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-22 23:55:50 +01:00
										 |  |  | Int exists_directory(USES_REGS1) { | 
					
						
							|  |  |  |     int lvl = push_text_stack(); | 
					
						
							|  |  |  |     const char *path = Yap_AbsoluteFile(Yap_TextTermToText(Deref(ARG1) PASS_REGS),true); | 
					
						
							|  |  |  |     bool rc = Yap_isDirectory(path); | 
					
						
							|  |  |  |     pop_text_stack(lvl); | 
					
						
							|  |  |  |     return rc; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  | bool Yap_Exists(const char *f) { | 
					
						
							| 
									
										
										
										
											2018-06-22 23:55:50 +01:00
										 |  |  |     VFS_t *vfs; | 
					
						
							|  |  |  |     f = Yap_VFAlloc(f); | 
					
						
							|  |  |  |     if ((vfs = vfs_owner(f))) { | 
					
						
							|  |  |  |         return vfs->exists(vfs, f); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  | #if _WIN32
 | 
					
						
							| 
									
										
										
										
											2018-06-22 23:55:50 +01:00
										 |  |  |     if (_access(f, 0) == 0) | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  |     return true; | 
					
						
							|  |  |  |   if (errno == EINVAL) { | 
					
						
							|  |  |  |     Yap_Error(SYSTEM_ERROR_INTERNAL, TermNil, "bad flags to access"); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  |   return false; | 
					
						
							|  |  |  | #elif HAVE_ACCESS
 | 
					
						
							| 
									
										
										
										
											2018-06-22 23:55:50 +01:00
										 |  |  |     if (access(f, F_OK) == 0) { | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (errno == EINVAL) { | 
					
						
							|  |  |  |         Yap_Error(SYSTEM_ERROR_INTERNAL, TermNil, "bad flags to access"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return false; | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2018-06-22 23:55:50 +01:00
										 |  |  |     Yap_Error(SYSTEM_ERROR_INTERNAL, TermNil, | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |             "access not available in this configuration"); | 
					
						
							|  |  |  |   return false; | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static int dir_separator(int ch) { | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | #ifdef MAC
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return (ch == ':'); | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | #elif ATARI || _MSC_VER
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return (ch == '\\'); | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | #elif defined(__MINGW32__) || defined(__CYGWIN__)
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return (ch == '\\' || ch == '/'); | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return (ch == '/'); | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | 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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-01 10:42:10 +00:00
										 |  |  | bool Yap_IsAbsolutePath(const char *p0, bool expand) { | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   // verify first if expansion is needed: ~/ or $HOME/
 | 
					
						
							| 
									
										
										
										
											2017-12-01 10:42:10 +00:00
										 |  |  |   const char *p = p0; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   bool nrc; | 
					
						
							| 
									
										
										
										
											2017-12-10 01:22:45 +00:00
										 |  |  |   if (expand) { | 
					
						
							|  |  |  |     p = expandVars(p0, LOCAL_FileNameBuf); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | #if _WIN32 || __MINGW32__
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   nrc = !PathIsRelative(p); | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   nrc = (p[0] == '/'); | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return nrc; | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | #define isValidEnvChar(C)                                                      \
 | 
					
						
							|  |  |  |   (((C) >= 'a' && (C) <= 'z') || ((C) >= 'A' && (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.
 | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  | static const char *PlExpandVars(const char *source, const char *root) { | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2017-11-27 13:36:19 +00:00
										 |  |  |   int lvl = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   const char *src = source; | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |   char *result = Malloc(YAP_FILENAME_MAX + 1); | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   if (strlen(source) >= YAP_FILENAME_MAX) { | 
					
						
							|  |  |  |     Yap_Error(SYSTEM_ERROR_OPERATING_SYSTEM, 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++; | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | #if defined(_WIN32)
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |       s = getenv("HOMEDRIVE"); | 
					
						
							|  |  |  |       if (s != NULL) | 
					
						
							|  |  |  |         strncpy(result, getenv("HOMEDRIVE"), YAP_FILENAME_MAX); | 
					
						
							|  |  |  | // s = getenv("HOMEPATH");
 | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |       s = getenv("HOME"); | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |       if (s != NULL) | 
					
						
							|  |  |  |         strncpy(result, s, YAP_FILENAME_MAX); | 
					
						
							|  |  |  |       strcat(result, src); | 
					
						
							| 
									
										
										
										
											2017-11-27 13:36:19 +00:00
										 |  |  |       result = pop_output_text_stack(lvl, result); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |       return result; | 
					
						
							|  |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | #if HAVE_GETPWNAM
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |       struct passwd *user_passwd; | 
					
						
							|  |  |  |       char *res = result; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       src++; | 
					
						
							|  |  |  |       while (!dir_separator((*res = *src)) && *res != '\0') | 
					
						
							|  |  |  |         res++, src++; | 
					
						
							|  |  |  |       res[0] = '\0'; | 
					
						
							|  |  |  |       if ((user_passwd = getpwnam(result)) == NULL) { | 
					
						
							|  |  |  |         FileError(SYSTEM_ERROR_OPERATING_SYSTEM, | 
					
						
							|  |  |  |                   MkAtomTerm(Yap_LookupAtom(source)), | 
					
						
							|  |  |  |                   "User %s does not exist in %s", result, source); | 
					
						
							| 
									
										
										
										
											2017-11-27 13:36:19 +00:00
										 |  |  |         pop_text_stack(lvl); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |         return NULL; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       strncpy(result, user_passwd->pw_dir, YAP_FILENAME_MAX); | 
					
						
							|  |  |  |       strcat(result, src); | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |       FileError( | 
					
						
							|  |  |  |           SYSTEM_ERROR_OPERATING_SYSTEM, MkAtomTerm(Yap_LookupAtom(source)), | 
					
						
							|  |  |  |           "User %s cannot be found in %s, missing getpwnam", result, source); | 
					
						
							|  |  |  |       return NULL; | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-02-11 15:32:42 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2017-11-27 13:36:19 +00:00
										 |  |  |     result = pop_output_text_stack(lvl, result); | 
					
						
							| 
									
										
										
										
											2016-02-11 15:35:34 +00:00
										 |  |  |     return result; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   // do VARIABLE expansion
 | 
					
						
							|  |  |  |   else if (source[0] == '$') { | 
					
						
							|  |  |  |     /* follow SICStus expansion rules */ | 
					
						
							|  |  |  |     char v[YAP_FILENAME_MAX + 1]; | 
					
						
							|  |  |  |     int ch; | 
					
						
							|  |  |  |     char *s, *res; | 
					
						
							|  |  |  |     src = source + 1; | 
					
						
							|  |  |  |     if (src[0] == '{') { | 
					
						
							|  |  |  |       res = v; | 
					
						
							|  |  |  |       src++; | 
					
						
							|  |  |  |       while ((*res = (ch = *src++)) && isValidEnvChar(ch) && ch != '}') { | 
					
						
							|  |  |  |         res++; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       if (ch == '}') { | 
					
						
							|  |  |  |         // {...}
 | 
					
						
							|  |  |  |         // done
 | 
					
						
							|  |  |  |         res[0] = '\0'; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       res = v; | 
					
						
							|  |  |  |       while ((*res = (ch = *src++)) && isValidEnvChar(ch) && ch != '}') { | 
					
						
							|  |  |  |         res++; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       src--; | 
					
						
							|  |  |  |       res[0] = '\0'; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if ((s = (char *)getenv(v))) { | 
					
						
							|  |  |  |       strcpy(result, s); | 
					
						
							|  |  |  |       strcat(result, src); | 
					
						
							|  |  |  |     } else | 
					
						
							|  |  |  |       strcpy(result, src); | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     size_t tocp = strlen(src); | 
					
						
							|  |  |  |     if (root) { | 
					
						
							|  |  |  |       tocp = strlen(root) + 1; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (tocp > YAP_FILENAME_MAX) { | 
					
						
							|  |  |  |       Yap_Error(SYSTEM_ERROR_OPERATING_SYSTEM, MkStringTerm(src), | 
					
						
							|  |  |  |                 "path too long"); | 
					
						
							| 
									
										
										
										
											2017-11-27 13:36:19 +00:00
										 |  |  |       pop_text_stack(lvl); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |       return NULL; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2017-12-01 10:42:10 +00:00
										 |  |  |     if (root && !Yap_IsAbsolutePath(source, false)) { | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |       strncpy(result, root, YAP_FILENAME_MAX); | 
					
						
							| 
									
										
										
										
											2016-07-31 09:55:50 -05:00
										 |  |  |       if (root[strlen(root) - 1] != '/') | 
					
						
							|  |  |  |         strncat(result, "/", YAP_FILENAME_MAX); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |       strncat(result, source, YAP_FILENAME_MAX); | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       strncpy(result, source, strlen(src) + 1); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2017-11-27 13:36:19 +00:00
										 |  |  |   result = pop_output_text_stack(lvl, result); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return result; | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  | #if _WIN32
 | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | // straightforward conversion from Unix style to WIN style
 | 
					
						
							|  |  |  | // check cygwin path.cc for possible improvements
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | 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'; | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  |     return s; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (s0[0] == '/' && s0[1] == '/' && isalpha(s0[2]) && s0[3] == '/') { | 
					
						
							|  |  |  |     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; | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static char *OsPath(const char *p, char *buf) { return (char *)p; } | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static char *PrologPath(const char *Y, char *X) { return (char *)Y; } | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #if _WIN32
 | 
					
						
							|  |  |  | #define HAVE_BASENAME 1
 | 
					
						
							|  |  |  | #define HAVE_REALPATH 1
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-21 17:41:00 +00:00
										 |  |  | extern char *virtual_cwd; | 
					
						
							| 
									
										
										
										
											2017-11-30 01:14:26 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-10 01:22:45 +00:00
										 |  |  | bool Yap_ChDir(const char *path) { | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   bool rc = false; | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |   int lvl = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-22 23:55:50 +01:00
										 |  |  |     const char *qpath = Yap_AbsoluteFile(path, true); | 
					
						
							| 
									
										
										
										
											2018-06-25 13:44:09 +01:00
										 |  |  |   //__android_log_print(ANDROID_LOG_INFO, "YAPDroid", "chdir %s", path);
 | 
					
						
							| 
									
										
										
										
											2016-07-31 09:55:50 -05:00
										 |  |  |   VFS_t *v; | 
					
						
							| 
									
										
										
										
											2018-06-22 23:55:50 +01:00
										 |  |  |   if ((v = vfs_owner(qpath))) { | 
					
						
							|  |  |  |     rc = v->chdir(v, (qpath)); | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |     pop_text_stack(lvl); | 
					
						
							|  |  |  |     return rc; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  | #if _WIN32
 | 
					
						
							|  |  |  |   rc = true; | 
					
						
							| 
									
										
										
										
											2016-04-18 16:41:30 +01:00
										 |  |  |   if (qpath != NULL && qpath[0] && | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  |       (rc = (SetCurrentDirectory(qpath) != 0)) == 0) { | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     Yap_WinError("SetCurrentDirectory failed"); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   rc = (chdir(qpath) == 0); | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |   pop_text_stack(lvl); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return rc; | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  | static char *close_path(char *b0, char *o0, char *o) { | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |   if (b0[0] == '\0') { | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  |     return o; | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |   } else if (!strcmp(b0, "..")) { | 
					
						
							|  |  |  |     while (o-- > o0) { | 
					
						
							|  |  |  |       if (dir_separator(*o)) { | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  |         break; | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |   } else if (strcmp(b0, ".") != 0) { | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  |     *o++ = '/'; | 
					
						
							|  |  |  |     strcpy(o, b0); | 
					
						
							|  |  |  |     o += strlen(b0); | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   return o; | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  | static char *clean_path(const char *path) { | 
					
						
							|  |  |  |   const char *p, *p0; | 
					
						
							|  |  |  |   int lvl = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-25 13:44:09 +01:00
										 |  |  |   //__android_log_print(ANDROID_LOG_INFO, "YAPDroid ", " looking at %s", path);
 | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |   char *o0 = Malloc(FILENAME_MAX + 1), *o = o0; | 
					
						
							|  |  |  |   int ch; | 
					
						
							|  |  |  |   char *b0 = Malloc(FILENAME_MAX + 1), *b = b0; | 
					
						
							|  |  |  |   p = p0 = path; | 
					
						
							|  |  |  |   while ((ch = *p++)) { | 
					
						
							|  |  |  |     if (dir_separator(ch)) { | 
					
						
							|  |  |  |       if (b == b0) { | 
					
						
							|  |  |  |         o = o0; | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  |         b[0] = '\0'; | 
					
						
							|  |  |  |         o = close_path(b0, o0, o); | 
					
						
							|  |  |  |         b = b0; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       *b++ = ch; | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (!dir_separator(p[-1])) { | 
					
						
							|  |  |  |     b[0] = '\0'; | 
					
						
							|  |  |  |     o = close_path(b0, o0, o); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (o == o0) | 
					
						
							|  |  |  |     *o++ = '/'; | 
					
						
							|  |  |  |   *o = '\0'; | 
					
						
							| 
									
										
										
										
											2018-06-25 13:44:09 +01:00
										 |  |  | //  __android_log_print(ANDROID_LOG_INFO, "YAPDroid ", " %s at %s, %p-%p", p0, o0,
 | 
					
						
							|  |  |  | //                      o, o0);
 | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |   return pop_output_text_stack(lvl, o0); | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static const char *myrealpath(const char *path USES_REGS) { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-10 01:22:45 +00:00
										 |  |  |   int lvl = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  |   VFS_t *v; | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |   char *out, *o; | 
					
						
							|  |  |  |   if (Yap_IsAbsolutePath(path, true)) { | 
					
						
							|  |  |  |     o = clean_path(path); | 
					
						
							|  |  |  |     return pop_output_text_stack(lvl, o); | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |   } else { | 
					
						
							|  |  |  |     out = Malloc(FILENAME_MAX + 1); | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  |     Yap_getcwd(out, FILENAME_MAX); | 
					
						
							|  |  |  |     strcat(out, "/"); | 
					
						
							|  |  |  |     strcat(out, path); | 
					
						
							|  |  |  |     o = clean_path(out); | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |     if ((v = vfs_owner(o))) { | 
					
						
							|  |  |  |       return pop_output_text_stack(lvl, o); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2017-12-10 01:22:45 +00:00
										 |  |  | #if _WIN32
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   DWORD retval = 0; | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   // notice that the file does not need to exist
 | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  |   retval = GetFullPathName(path, YAP_FILENAME_MAX, o, NULL); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   if (retval == 0) { | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |     pop_text_stack(lvl); | 
					
						
							|  |  |  |     Yap_WinError("Generating a full path name for a file"); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     return NULL; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  |   return pop_output_text_stack(lvl, o); | 
					
						
							| 
									
										
										
										
											2016-02-11 15:35:34 +00:00
										 |  |  | #elif HAVE_REALPATH
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   { | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  |     char *rc = realpath(path, o); | 
					
						
							| 
									
										
										
										
											2016-02-11 15:32:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     if (rc) { | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |       return pop_output_text_stack(lvl, rc); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     // rc = NULL;
 | 
					
						
							|  |  |  |     if (errno == ENOENT || errno == EACCES) { | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  |       char *base = Malloc(FILENAME_MAX + 1); | 
					
						
							|  |  |  |       strncpy(base, path, FILENAME_MAX); | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |       char *p = base + strlen(base); | 
					
						
							|  |  |  |       while (p > base && !dir_separator(*--p)) | 
					
						
							|  |  |  |         ; | 
					
						
							|  |  |  |       if (p == base) | 
					
						
							|  |  |  |         p[1] = '\0'; | 
					
						
							|  |  |  |       else | 
					
						
							|  |  |  |         p[0] = '\0'; | 
					
						
							|  |  |  |       char *tmp = Malloc(FILENAME_MAX + 1); | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  |       rc = realpath(base, tmp); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |       if (rc) { | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  |         // base may have been destroyed
 | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |         char *b = base + strlen(base); | 
					
						
							|  |  |  |         while (b > base && !dir_separator(*--b)) | 
					
						
							|  |  |  |           ; | 
					
						
							|  |  |  |         if (b[0] && !dir_separator(b[0])) | 
					
						
							|  |  |  |           b++; | 
					
						
							|  |  |  |         size_t e = strlen(rc); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |         size_t bs = strlen(b); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-18 16:41:30 +01:00
										 |  |  |         if (rc != out && rc != base) { | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  |           rc = Realloc(rc, e + bs + 2); | 
					
						
							| 
									
										
										
										
											2016-04-18 16:41:30 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-02-11 15:35:34 +00:00
										 |  |  | #if _WIN32
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |         if (rc[e - 1] != '\\' && rc[e - 1] != '/') { | 
					
						
							|  |  |  |           rc[e] = '\\'; | 
					
						
							|  |  |  |           rc[e + 1] = '\0'; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |         if (rc[e - 1] != '/') { | 
					
						
							|  |  |  |           rc[e] = '/'; | 
					
						
							|  |  |  |           rc[e + 1] = '\0'; | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  |         strcat(rc, b); | 
					
						
							| 
									
										
										
										
											2017-12-10 01:22:45 +00:00
										 |  |  |         rc = pop_output_text_stack(lvl, rc); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |         return rc; | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2017-12-10 01:22:45 +00:00
										 |  |  |   pop_text_stack(lvl); | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  |   return path; | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static const char *expandVars(const char *spec, char *u) { | 
					
						
							|  |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | #if _WIN32 || defined(__MINGW32__)
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   char *out; | 
					
						
							| 
									
										
										
										
											2015-11-09 11:31:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   // first pass, remove Unix style stuff
 | 
					
						
							| 
									
										
										
										
											2018-02-07 11:24:05 +00:00
										 |  |  |   if (spec == NULL || (out = unix2win(spec, u, YAP_FILENAME_MAX)) == NULL) | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     return NULL; | 
					
						
							|  |  |  |   spec = u; | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   bool ok_to = LOCAL_PrologMode && !(LOCAL_PrologMode & BootMode); | 
					
						
							|  |  |  |   if (ok_to) { | 
					
						
							|  |  |  |     Term t = do_glob(spec, true); | 
					
						
							|  |  |  |     if (IsPairTerm(t)) | 
					
						
							|  |  |  |       return RepAtom(AtomOfTerm(HeadOfTerm(t)))->StrOfAE; | 
					
						
							|  |  |  |     return NULL; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return spec; | 
					
						
							| 
									
										
										
										
											2015-11-09 11:31:58 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-31 10:33:32 +00:00
										 |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2015-11-09 11:31:58 +00:00
										 |  |  |  * generate absolute path, if ok first expand SICStus Prolog style | 
					
						
							| 
									
										
										
										
											2016-01-31 10:33:32 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * @param[in]  spec the file path, including `~` and `$`. | 
					
						
							|  |  |  |  * @param[in]  ok where to process `~` and `$`. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  |  * @return tmp, or NULL, in malloced memory | 
					
						
							| 
									
										
										
										
											2016-01-31 10:33:32 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  | const char *Yap_AbsoluteFile(const char *spec, bool ok) { | 
					
						
							| 
									
										
										
										
											2016-04-12 16:04:33 +01:00
										 |  |  |   const char *rc; | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  |   const char *spec1; | 
					
						
							|  |  |  |   const char *spec2; | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |   int lvl = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-07 11:24:05 +00:00
										 |  |  |   /// spec gothe original spec;
 | 
					
						
							|  |  |  |   /// rc0 may be an outout buffer
 | 
					
						
							|  |  |  |   /// rc1 the internal buffer
 | 
					
						
							|  |  |  |   ///
 | 
					
						
							|  |  |  |   /// PlExpandVars
 | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #if _WIN32
 | 
					
						
							|  |  |  |   char rc2[YAP_FILENAME_MAX]; | 
					
						
							| 
									
										
										
										
											2016-04-18 16:41:30 +01:00
										 |  |  |   if ((rc = unix2win(spec, rc2, YAP_FILENAME_MAX)) == NULL) { | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     return NULL; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  |   spec1 = rc; | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |   spec1 = spec; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |   /// spec gothe original spec;
 | 
					
						
							|  |  |  |   /// rc1 the internal buffer
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   if (ok) { | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  |     const char *q = PlExpandVars(spec1, NULL); | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  |     if (!q) | 
					
						
							|  |  |  |       spec2 = spec1; | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |       spec2 = q; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  |     spec2 = spec1; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  |   rc = myrealpath(spec2 PASS_REGS); | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |   return pop_output_text_stack(lvl, rc); | 
					
						
							| 
									
										
										
										
											2015-11-09 11:31:58 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2015-11-05 16:47:52 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static Term | 
					
						
							| 
									
										
										
										
											2017-09-23 02:17:55 +01:00
										 |  |  | /* Expand the string for the program to run.  */ | 
					
						
							|  |  |  | do_glob(const char *spec, bool glob_vs_wordexp) { | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2016-02-13 03:11:25 +00:00
										 |  |  |   if (spec == NULL) { | 
					
						
							|  |  |  |     return TermNil; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  | #if _WIN32
 | 
					
						
							| 
									
										
										
										
											2016-07-31 09:55:50 -05:00
										 |  |  |   char u[YAP_FILENAME_MAX + 1]; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   { | 
					
						
							|  |  |  |     WIN32_FIND_DATA find; | 
					
						
							|  |  |  |     HANDLE hFind; | 
					
						
							|  |  |  |     CELL *dest; | 
					
						
							|  |  |  |     Term tf; | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  |     char drive[_MAX_DRIVE]; | 
					
						
							|  |  |  |     char dir[_MAX_DIR]; | 
					
						
							|  |  |  |     char fname[_MAX_FNAME]; | 
					
						
							|  |  |  |     char ext[_MAX_EXT]; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-18 16:41:30 +01:00
										 |  |  |     _splitpath(spec, drive, dir, fname, ext); | 
					
						
							|  |  |  |     _makepath(u, drive, dir, fname, ext); | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  |     // first pass, remove Unix style stuff
 | 
					
						
							|  |  |  |     hFind = FindFirstFile(u, &find); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     if (hFind == INVALID_HANDLE_VALUE) { | 
					
						
							|  |  |  |       return TermNil; | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       tf = AbsPair(HR); | 
					
						
							| 
									
										
										
										
											2016-04-18 16:41:30 +01:00
										 |  |  |       _makepath(u, drive, dir, find.cFileName, NULL); | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  |       HR[0] = MkAtomTerm(Yap_LookupAtom(u)); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |       HR[1] = TermNil; | 
					
						
							|  |  |  |       dest = HR + 1; | 
					
						
							|  |  |  |       HR += 2; | 
					
						
							|  |  |  |       while (FindNextFile(hFind, &find)) { | 
					
						
							|  |  |  |         *dest = AbsPair(HR); | 
					
						
							| 
									
										
										
										
											2016-04-18 16:41:30 +01:00
										 |  |  |         _makepath(u, drive, dir, find.cFileName, NULL); | 
					
						
							|  |  |  |         HR[0] = MkAtomTerm(Yap_LookupAtom(u)); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |         HR[1] = TermNil; | 
					
						
							|  |  |  |         dest = HR + 1; | 
					
						
							|  |  |  |         HR += 2; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       FindClose(hFind); | 
					
						
							| 
									
										
										
										
											2015-11-05 16:47:52 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     return tf; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-06-22 23:55:50 +01:00
										 |  |  | #elif __ANDROID__
 | 
					
						
							|  |  |  |      return MkPairTerm(MkAtomTerm(Yap_LookupAtom(spec)), TermNil); | 
					
						
							| 
									
										
										
										
											2015-11-05 16:47:52 +00:00
										 |  |  | #elif HAVE_WORDEXP || HAVE_GLOB
 | 
					
						
							| 
									
										
										
										
											2016-07-31 09:55:50 -05:00
										 |  |  |   char u[YAP_FILENAME_MAX + 1]; | 
					
						
							|  |  |  |   const char *espec = u; | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  |   strncpy(u, spec, sizeof(u)); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   /* Expand the string for the program to run.  */ | 
					
						
							|  |  |  |   size_t pathcount; | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | #if HAVE_GLOB
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   glob_t gresult; | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_WORDEXP
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   wordexp_t wresult; | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_GLOB || HAVE_WORDEXP
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   char **ss = NULL; | 
					
						
							|  |  |  |   int flags = 0, j; | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   if (glob_vs_wordexp) { | 
					
						
							| 
									
										
										
										
											2015-11-05 16:47:52 +00:00
										 |  |  | #if HAVE_GLOB
 | 
					
						
							| 
									
										
										
										
											2016-01-31 18:48:07 -08:00
										 |  |  | #ifdef GLOB_NOCHECK
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     flags = GLOB_NOCHECK; | 
					
						
							| 
									
										
										
										
											2016-01-31 18:48:07 -08:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     flags = 0; | 
					
						
							| 
									
										
										
										
											2016-01-31 18:48:07 -08:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef GLOB_BRACE
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     flags |= GLOB_BRACE | GLOB_TILDE; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |     switch (glob(espec, flags, NULL, &gresult)) { | 
					
						
							|  |  |  |     case 0: /* Successful.  */ | 
					
						
							|  |  |  |       ss = gresult.gl_pathv; | 
					
						
							|  |  |  |       pathcount = gresult.gl_pathc; | 
					
						
							|  |  |  |       if (pathcount) { | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     case GLOB_NOMATCH: | 
					
						
							|  |  |  |       globfree(&gresult); | 
					
						
							|  |  |  |       { return TermNil; } | 
					
						
							|  |  |  |     case GLOB_ABORTED: | 
					
						
							|  |  |  |       PlIOError(SYSTEM_ERROR_OPERATING_SYSTEM, ARG1, "glob aborted: %sn", | 
					
						
							|  |  |  |                 strerror(errno)); | 
					
						
							|  |  |  |       globfree(&gresult); | 
					
						
							|  |  |  |       return TermNil; | 
					
						
							|  |  |  |     case GLOB_NOSPACE: | 
					
						
							|  |  |  |       Yap_Error(RESOURCE_ERROR_HEAP, ARG1, "glob ran out of space: %sn", | 
					
						
							|  |  |  |                 strerror(errno)); | 
					
						
							|  |  |  |       globfree(&gresult); | 
					
						
							|  |  |  |       return TermNil; | 
					
						
							|  |  |  |     /* If the error was WRDE_NOSPACE,
 | 
					
						
							|  |  |  |      then perhaps part of the result was allocated.  */ | 
					
						
							|  |  |  |     default: /* Some other error.  */ | 
					
						
							|  |  |  |       return TermNil; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2015-11-05 16:47:52 +00:00
										 |  |  | #if HAVE_WORDEXP
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     int rc; | 
					
						
							|  |  |  |     memset(&wresult, 0, sizeof(wresult)); | 
					
						
							|  |  |  |     switch ((rc = wordexp(espec, &wresult, flags))) { | 
					
						
							|  |  |  |     case 0: /* Successful.  */ | 
					
						
							|  |  |  |       ss = wresult.we_wordv; | 
					
						
							|  |  |  |       pathcount = wresult.we_wordc; | 
					
						
							|  |  |  |       if (pathcount) { | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  |         Term t; | 
					
						
							|  |  |  |         t = MkAtomTerm(Yap_LookupAtom(expandVars(espec, NULL))); | 
					
						
							|  |  |  |         wordfree(&wresult); | 
					
						
							|  |  |  |         return MkPairTerm(t, TermNil); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     case WRDE_NOSPACE: | 
					
						
							|  |  |  |       /* If the error was WRDE_NOSPACE,
 | 
					
						
							|  |  |  |        then perhaps part of the result was allocated.  */ | 
					
						
							|  |  |  |       Yap_Error(RESOURCE_ERROR_HEAP, ARG1, "wordexp ran out of space: %s", | 
					
						
							|  |  |  |                 strerror(errno)); | 
					
						
							|  |  |  |       wordfree(&wresult); | 
					
						
							|  |  |  |       return TermNil; | 
					
						
							|  |  |  |     default: /* Some other error.  */ | 
					
						
							|  |  |  |       PlIOError(SYSTEM_ERROR_OPERATING_SYSTEM, ARG1, "wordexp failed: %s", | 
					
						
							|  |  |  |                 strerror(errno)); | 
					
						
							|  |  |  |       wordfree(&wresult); | 
					
						
							|  |  |  |       return TermNil; | 
					
						
							| 
									
										
										
										
											2016-02-11 15:35:34 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   const char *tmp; | 
					
						
							|  |  |  |   Term tf = TermNil; | 
					
						
							|  |  |  |   for (j = 0; j < pathcount; j++) { | 
					
						
							|  |  |  |     const char *s = ss[pathcount - (j + 1)]; | 
					
						
							|  |  |  |     tmp = s; | 
					
						
							|  |  |  |     // if (!exists(s))
 | 
					
						
							|  |  |  |     //  continue;
 | 
					
						
							|  |  |  |     Atom a = Yap_LookupAtom(tmp); | 
					
						
							|  |  |  |     tf = MkPairTerm(MkAtomTerm(a), tf); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-11-05 16:47:52 +00:00
										 |  |  | #if HAVE_GLOB
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   if (glob_vs_wordexp) | 
					
						
							|  |  |  |     globfree(&gresult); | 
					
						
							| 
									
										
										
										
											2015-11-05 16:47:52 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_WORDEXP
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   if (!glob_vs_wordexp) | 
					
						
							|  |  |  |     wordfree(&wresult); | 
					
						
							| 
									
										
										
										
											2016-01-31 10:33:32 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return tf; | 
					
						
							| 
									
										
										
										
											2016-01-31 10:33:32 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   // just use basic
 | 
					
						
							| 
									
										
										
										
											2016-07-31 09:55:50 -05:00
										 |  |  |   return MkPairTerm(MkAtomTerm(Yap_LookupAtom(spec)), TermNil); | 
					
						
							| 
									
										
										
										
											2015-11-05 16:47:52 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * @pred prolog_expanded_file_system_path( +PrologPath, +ExpandVars, -OSPath ) | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Apply basic transformations to paths, and conidtionally apply | 
					
						
							|  |  |  |  * traditional SICStus-style variable expansion. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param PrologPath the source, may be atom or string | 
					
						
							|  |  |  |  * @param ExpandVars expand initial occurrence of ~ or $ | 
					
						
							|  |  |  |  * @param Prefix add this path before _PrologPath_ | 
					
						
							|  |  |  |  * @param OSPath pathname. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @return | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-04-14 12:00:09 +01:00
										 |  |  | static Int real_path(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   Term t1 = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  |   const char *cmd, *rc0; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   if (IsAtomTerm(t1)) { | 
					
						
							|  |  |  |     cmd = RepAtom(AtomOfTerm(t1))->StrOfAE; | 
					
						
							|  |  |  |   } else if (IsStringTerm(t1)) { | 
					
						
							|  |  |  |     cmd = StringOfTerm(t1); | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     return false; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  | #if _WIN32
 | 
					
						
							| 
									
										
										
										
											2016-04-18 16:41:30 +01:00
										 |  |  |   char cmd2[YAP_FILENAME_MAX + 1]; | 
					
						
							| 
									
										
										
										
											2016-05-10 08:33:44 +01:00
										 |  |  |   char *rc; | 
					
						
							| 
									
										
										
										
											2016-04-18 16:41:30 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |   if ((rc = unix2win(cmd, cmd2, YAP_FILENAME_MAX)) == NULL) { | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     return false; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  |   cmd = rc; | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |   int lvl = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  |   rc0 = myrealpath(cmd PASS_REGS); | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  |   if (!rc0) { | 
					
						
							|  |  |  |     PlIOError(SYSTEM_ERROR_OPERATING_SYSTEM, ARG1, NULL); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-05-30 11:25:28 +01:00
										 |  |  |   bool out = Yap_unify(MkAtomTerm(Yap_LookupAtom(rc0)), ARG2); | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |   pop_output_text_stack(lvl, rc0); | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |   return out; | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | #define EXPAND_FILENAME_DEFS()                                                 \
 | 
					
						
							|  |  |  |   PAR("parameter_expansion", isatom, EXPAND_FILENAME_PARAMETER_EXPANSION)      \ | 
					
						
							|  |  |  |   , PAR("commands", booleanFlag, EXPAND_FILENAME_COMMANDS),                    \ | 
					
						
							|  |  |  |       PAR(NULL, ok, EXPAND_FILENAME_END) | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define PAR(x, y, z) z
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef enum expand_filename_enum_choices { | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   EXPAND_FILENAME_DEFS() | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | } expand_filename_enum_choices_t; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #undef PAR
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define PAR(x, y, z)                                                           \
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   { x, y, z } | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | static const param_t expand_filename_defs[] = {EXPAND_FILENAME_DEFS()}; | 
					
						
							|  |  |  | #undef PAR
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Term do_expand_file_name(Term t1, Term opts USES_REGS) { | 
					
						
							|  |  |  |   xarg *args; | 
					
						
							|  |  |  |   expand_filename_enum_choices_t i; | 
					
						
							|  |  |  |   bool use_system_expansion = true; | 
					
						
							| 
									
										
										
										
											2016-05-30 11:25:28 +01:00
										 |  |  |   const char *tmpe = NULL; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   const char *spec; | 
					
						
							|  |  |  |   Term tf; | 
					
						
							| 
									
										
										
										
											2016-02-28 19:32:55 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   if (IsVarTerm(t1)) { | 
					
						
							|  |  |  |     Yap_Error(INSTANTIATION_ERROR, t1, NULL); | 
					
						
							|  |  |  |     return TermNil; | 
					
						
							|  |  |  |   } else if (IsAtomTerm(t1)) { | 
					
						
							|  |  |  |     spec = AtomTermName(t1); | 
					
						
							|  |  |  |   } else if (IsStringTerm(t1)) { | 
					
						
							|  |  |  |     spec = StringOfTerm(t1); | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     Yap_Error(TYPE_ERROR_ATOM, t1, NULL); | 
					
						
							|  |  |  |     return TermNil; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  | #if _WIN32
 | 
					
						
							| 
									
										
										
										
											2016-07-31 09:55:50 -05:00
										 |  |  |   char *rc; | 
					
						
							|  |  |  |   char cmd2[YAP_FILENAME_MAX + 1]; | 
					
						
							| 
									
										
										
										
											2016-04-18 16:41:30 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-31 09:55:50 -05:00
										 |  |  |   if ((rc = unix2win(spec, cmd2, YAP_FILENAME_MAX)) == NULL) { | 
					
						
							|  |  |  |     return false; | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-07-31 09:55:50 -05:00
										 |  |  |   spec = rc; | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-04-18 16:41:30 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-14 11:27:43 +01:00
										 |  |  |   args = Yap_ArgListToVector( | 
					
						
							|  |  |  |       opts, expand_filename_defs, | 
					
						
							|  |  |  |       EXPAND_FILENAME_END,DOMAIN_ERROR_EXPAND_FILENAME_OPTION); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   if (args == NULL) { | 
					
						
							|  |  |  |     return TermNil; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-05-30 11:25:28 +01:00
										 |  |  |   tmpe = NULL; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   for (i = 0; i < EXPAND_FILENAME_END; i++) { | 
					
						
							|  |  |  |     if (args[i].used) { | 
					
						
							|  |  |  |       Term t = args[i].tvalue; | 
					
						
							|  |  |  |       switch (i) { | 
					
						
							|  |  |  |       case EXPAND_FILENAME_PARAMETER_EXPANSION: | 
					
						
							|  |  |  |         if (t == TermProlog) { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:25:28 +01:00
										 |  |  |           tmpe = expandVars(spec, LOCAL_FileNameBuf); | 
					
						
							|  |  |  |           if (tmpe == NULL) { | 
					
						
							|  |  |  |             free(args); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |             return TermNil; | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2016-05-30 11:25:28 +01:00
										 |  |  |           spec = tmpe; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |         } else if (t == TermTrue) { | 
					
						
							|  |  |  |           use_system_expansion = true; | 
					
						
							|  |  |  |         } else if (t == TermFalse) { | 
					
						
							|  |  |  |           use_system_expansion = false; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |       case EXPAND_FILENAME_COMMANDS: | 
					
						
							|  |  |  |         if (!use_system_expansion) { | 
					
						
							|  |  |  |           use_system_expansion = true; | 
					
						
							|  |  |  | #if 0 // def WRDE_NOCMD
 | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  |                     if (t == TermFalse) { | 
					
						
							|  |  |  |                         flags = WRDE_NOCMD; | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |       case EXPAND_FILENAME_END: | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-05-30 11:25:28 +01:00
										 |  |  |   free(args); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   if (!use_system_expansion) { | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  |     const char *o = expandVars(spec, NULL); | 
					
						
							|  |  |  |     if (!o) | 
					
						
							|  |  |  |       return false; | 
					
						
							| 
									
										
										
										
											2016-05-30 11:25:28 +01:00
										 |  |  |     tf = MkPairTerm(MkAtomTerm(Yap_LookupAtom(o)), TermNil); | 
					
						
							|  |  |  | #if _WIN32
 | 
					
						
							|  |  |  |     if (o != cmd2) | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       freeBuffer(o); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     tf = do_glob(spec, true); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (tmpe | 
					
						
							|  |  |  | #if _WIN32
 | 
					
						
							|  |  |  |       && tmpe != cmd2 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2017-10-02 08:58:51 +01:00
										 |  |  |   ) { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:25:28 +01:00
										 |  |  |     freeBuffer(tmpe); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   return tf; | 
					
						
							| 
									
										
										
										
											2015-11-05 16:47:52 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-18 22:10:40 +00:00
										 |  |  | /* @pred expand_file_name( +Pattern, -ListOfPaths) is det
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | This builtin receives a pattern and expands it into a list of files. | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   In Unix-like systems, YAP applies glob to expand patterns such as '*', '.', | 
					
						
							|  |  |  | and '?'. Further variable expansion | 
					
						
							|  |  |  | may also happen. glob is shell-dependent: som   Yap_InitCPred | 
					
						
							|  |  |  | ("absolute_file_system_path", 2, absolute_file_system_path, 0); | 
					
						
							| 
									
										
										
										
											2016-02-18 22:10:40 +00:00
										 |  |  |     Yap_InitCPred ("real_path", 2, prolog_realpath, 0); | 
					
						
							|  |  |  |     Yap_InitCPred ("true_file_name", 2, | 
					
						
							|  |  |  |                    true_file_name, SyncPredFlag); | 
					
						
							|  |  |  |     Yap_InitCPred ("true_file_name", 3, true_file_name3, SyncPredFlag); | 
					
						
							|  |  |  | e shells allow command execution and brace-expansion. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int expand_file_name(USES_REGS1) { | 
					
						
							|  |  |  |   Term tf = do_expand_file_name(Deref(ARG1), TermNil PASS_REGS); | 
					
						
							|  |  |  |   if (tf == 0) | 
					
						
							|  |  |  |     return false; | 
					
						
							|  |  |  |   return Yap_unify(tf, ARG2); | 
					
						
							| 
									
										
										
										
											2015-11-05 16:47:52 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int expand_file_name3(USES_REGS1) { | 
					
						
							|  |  |  |   Term tf = do_expand_file_name(Deref(ARG1), Deref(ARG2) PASS_REGS); | 
					
						
							|  |  |  |   return Yap_unify(tf, ARG3); | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |        static char *canoniseFileName( char *path) { | 
					
						
							|  |  |  |        #if HAVE_REALPATH && HAVE_BASENAME
 | 
					
						
							|  |  |  |        #if _WIN32 || defined(__MINGW32__)
 | 
					
						
							|  |  |  |          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; | 
					
						
							|  |  |  |        #endif
 | 
					
						
							|  |  |  |          char *rc; | 
					
						
							|  |  |  |          if (tmp == NULL) return NULL; | 
					
						
							|  |  |  |          rc = myrealpath(path); | 
					
						
							|  |  |  |        #if _WIN32 || defined(__MINGW32__)
 | 
					
						
							|  |  |  |          freeBuffer(o); | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  |   return rc; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  | */ | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int absolute_file_system_path(USES_REGS1) { | 
					
						
							|  |  |  |   Term t = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2017-09-26 15:15:15 +01:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2017-10-02 08:58:51 +01:00
										 |  |  |   const char *text = Yap_TextTermToText(t); | 
					
						
							|  |  |  |   const char *fp; | 
					
						
							|  |  |  |   bool rc; | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   if (text == NULL) { | 
					
						
							| 
									
										
										
										
											2017-09-26 15:15:15 +01:00
										 |  |  |     pop_text_stack(l); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     return false; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  |   if (!(fp = Yap_AbsoluteFile(text, true))) { | 
					
						
							| 
									
										
										
										
											2017-09-26 15:15:15 +01:00
										 |  |  |     pop_text_stack(l); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     return false; | 
					
						
							| 
									
										
										
										
											2017-09-26 15:15:15 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2017-10-02 08:58:51 +01:00
										 |  |  |   rc = Yap_unify(Yap_MkTextTerm(fp, Yap_TextType(t)), ARG2); | 
					
						
							|  |  |  |   pop_text_stack(l); | 
					
						
							|  |  |  |   return rc; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static Int prolog_to_os_filename(USES_REGS1) { | 
					
						
							|  |  |  |   Term t = Deref(ARG1), t2 = Deref(ARG2); | 
					
						
							|  |  |  |   char *fp; | 
					
						
							|  |  |  |   char out[MAXPATHLEN + 1]; | 
					
						
							| 
									
										
										
										
											2016-02-11 15:32:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   if (IsVarTerm(t)) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (IsVarTerm(t2)) { | 
					
						
							|  |  |  |       Yap_Error(INSTANTIATION_ERROR, t, "prolog_to_os_filename"); | 
					
						
							|  |  |  |       return false; | 
					
						
							|  |  |  |     } else if (IsAtomTerm(t2)) { | 
					
						
							|  |  |  |       if (!(fp = PrologPath(RepAtom(AtomOfTerm(t2))->StrOfAE, out))) | 
					
						
							| 
									
										
										
										
											2016-02-11 15:35:34 +00:00
										 |  |  |         return false; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |       return Yap_unify(ARG1, MkAtomTerm(Yap_LookupAtom(fp))); | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_ATOM, t2, "prolog_to_os_filename"); | 
					
						
							| 
									
										
										
										
											2016-02-13 03:11:25 +00:00
										 |  |  |       return false; | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   } else if (!IsAtomTerm(t)) { | 
					
						
							|  |  |  |     Yap_Error(TYPE_ERROR_ATOM, t, "prolog_to_os_filename"); | 
					
						
							|  |  |  |     return false; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   if (!(fp = OsPath(RepAtom(AtomOfTerm(t))->StrOfAE, out))) | 
					
						
							|  |  |  |     return false; | 
					
						
							|  |  |  |   return Yap_unify(MkAtomTerm(Yap_LookupAtom(fp)), ARG2); | 
					
						
							| 
									
										
										
										
											2015-06-17 23:49:02 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | Atom Yap_TemporaryFile(const char *prefix, int *fd) { | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | #if HAVE_MKSTEMP
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   char *tmp = malloc(PATH_MAX); | 
					
						
							|  |  |  |   int n; | 
					
						
							|  |  |  |   int f; | 
					
						
							|  |  |  |   if (tmp == NULL) | 
					
						
							|  |  |  |     return NIL; | 
					
						
							|  |  |  |   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; | 
					
						
							|  |  |  |   return Yap_LookupAtom(tmp); | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return AtomNil; | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | /** @pred make_directory(+ _Dir_)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Create a directory  _Dir_. The name of the directory must be an atom. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int make_directory(USES_REGS1) { | 
					
						
							|  |  |  |   const char *fd = AtomName(AtomOfTerm(ARG1)); | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | #if defined(__MINGW32__) || _MSC_VER
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   if (_mkdir(fd) == -1) { | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2017-12-01 10:42:10 +00:00
										 |  |  |   if (mkdir(Yap_VFAlloc(fd), 0777) == -1) { | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     /* return an error number */ | 
					
						
							|  |  |  |     return false; // errno?
 | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return true; | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int p_rmdir(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2017-12-01 10:42:10 +00:00
										 |  |  |   const char *fd = Yap_VFAlloc(AtomName(AtomOfTerm(ARG1))); | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | #if defined(__MINGW32__) || _MSC_VER
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   if (_rmdir(fd) == -1) { | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   if (rmdir(fd) == -1) { | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     /* return an error number */ | 
					
						
							|  |  |  |     return (Yap_unify(ARG2, MkIntTerm(errno))); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return true; | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static bool initSysPath(Term tlib, Term tcommons, bool dir_done, | 
					
						
							|  |  |  |                         bool commons_done) { | 
					
						
							|  |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2014-11-09 12:06:40 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-10 01:22:45 +00:00
										 |  |  |   if (!Yap_unify(tlib, MkAtomTerm(Yap_LookupAtom(Yap_PLDIR)))) | 
					
						
							|  |  |  |     return false; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-10 01:22:45 +00:00
										 |  |  |   return Yap_unify(tcommons, MkAtomTerm(Yap_LookupAtom(Yap_COMMONSDIR))); | 
					
						
							| 
									
										
										
										
											2014-03-15 23:47:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int libraries_directories(USES_REGS1) { | 
					
						
							|  |  |  |   return initSysPath(ARG1, ARG2, false, false); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2014-10-24 15:18:32 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int system_library(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2016-07-31 09:55:50 -05:00
										 |  |  | #if __ANDROID__
 | 
					
						
							|  |  |  |   static Term dir = 0; | 
					
						
							|  |  |  |   Term t; | 
					
						
							|  |  |  |   if (IsVarTerm(t = Deref(ARG1))) { | 
					
						
							|  |  |  |     if (dir == 0) | 
					
						
							|  |  |  |       return false; | 
					
						
							|  |  |  |     return Yap_unify(dir, ARG1); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (!IsAtomTerm(t)) | 
					
						
							|  |  |  |     return false; | 
					
						
							|  |  |  |   dir = t; | 
					
						
							|  |  |  |   return true; | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return initSysPath(ARG1, MkVarTerm(), false, true); | 
					
						
							| 
									
										
										
										
											2016-07-31 09:55:50 -05:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int commons_library(USES_REGS1) { | 
					
						
							|  |  |  |   return initSysPath(MkVarTerm(), ARG1, true, false); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int p_dir_sp(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2015-11-09 11:31:58 +00:00
										 |  |  | #if ATARI || _MSC_VER || defined(__MINGW32__)
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   Term t = MkIntTerm('\\'); | 
					
						
							|  |  |  |   Term t2 = MkIntTerm('/'); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   Term t = MkIntTerm('/'); | 
					
						
							|  |  |  |   Term t2 = MkIntTerm('/'); | 
					
						
							| 
									
										
										
										
											2015-11-05 16:47:11 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return Yap_unify_constant(ARG1, t) || Yap_unify_constant(ARG1, t2); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-10 08:33:44 +01:00
										 |  |  | size_t Yap_InitPageSize(void) { | 
					
						
							| 
									
										
										
										
											2015-11-05 16:47:11 +00:00
										 |  |  | #ifdef _WIN32
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   SYSTEM_INFO si; | 
					
						
							|  |  |  |   GetSystemInfo(&si); | 
					
						
							| 
									
										
										
										
											2016-05-10 08:33:44 +01:00
										 |  |  |   return si.dwPageSize; | 
					
						
							| 
									
										
										
										
											2015-11-05 16:47:11 +00:00
										 |  |  | #elif HAVE_UNISTD_H
 | 
					
						
							|  |  |  | #if defined(__FreeBSD__) || defined(__DragonFly__)
 | 
					
						
							| 
									
										
										
										
											2016-05-10 08:33:44 +01:00
										 |  |  |   return getpagesize(); | 
					
						
							| 
									
										
										
										
											2015-11-05 16:47:11 +00:00
										 |  |  | #elif defined(_AIX)
 | 
					
						
							| 
									
										
										
										
											2016-05-10 08:33:44 +01:00
										 |  |  |   return sysconf(_SC_PAGE_SIZE); | 
					
						
							| 
									
										
										
										
											2015-11-05 16:47:11 +00:00
										 |  |  | #elif !defined(_SC_PAGESIZE)
 | 
					
						
							| 
									
										
										
										
											2016-05-10 08:33:44 +01:00
										 |  |  |   return getpagesize(); | 
					
						
							| 
									
										
										
										
											2014-05-29 11:30:09 +02:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-05-10 08:33:44 +01:00
										 |  |  |   return sysconf(_SC_PAGESIZE); | 
					
						
							| 
									
										
										
										
											2008-05-23 10:02:13 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   bla bla | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | /* TrueFileName -> Finds the true name of a file */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #ifdef __MINGW32__
 | 
					
						
							|  |  |  | #include <ctype.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static int volume_header(char *file) { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #if _MSC_VER || defined(__MINGW32__)
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   char *ch = file; | 
					
						
							|  |  |  |   int c; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   while ((c = ch[0]) != '\0') { | 
					
						
							|  |  |  |     if (isalnum(c)) | 
					
						
							|  |  |  |       ch++; | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |       return (c == ':'); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return (FALSE); | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | int Yap_volume_header(char *file) { return volume_header(file); } | 
					
						
							| 
									
										
										
										
											2002-11-11 17:38:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-01 10:42:10 +00:00
										 |  |  | const char *Yap_getcwd(char *cwd, size_t cwdlen) { | 
					
						
							| 
									
										
										
										
											2018-02-22 08:18:45 +00:00
										 |  |  |   if (GLOBAL_cwd && GLOBAL_cwd[0]) { | 
					
						
							| 
									
										
										
										
											2018-06-14 11:27:43 +01:00
										 |  |  |     strcpy(cwd, GLOBAL_cwd); | 
					
						
							| 
									
										
										
										
											2017-11-30 01:14:26 +00:00
										 |  |  |     return cwd; | 
					
						
							| 
									
										
										
										
											2017-11-29 13:47:57 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-03-28 19:38:04 +00:00
										 |  |  | #if _WIN32 || defined(__MINGW32__)
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   if (GetCurrentDirectory(cwdlen, (char *)cwd) == 0) { | 
					
						
							|  |  |  |     Yap_WinError("GetCurrentDirectory failed"); | 
					
						
							|  |  |  |     return NULL; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return (char *)cwd; | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2018-06-18 12:16:36 +01:00
										 |  |  |   const char *rc = getcwd(cwd, FILENAME_MAX); | 
					
						
							| 
									
										
										
										
											2018-06-25 13:44:09 +01:00
										 |  |  |  // __android_log_print(ANDROID_LOG_INFO, "YAPDroid", "chdir %s", rc);
 | 
					
						
							| 
									
										
										
										
											2018-06-18 12:16:36 +01:00
										 |  |  | return rc; | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int working_directory(USES_REGS1) { | 
					
						
							|  |  |  |   char dir[YAP_FILENAME_MAX + 1]; | 
					
						
							|  |  |  |   Term t1 = Deref(ARG1), t2; | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   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"); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  |   if (t2 == TermEmptyAtom || t2 == TermDot) | 
					
						
							|  |  |  |     return true; | 
					
						
							| 
									
										
										
										
											2017-11-29 13:47:57 +00:00
										 |  |  |   return Yap_ChDir(RepAtom(AtomOfTerm(t2))->StrOfAE); | 
					
						
							| 
									
										
										
										
											2016-02-11 15:35:34 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int true_file_name(USES_REGS1) { | 
					
						
							|  |  |  |   Term t = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  |   const char *s; | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |   if (IsVarTerm(t)) { | 
					
						
							|  |  |  |     Yap_Error(INSTANTIATION_ERROR, t, "argument to true_file_name unbound"); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     return FALSE; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-04-17 17:09:10 -07:00
										 |  |  |   if (IsAtomTerm(t)) { | 
					
						
							|  |  |  |     s = RepAtom(AtomOfTerm(t))->StrOfAE; | 
					
						
							|  |  |  |   } else if (IsStringTerm(t)) { | 
					
						
							|  |  |  |     s = StringOfTerm(t); | 
					
						
							|  |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |     Yap_Error(TYPE_ERROR_ATOM, t, "argument to true_file_name"); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     return FALSE; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  |   if (!(s = Yap_AbsoluteFile(s, true))) | 
					
						
							| 
									
										
										
										
											2016-04-18 16:41:30 +01:00
										 |  |  |     return false; | 
					
						
							| 
									
										
										
										
											2016-05-30 11:25:28 +01:00
										 |  |  |   bool rc = Yap_unify(ARG2, MkAtomTerm(Yap_LookupAtom(s))); | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |   pop_text_stack(l); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:25:28 +01:00
										 |  |  |   return rc; | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2013-11-08 12:43:07 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int p_expand_file_name(USES_REGS1) { | 
					
						
							|  |  |  |   Term t = Deref(ARG1); | 
					
						
							|  |  |  |   const char *text, *text2; | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   if (IsVarTerm(t)) { | 
					
						
							|  |  |  |     Yap_Error(INSTANTIATION_ERROR, t, "argument to true_file_name unbound"); | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2017-09-26 15:15:15 +01:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2017-10-02 08:58:51 +01:00
										 |  |  |   text = Yap_TextTermToText(t); | 
					
						
							| 
									
										
										
										
											2017-09-26 15:15:15 +01:00
										 |  |  |   if (!text) { | 
					
						
							|  |  |  |     pop_text_stack(l); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     return false; | 
					
						
							| 
									
										
										
										
											2017-09-26 15:15:15 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-02-14 00:13:13 +00:00
										 |  |  |   if (!(text2 = PlExpandVars(text, NULL))) { | 
					
						
							| 
									
										
										
										
											2017-09-26 15:15:15 +01:00
										 |  |  |     pop_text_stack(l); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     return false; | 
					
						
							| 
									
										
										
										
											2017-09-26 15:15:15 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2017-10-02 08:58:51 +01:00
										 |  |  |   bool rc = Yap_unify(ARG2, Yap_MkTextTerm(text2, Yap_TextType(t))); | 
					
						
							| 
									
										
										
										
											2017-09-26 15:15:15 +01:00
										 |  |  |   pop_text_stack(l); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return rc; | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2006-05-17 18:38:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int true_file_name3(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |   Term t = Deref(ARG1), t2 = Deref(ARG2); | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00: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 (!IsVarTerm(t2)) { | 
					
						
							| 
									
										
										
										
											2007-09-27 22:40:22 +00:00
										 |  |  |     if (!IsAtomTerm(t)) { | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |       Yap_Error(TYPE_ERROR_ATOM, t2, "argument to true_file_name"); | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							| 
									
										
										
										
											2007-09-27 22:40:22 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-02-14 10:37:07 +00:00
										 |  |  |     //    root = RepAtom(AtomOfTerm(t2))->StrOfAE;
 | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   int lvl = push_text_stack(); | 
					
						
							|  |  |  |   const char *tmp = Yap_AbsoluteFile(RepAtom(AtomOfTerm(t))->StrOfAE, true); | 
					
						
							|  |  |  |   Atom at = NULL; | 
					
						
							|  |  |  |   bool rc = (tmp != NULL && (at = Yap_LookupAtom(tmp)) != NULL); | 
					
						
							|  |  |  |   pop_text_stack(lvl); | 
					
						
							|  |  |  |   return rc && Yap_unify(ARG3, MkAtomTerm(at)); | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2007-09-27 22:40:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08: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
										 |  |  |   */ | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int p_sh(USES_REGS1) { /* sh				 */ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #ifdef HAVE_SYSTEM
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   char *shell; | 
					
						
							|  |  |  |   shell = (char *)getenv("SHELL"); | 
					
						
							|  |  |  |   if (shell == NULL) | 
					
						
							|  |  |  |     shell = "/bin/sh"; | 
					
						
							| 
									
										
										
										
											2017-12-01 10:42:10 +00:00
										 |  |  |   if (system(Yap_VFAlloc(shell)) < 0) { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #if HAVE_STRERROR
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     Yap_Error(SYSTEM_ERROR_OPERATING_SYSTEM, TermNil, "%s in sh/0", | 
					
						
							|  |  |  |               strerror(errno)); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     Yap_Error(SYSTEM_ERROR_OPERATING_SYSTEM, TermNil, "in sh/0"); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     return FALSE; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return TRUE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #ifdef MSH
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   register char *shell; | 
					
						
							|  |  |  |   shell = "msh -i"; | 
					
						
							|  |  |  |   system(shell); | 
					
						
							|  |  |  |   return (TRUE); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   Yap_Error(SYSTEM_ERROR_INTERNAL, TermNil, | 
					
						
							|  |  |  |             "sh not available in this configuration"); | 
					
						
							|  |  |  |   return (FALSE); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif /* MSH */
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08: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. | 
					
						
							|  |  |  |   */ | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int p_shell(USES_REGS1) { /* '$shell'(+SystCommand) */ | 
					
						
							|  |  |  |   const char *cmd; | 
					
						
							|  |  |  |   Term t1 = Deref(ARG1); | 
					
						
							|  |  |  |   if (IsAtomTerm(t1)) | 
					
						
							|  |  |  |     cmd = RepAtom(AtomOfTerm(t1))->StrOfAE; | 
					
						
							|  |  |  |   else if (IsStringTerm(t1)) | 
					
						
							|  |  |  |     cmd = StringOfTerm(t1); | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							| 
									
										
										
										
											2014-09-15 13:10:49 -05:00
										 |  |  | #if _MSC_VER || defined(__MINGW32__)
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   { | 
					
						
							|  |  |  |     int rval = system(cmd); | 
					
						
							| 
									
										
										
										
											2014-03-06 02:09:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     return rval == 0; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2014-03-06 02:09:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return true; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-01-20 03:00:42 +00:00
										 |  |  | #if HAVE_SYSTEM
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   char *shell; | 
					
						
							|  |  |  |   register int bourne = FALSE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   shell = (char *)getenv("SHELL"); | 
					
						
							|  |  |  |   if (!strcmp(shell, "/bin/sh")) | 
					
						
							|  |  |  |     bourne = TRUE; | 
					
						
							|  |  |  |   if (shell == NIL) | 
					
						
							|  |  |  |     bourne = TRUE; | 
					
						
							|  |  |  |   /* 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); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     { /* 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; | 
					
						
							|  |  |  |       return result; | 
					
						
							| 
									
										
										
										
											2016-02-11 15:35:34 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else /* HAVE_SYSTEM */
 | 
					
						
							|  |  |  | #ifdef MSH
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   register char *shell; | 
					
						
							|  |  |  |   shell = "msh -i"; | 
					
						
							|  |  |  |   /* Yap_CloseStreams(); */ | 
					
						
							|  |  |  |   system(shell); | 
					
						
							|  |  |  |   return TRUE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   Yap_Error(SYSTEM_ERROR_INTERNAL, TermNil, | 
					
						
							|  |  |  |             "shell not available in this configuration"); | 
					
						
							|  |  |  |   return FALSE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #endif /* HAVE_SYSTEM */
 | 
					
						
							|  |  |  | #endif /* _MSC_VER */
 | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08: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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int p_system(USES_REGS1) { /* '$system'(+SystCommand)	       */ | 
					
						
							|  |  |  |   const char *cmd; | 
					
						
							|  |  |  |   Term t1 = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2016-01-31 10:33:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   if (IsVarTerm(t1)) { | 
					
						
							|  |  |  |     Yap_Error(INSTANTIATION_ERROR, t1, "argument to system/1 unbound"); | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							|  |  |  |   } else if (IsAtomTerm(t1)) { | 
					
						
							|  |  |  |     cmd = RepAtom(AtomOfTerm(t1))->StrOfAE; | 
					
						
							|  |  |  |   } else if (IsStringTerm(t1)) { | 
					
						
							|  |  |  |     cmd = StringOfTerm(t1); | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     if (!Yap_GetName(LOCAL_FileNameBuf, YAP_FILENAME_MAX, t1)) { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_ATOM, t1, "argument to system/1"); | 
					
						
							|  |  |  |       return false; | 
					
						
							| 
									
										
										
										
											2016-02-11 15:35:34 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     cmd = LOCAL_FileNameBuf; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | /* Yap_CloseStreams(TRUE); */ | 
					
						
							| 
									
										
										
										
											2014-03-16 00:52:43 +00:00
										 |  |  | #if _MSC_VER || defined(__MINGW32__)
 | 
					
						
							| 
									
										
										
										
											2016-01-31 10:33:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   { | 
					
						
							|  |  |  |     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)
 | 
					
						
							|  |  |  |                        (LPSTR)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
 | 
					
						
							| 
									
										
										
										
											2017-10-02 08:58:51 +01:00
										 |  |  |     ) { | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |       Yap_Error(SYSTEM_ERROR_INTERNAL, ARG1, "CreateProcess failed (%d).\n", | 
					
						
							|  |  |  |                 GetLastError()); | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     // Wait until child process exits.
 | 
					
						
							|  |  |  |     WaitForSingleObject(pi.hProcess, INFINITE); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Close process and thread handles.
 | 
					
						
							|  |  |  |     CloseHandle(pi.hProcess); | 
					
						
							|  |  |  |     CloseHandle(pi.hThread); | 
					
						
							| 
									
										
										
										
											2016-02-11 15:35:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     return TRUE; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2014-03-16 00:52:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return FALSE; | 
					
						
							| 
									
										
										
										
											2014-03-16 00:52:43 +00:00
										 |  |  | #elif HAVE_SYSTEM
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #if _MSC_VER
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   _flushall(); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   if (system(cmd)) { | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  | #if HAVE_STRERROR
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     Yap_Error(SYSTEM_ERROR_OPERATING_SYSTEM, t1, "%s in system(%s)", | 
					
						
							|  |  |  |               strerror(errno), cmd); | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     Yap_Error(SYSTEM_ERROR_OPERATING_SYSTEM, t1, "in system(%s)", cmd); | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     return FALSE; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return TRUE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #ifdef MSH
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00: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
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   Yap_Error(SYSTEM_ERROR_INTERNAL, TermNil, "sh not available in this machine"); | 
					
						
							|  |  |  |   return (FALSE); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #endif /* HAVE_SYSTEM */
 | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int p_mv(USES_REGS1) { /* rename(+OldName,+NewName)   */ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #if HAVE_LINK
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   int r; | 
					
						
							|  |  |  |   char *oldname, *newname; | 
					
						
							|  |  |  |   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"); | 
					
						
							|  |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2018-01-27 10:17:27 +00:00
										 |  |  |     oldname = RepAtom(AtomOfTerm(t1))->StrOfAE; | 
					
						
							|  |  |  |     newname = RepAtom(AtomOfTerm(t2))->StrOfAE; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     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
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |       Yap_Error(SYSTEM_ERROR_OPERATING_SYSTEM, t2, "%s in rename(%s,%s)", | 
					
						
							|  |  |  |                 strerror(errno), oldname, newname); | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |       Yap_Error(SYSTEM_ERROR_OPERATING_SYSTEM, t2, "in rename(%s,%s)", oldname, | 
					
						
							|  |  |  |                 newname); | 
					
						
							| 
									
										
										
										
											2005-11-23 13:24:00 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |       return false; | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     return true; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   Yap_Error(SYSTEM_ERROR_INTERNAL, TermNil, | 
					
						
							|  |  |  |             "rename/2 not available in this machine"); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return false; | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef MAC
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | void Yap_SetTextFile(name) char *name; | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #ifdef MACC
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   SetFileType(name, 'TEXT'); | 
					
						
							|  |  |  |   SetFileSignature(name, 'EDIT'); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   FInfo f; | 
					
						
							|  |  |  |   FInfo *p = &f; | 
					
						
							|  |  |  |   GetFInfo(name, 0, p); | 
					
						
							|  |  |  |   p->fdType = 'TEXT'; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #ifdef MPW
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   if (mpwshell) | 
					
						
							|  |  |  |     p->fdCreator = 'MPS\0'; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef LIGHT
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   else | 
					
						
							|  |  |  |     p->fdCreator = 'EDIT'; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   SetFInfo(name, 0, p); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | /* return YAP's environment */ | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int p_getenv(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #if HAVE_GETENV
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00: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) | 
					
						
							| 
									
										
										
										
											2016-02-11 15:35:34 +00:00
										 |  |  |     return (FALSE); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   to = MkAtomTerm(Yap_LookupAtom(so)); | 
					
						
							|  |  |  |   return (Yap_unify_constant(ARG2, to)); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |   Yap_Error(SYSTEM_ERROR_INTERNAL, TermNil, | 
					
						
							|  |  |  |             "getenv not available in this configuration"); | 
					
						
							|  |  |  |   return (FALSE); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | /* set a variable in YAP's environment */ | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int p_putenv(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #if HAVE_PUTENV
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   Term t1 = Deref(ARG1), t2 = Deref(ARG2); | 
					
						
							| 
									
										
										
										
											2016-07-31 09:55:50 -05:00
										 |  |  |   char *s = "", *s2 = "", *p0, *p; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   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(RESOURCE_ERROR_HEAP, TermNil, LOCAL_ErrorMessage); | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							| 
									
										
										
										
											2016-02-11 15:35:34 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00: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
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   Yap_Error(SYSTEM_ERROR_OPERATING_SYSTEM, TermNil, "in putenv(%s)", | 
					
						
							|  |  |  |             strerror(errno), p0); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   Yap_Error(SYSTEM_ERROR_OPERATING_SYSTEM, TermNil, "in putenv(%s)", p0); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return FALSE; | 
					
						
							| 
									
										
										
										
											2016-02-11 15:35:34 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   Yap_Error(SYSTEM_ERROR_INTERNAL, TermNil, | 
					
						
							|  |  |  |             "putenv not available in this configuration"); | 
					
						
							|  |  |  |   return FALSE; | 
					
						
							| 
									
										
										
										
											2016-02-11 15:35:34 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int p_host_type(USES_REGS1) { | 
					
						
							|  |  |  |   Term out = MkAtomTerm(Yap_LookupAtom(HOST_ALIAS)); | 
					
						
							|  |  |  |   return (Yap_unify(out, ARG1)); | 
					
						
							| 
									
										
										
										
											2016-02-11 15:35:34 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int p_yap_home(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2017-12-10 01:22:45 +00:00
										 |  |  |   Term out; | 
					
						
							| 
									
										
										
										
											2017-12-05 15:14:57 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-10 01:22:45 +00:00
										 |  |  |   out = MkAtomTerm(Yap_LookupAtom(Yap_ROOTDIR)); | 
					
						
							|  |  |  |   return Yap_unify(out, ARG1); | 
					
						
							| 
									
										
										
										
											2016-02-11 15:35:34 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int p_yap_paths(USES_REGS1) { | 
					
						
							|  |  |  |   Term out1, out2, out3; | 
					
						
							| 
									
										
										
										
											2017-12-05 15:14:57 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-10 01:22:45 +00:00
										 |  |  |   out1 = MkAtomTerm(Yap_LookupAtom(Yap_LIBDIR)); | 
					
						
							|  |  |  |   out2 = MkAtomTerm(Yap_LookupAtom(Yap_SHAREDIR)); | 
					
						
							|  |  |  |   out3 = MkAtomTerm(Yap_LookupAtom(Yap_BINDIR)); | 
					
						
							| 
									
										
										
										
											2017-12-05 15:14:57 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return (Yap_unify(out1, ARG1) && Yap_unify(out2, ARG2) && | 
					
						
							|  |  |  |           Yap_unify(out3, ARG3)); | 
					
						
							| 
									
										
										
										
											2016-02-11 15:35:34 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int p_log_event(USES_REGS1) { | 
					
						
							|  |  |  |   Term in = Deref(ARG1); | 
					
						
							|  |  |  |   Atom at; | 
					
						
							| 
									
										
										
										
											2016-02-11 15:35:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   if (IsVarTerm(in)) | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							|  |  |  |   if (!IsAtomTerm(in)) | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							|  |  |  |   at = AtomOfTerm(in); | 
					
						
							| 
									
										
										
										
											2014-06-22 17:35:05 +01:00
										 |  |  | #if DEBUG
 | 
					
						
							| 
									
										
										
										
											2016-11-02 00:16:36 -05:00
										 |  |  |   if (IsBlob(at)) | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     return FALSE; | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     fprintf(stderr, "LOG %s\n", RepAtom(at)->StrOfAE); | 
					
						
							| 
									
										
										
										
											2014-06-22 17:35:05 +01:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-11-02 00:16:36 -05:00
										 |  |  |   if (IsBlob(at)) | 
					
						
							|  |  |  |     return false; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   LOG(" %s ", RepAtom(at)->StrOfAE); | 
					
						
							|  |  |  |   return TRUE; | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2014-06-22 17:35:05 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int p_env_separator(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2005-10-28 17:38:50 +00:00
										 |  |  | #if defined(_WIN32)
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return Yap_unify(MkIntegerTerm(';'), ARG1); | 
					
						
							| 
									
										
										
										
											2005-10-28 17:38:50 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return Yap_unify(MkIntegerTerm(':'), ARG1); | 
					
						
							| 
									
										
										
										
											2005-10-28 17:38:50 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2005-10-28 17:38:50 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2017-09-23 02:17:55 +01:00
										 |  |  |  * This is responsable for the initialization of all machine dependant | 
					
						
							|  |  |  |  * predicates | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | void Yap_InitSysbits(int wid) { | 
					
						
							|  |  |  |   CACHE_REGS | 
					
						
							|  |  |  | #if __simplescalar__
 | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     char *pwd = getenv("PWD"); | 
					
						
							|  |  |  |     strncpy(GLOBAL_pwd, pwd, YAP_FILENAME_MAX); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2002-01-23 02:28:31 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   Yap_InitWTime(); | 
					
						
							|  |  |  |   Yap_InitRandom(); | 
					
						
							|  |  |  |   /* let the caller control signals as it sees fit */ | 
					
						
							|  |  |  |   Yap_InitOSSignals(worker_id); | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int p_unix(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2007-09-27 15:25:34 +00:00
										 |  |  | #ifdef unix
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return TRUE; | 
					
						
							| 
									
										
										
										
											2007-09-27 15:25:34 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #ifdef __unix__
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return TRUE; | 
					
						
							| 
									
										
										
										
											2008-03-31 19:51:07 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #ifdef __APPLE__
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return TRUE; | 
					
						
							| 
									
										
										
										
											2007-09-27 15:25:34 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return FALSE; | 
					
						
							| 
									
										
										
										
											2007-09-27 15:25:34 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2008-03-31 19:51:07 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2007-09-27 15:25:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int p_win32(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2007-09-27 15:25:34 +00:00
										 |  |  | #ifdef _WIN32
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return TRUE; | 
					
						
							| 
									
										
										
										
											2007-09-27 15:25:34 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #ifdef __CYGWIN__
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return TRUE; | 
					
						
							| 
									
										
										
										
											2007-09-27 15:25:34 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return FALSE; | 
					
						
							| 
									
										
										
										
											2007-09-27 15:25:34 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2007-09-27 15:25:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int p_ld_path(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2017-12-10 01:22:45 +00:00
										 |  |  |   return Yap_unify(ARG1, MkAtomTerm(Yap_LookupAtom(Yap_DLLDIR))); | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2007-09-27 15:25:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static Int p_address_bits(USES_REGS1) { | 
					
						
							|  |  |  | #if SIZEOF_INT_P == 4
 | 
					
						
							|  |  |  |   return Yap_unify(ARG1, MkIntTerm(32)); | 
					
						
							| 
									
										
										
										
											2010-02-23 00:29:17 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return Yap_unify(ARG1, MkIntTerm(64)); | 
					
						
							| 
									
										
										
										
											2010-02-23 00:29:17 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2010-02-23 00:29:17 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-27 00:41:33 +00:00
										 |  |  | #ifdef _WIN32
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | /* This code is from SWI-Prolog by Jan Wielemaker */ | 
					
						
							| 
									
										
										
										
											2008-03-27 00:41:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | #define wstreq(s, q) (wcscmp((s), (q)) == 0)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 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; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (RegOpenKeyExW(key, buf, 0L, KEY_READ, &tmp) == ERROR_SUCCESS) { | 
					
						
							|  |  |  |       RegCloseKey(key); | 
					
						
							|  |  |  |       key = tmp; | 
					
						
							|  |  |  |       continue; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     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; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-02-11 15:35:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return key; | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2008-03-27 00:41:33 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define MAXREGSTRLEN 1024
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | static wchar_t *WideStringFromAtom(Atom KeyAt USES_REGS) { | 
					
						
							| 
									
										
										
										
											2017-09-23 02:17:55 +01:00
										 |  |  |   return Yap_AtomToWide(KeyAt); | 
					
						
							| 
									
										
										
										
											2016-02-11 15:35:34 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00: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; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2008-03-27 00:41:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   if (IsVarTerm(Key)) { | 
					
						
							|  |  |  |     Yap_Error(INSTANTIATION_ERROR, Key, | 
					
						
							|  |  |  |               "argument to win_registry_get_value unbound"); | 
					
						
							| 
									
										
										
										
											2017-09-23 02:17:55 +01:00
										 |  |  |     pop_text_stack(l); | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (!IsAtomTerm(Key)) { | 
					
						
							|  |  |  |     Yap_Error(TYPE_ERROR_ATOM, Key, "argument to win_registry_get_value"); | 
					
						
							| 
									
										
										
										
											2017-09-23 02:17:55 +01:00
										 |  |  |     pop_text_stack(l); | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   KeyAt = AtomOfTerm(Key); | 
					
						
							|  |  |  |   if (IsVarTerm(Name)) { | 
					
						
							|  |  |  |     Yap_Error(INSTANTIATION_ERROR, Key, | 
					
						
							|  |  |  |               "argument to win_registry_get_value unbound"); | 
					
						
							| 
									
										
										
										
											2017-09-23 02:17:55 +01:00
										 |  |  |     pop_text_stack(l); | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (!IsAtomTerm(Name)) { | 
					
						
							|  |  |  |     Yap_Error(TYPE_ERROR_ATOM, Key, "argument to win_registry_get_value"); | 
					
						
							| 
									
										
										
										
											2017-09-23 02:17:55 +01:00
										 |  |  |     pop_text_stack(l); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     return FALSE; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   NameAt = AtomOfTerm(Name); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   k = WideStringFromAtom(KeyAt PASS_REGS); | 
					
						
							|  |  |  |   if (!(key = reg_open_key(k, FALSE))) { | 
					
						
							|  |  |  |     Yap_Error(EXISTENCE_ERROR_KEY, Key, "argument to win_registry_get_value"); | 
					
						
							| 
									
										
										
										
											2017-09-23 02:17:55 +01:00
										 |  |  |     pop_text_stack(l); | 
					
						
							| 
									
										
										
										
											2015-04-24 10:03:44 -06:00
										 |  |  |     return FALSE; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   name = WideStringFromAtom(NameAt PASS_REGS); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (RegQueryValueExW(key, name, NULL, &type, data, &len) == ERROR_SUCCESS) { | 
					
						
							|  |  |  |     RegCloseKey(key); | 
					
						
							|  |  |  |     switch (type) { | 
					
						
							|  |  |  |     case REG_SZ: | 
					
						
							|  |  |  |       ((wchar_t *)data)[len] = '\0'; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       Atom at = Yap_NWCharsToAtom((wchar_t *)data, len PASS_REGS); | 
					
						
							|  |  |  |       pop_text_stack(l); | 
					
						
							| 
									
										
										
										
											2017-09-23 02:17:55 +01:00
										 |  |  |       return Yap_unify(MkAtomTerm(at), ARG3); | 
					
						
							|  |  |  |     case REG_DWORD: { | 
					
						
							|  |  |  |       DWORD *d = (DWORD *)data; | 
					
						
							|  |  |  |       pop_text_stack(l); | 
					
						
							|  |  |  |       return Yap_unify(MkIntegerTerm((Int)d[0]), ARG3); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     default: | 
					
						
							| 
									
										
										
										
											2017-09-23 02:17:55 +01:00
										 |  |  |       pop_text_stack(l); | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2017-09-23 02:17:55 +01:00
										 |  |  |   pop_text_stack(l); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   return FALSE; | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2008-03-27 00:41:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00: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
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00: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
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   if (!(key = reg_open_key(L"HKEY_LOCAL_MACHINE/SOFTWARE/YAP/Prolog", FALSE))) { | 
					
						
							| 
									
										
										
										
											2016-02-11 15:35:34 +00:00
										 |  |  |     return NULL; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-02-11 15:35:34 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00: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: | 
					
						
							|  |  |  |       return NULL; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return NULL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void Yap_InitSysPreds(void) { | 
					
						
							|  |  |  |   Yap_InitCPred("log_event", 1, p_log_event, SafePredFlag | SyncPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("sh", 0, p_sh, SafePredFlag | SyncPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("$shell", 1, p_shell, SafePredFlag | SyncPredFlag); | 
					
						
							|  |  |  |   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); | 
					
						
							|  |  |  |   Yap_InitCPred("libraries_directories", 2, libraries_directories, 0); | 
					
						
							| 
									
										
										
										
											2018-06-22 23:55:50 +01:00
										 |  |  |     Yap_InitCPred("system_library", 1, system_library, 0); | 
					
						
							|  |  |  |     Yap_InitCPred("exists_directory", 1, exists_directory, 0); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   Yap_InitCPred("commons_library", 1, commons_library, 0); | 
					
						
							|  |  |  |   Yap_InitCPred("$getenv", 2, p_getenv, SafePredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("$putenv", 2, p_putenv, 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); | 
					
						
							|  |  |  |   Yap_InitCPred("expand_file_name", 3, expand_file_name3, SyncPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("expand_file_name", 2, expand_file_name, SyncPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("working_directory", 2, working_directory, SyncPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("prolog_to_os_filename", 2, prolog_to_os_filename, | 
					
						
							|  |  |  |                 SyncPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("absolute_file_system_path", 2, absolute_file_system_path, 0); | 
					
						
							| 
									
										
										
										
											2016-04-14 12:00:09 +01:00
										 |  |  |   Yap_InitCPred("real_path", 2, real_path, 0); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   Yap_InitCPred("true_file_name", 2, true_file_name, SyncPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("true_file_name", 3, true_file_name3, SyncPredFlag); | 
					
						
							|  |  |  | #ifdef _WIN32
 | 
					
						
							|  |  |  |   Yap_InitCPred("win_registry_get_value", 3, p_win_registry_get_value, 0); | 
					
						
							| 
									
										
										
										
											2016-02-18 22:10:40 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |   Yap_InitCPred("rmdir", 2, p_rmdir, SyncPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("make_directory", 1, make_directory, SyncPredFlag); | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  | } |