windows stuff
This commit is contained in:
parent
05f9a935e1
commit
a1e599ebe4
@ -52,6 +52,7 @@
|
|||||||
#undef HAVE_ARPA_INET_H
|
#undef HAVE_ARPA_INET_H
|
||||||
#undef HAVE_CTYPE_H
|
#undef HAVE_CTYPE_H
|
||||||
#undef HAVE_CRYPT_H
|
#undef HAVE_CRYPT_H
|
||||||
|
#undef HAVE_CRTDBG_H
|
||||||
#undef HAVE_CUDD_H
|
#undef HAVE_CUDD_H
|
||||||
#undef HAVE_CUDDINT_H
|
#undef HAVE_CUDDINT_H
|
||||||
#undef HAVE_CUDD_CUDD_H
|
#undef HAVE_CUDD_CUDD_H
|
||||||
@ -87,6 +88,7 @@
|
|||||||
#undef HAVE_READLINE_HISTORY_H
|
#undef HAVE_READLINE_HISTORY_H
|
||||||
#undef HAVE_REGEX_H
|
#undef HAVE_REGEX_H
|
||||||
#undef HAVE_RINTERFACE_H
|
#undef HAVE_RINTERFACE_H
|
||||||
|
#undef HAVE_SHLOBJ_H
|
||||||
#undef HAVE_SIGINFO_H
|
#undef HAVE_SIGINFO_H
|
||||||
#undef HAVE_SIGNAL_H
|
#undef HAVE_SIGNAL_H
|
||||||
#undef HAVE_STDARG_H
|
#undef HAVE_STDARG_H
|
||||||
@ -117,6 +119,8 @@
|
|||||||
#undef HAVE_WCTYPE_H
|
#undef HAVE_WCTYPE_H
|
||||||
#undef HAVE_WINSOCK_H
|
#undef HAVE_WINSOCK_H
|
||||||
#undef HAVE_WINSOCK2_H
|
#undef HAVE_WINSOCK2_H
|
||||||
|
#undef HAVE_WINSOCK2_H
|
||||||
|
#undef HAVE_LIBLOADERAPI_H
|
||||||
|
|
||||||
#if __MINGW32__
|
#if __MINGW32__
|
||||||
#define __WINDOWS__ 1
|
#define __WINDOWS__ 1
|
||||||
@ -184,6 +188,7 @@
|
|||||||
#undef HAVE_FINITE
|
#undef HAVE_FINITE
|
||||||
#undef HAVE_FPCLASS
|
#undef HAVE_FPCLASS
|
||||||
#undef HAVE_FTIME
|
#undef HAVE_FTIME
|
||||||
|
#undef HAVE_FTRUNCATE
|
||||||
#undef HAVE_GETCWD
|
#undef HAVE_GETCWD
|
||||||
#undef HAVE_GETENV
|
#undef HAVE_GETENV
|
||||||
#undef HAVE_GETEXECNAME
|
#undef HAVE_GETEXECNAME
|
||||||
|
15
configure
vendored
15
configure
vendored
@ -9026,7 +9026,7 @@ $as_echo "#define HAVE_SYS_WAIT_H 1" >>confdefs.h
|
|||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
for ac_header in arpa/inet.h alloca.h crypt.h
|
for ac_header in arpa/inet.h alloca.h crtdbg.h crypt.h
|
||||||
do :
|
do :
|
||||||
as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh`
|
as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh`
|
||||||
ac_fn_c_check_header_mongrel "$LINENO" "$ac_header" "$as_ac_Header" "$ac_includes_default"
|
ac_fn_c_check_header_mongrel "$LINENO" "$ac_header" "$as_ac_Header" "$ac_includes_default"
|
||||||
@ -9091,7 +9091,7 @@ fi
|
|||||||
|
|
||||||
done
|
done
|
||||||
|
|
||||||
for ac_header in netdb.h netinet/in.h netinet/tcp.h pwd.h regex.h
|
for ac_header in netdb.h netinet/in.h netinet/tcp.h pwd.h regex.h shlobj.h
|
||||||
do :
|
do :
|
||||||
as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh`
|
as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh`
|
||||||
ac_fn_c_check_header_mongrel "$LINENO" "$ac_header" "$as_ac_Header" "$ac_includes_default"
|
ac_fn_c_check_header_mongrel "$LINENO" "$ac_header" "$as_ac_Header" "$ac_includes_default"
|
||||||
@ -9221,12 +9221,13 @@ fi
|
|||||||
|
|
||||||
done
|
done
|
||||||
|
|
||||||
for ac_header in mach-o/dyld.h
|
for ac_header in mach-o/dyld.h LibLoaderAPI.h
|
||||||
do :
|
do :
|
||||||
ac_fn_c_check_header_mongrel "$LINENO" "mach-o/dyld.h" "ac_cv_header_mach_o_dyld_h" "$ac_includes_default"
|
as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh`
|
||||||
if test "x$ac_cv_header_mach_o_dyld_h" = xyes; then :
|
ac_fn_c_check_header_mongrel "$LINENO" "$ac_header" "$as_ac_Header" "$ac_includes_default"
|
||||||
|
if eval test \"x\$"$as_ac_Header"\" = x"yes"; then :
|
||||||
cat >>confdefs.h <<_ACEOF
|
cat >>confdefs.h <<_ACEOF
|
||||||
#define HAVE_MACH_O_DYLD_H 1
|
#define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1
|
||||||
_ACEOF
|
_ACEOF
|
||||||
|
|
||||||
fi
|
fi
|
||||||
@ -10238,7 +10239,7 @@ _ACEOF
|
|||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
for ac_func in fesettrapenable fgetpos finite fpclass ftime getcwd getenv
|
for ac_func in fesettrapenable fgetpos finite fpclass ftime ftruncate getcwd getenv
|
||||||
do :
|
do :
|
||||||
as_ac_var=`$as_echo "ac_cv_func_$ac_func" | $as_tr_sh`
|
as_ac_var=`$as_echo "ac_cv_func_$ac_func" | $as_tr_sh`
|
||||||
ac_fn_c_check_func "$LINENO" "$ac_func" "$as_ac_var"
|
ac_fn_c_check_func "$LINENO" "$ac_func" "$as_ac_var"
|
||||||
|
@ -1694,12 +1694,12 @@ AC_SUBST(PRE_INSTALL_ENV)
|
|||||||
dnl Checks for header files.
|
dnl Checks for header files.
|
||||||
AC_HEADER_STDC
|
AC_HEADER_STDC
|
||||||
AC_HEADER_SYS_WAIT
|
AC_HEADER_SYS_WAIT
|
||||||
AC_CHECK_HEADERS(arpa/inet.h alloca.h crypt.h)
|
AC_CHECK_HEADERS(arpa/inet.h alloca.h crtdbg.h crypt.h)
|
||||||
AC_CHECK_HEADERS(ctype.h direct.h dirent.h dlfcn.h)
|
AC_CHECK_HEADERS(ctype.h direct.h dirent.h dlfcn.h)
|
||||||
AC_CHECK_HEADERS(errno.h execinfo.h fcntl.h fenv.h)
|
AC_CHECK_HEADERS(errno.h execinfo.h fcntl.h fenv.h)
|
||||||
AC_CHECK_HEADERS(float.h fpu_control.h ieeefp.h io.h limits.h)
|
AC_CHECK_HEADERS(float.h fpu_control.h ieeefp.h io.h limits.h)
|
||||||
AC_CHECK_HEADERS(locale.h malloc.h math.h memory.h)
|
AC_CHECK_HEADERS(locale.h malloc.h math.h memory.h)
|
||||||
AC_CHECK_HEADERS(netdb.h netinet/in.h netinet/tcp.h pwd.h regex.h)
|
AC_CHECK_HEADERS(netdb.h netinet/in.h netinet/tcp.h pwd.h regex.h shlobj.h)
|
||||||
AC_CHECK_HEADERS(siginfo.h signal.h stdarg.h stdint.h string.h stropts.h)
|
AC_CHECK_HEADERS(siginfo.h signal.h stdarg.h stdint.h string.h stropts.h)
|
||||||
AC_CHECK_HEADERS(sys/conf.h sys/dir.h sys/file.h)
|
AC_CHECK_HEADERS(sys/conf.h sys/dir.h sys/file.h)
|
||||||
AC_CHECK_HEADERS(sys/mman.h sys/ndir.h sys/param.h)
|
AC_CHECK_HEADERS(sys/mman.h sys/ndir.h sys/param.h)
|
||||||
@ -1709,7 +1709,7 @@ AC_CHECK_HEADERS(sys/time.h sys/times.h sys/types.h)
|
|||||||
AC_CHECK_HEADERS(sys/ucontext.h sys/un.h sys/wait.h)
|
AC_CHECK_HEADERS(sys/ucontext.h sys/un.h sys/wait.h)
|
||||||
AC_CHECK_HEADERS(time.h unistd.h utime.h wctype.h winsock.h winsock2.h)
|
AC_CHECK_HEADERS(time.h unistd.h utime.h wctype.h winsock.h winsock2.h)
|
||||||
AC_CHECK_HEADERS(zlib.h zutil.h)
|
AC_CHECK_HEADERS(zlib.h zutil.h)
|
||||||
AC_CHECK_HEADERS(mach-o/dyld.h)
|
AC_CHECK_HEADERS(mach-o/dyld.h LibLoaderAPI.h)
|
||||||
if test "$yap_cv_gmp" != "no"
|
if test "$yap_cv_gmp" != "no"
|
||||||
then
|
then
|
||||||
AC_CHECK_HEADERS(gmp.h)
|
AC_CHECK_HEADERS(gmp.h)
|
||||||
@ -2068,7 +2068,7 @@ AC_CHECK_FUNCS(_NSGetEnviron _chsize_s access acosh)
|
|||||||
AC_CHECK_FUNCS(alloca asinh atanh chdir clock clock_gettime)
|
AC_CHECK_FUNCS(alloca asinh atanh chdir clock clock_gettime)
|
||||||
AC_CHECK_FUNCS(ctime dlopen dup2)
|
AC_CHECK_FUNCS(ctime dlopen dup2)
|
||||||
AC_CHECK_FUNCS(erf feclearexcept)
|
AC_CHECK_FUNCS(erf feclearexcept)
|
||||||
AC_CHECK_FUNCS(fesettrapenable fgetpos finite fpclass ftime getcwd getenv)
|
AC_CHECK_FUNCS(fesettrapenable fgetpos finite fpclass ftime ftruncate getcwd getenv)
|
||||||
AC_CHECK_FUNCS(getexecname)
|
AC_CHECK_FUNCS(getexecname)
|
||||||
AC_CHECK_FUNCS(gethostbyname gethostent gethostid gethostname)
|
AC_CHECK_FUNCS(gethostbyname gethostent gethostid gethostname)
|
||||||
AC_CHECK_FUNCS(gethrtime getpagesize)
|
AC_CHECK_FUNCS(gethrtime getpagesize)
|
||||||
|
280
os/pl-nt.c
280
os/pl-nt.c
@ -19,7 +19,7 @@
|
|||||||
|
|
||||||
You should have received a copy of the GNU Lesser General Public
|
You should have received a copy of the GNU Lesser General Public
|
||||||
License along with this library; if not, write to the Free Software
|
License along with this library; if not, write to the Free Software
|
||||||
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef __MINGW32__
|
#ifdef __MINGW32__
|
||||||
@ -27,8 +27,8 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef __WINDOWS__
|
#ifdef __WINDOWS__
|
||||||
#define _WIN32_WINNT 0x0400
|
#define WINVER 0x0501
|
||||||
#if (_MSC_VER >= 1300) || defined(__MINGW32__)
|
#if (_MSC_VER >= 1300) || __MINGW32__
|
||||||
#include <winsock2.h> /* Needed on VC8 */
|
#include <winsock2.h> /* Needed on VC8 */
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
#else
|
#else
|
||||||
@ -36,16 +36,28 @@
|
|||||||
#include <winsock2.h>
|
#include <winsock2.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef __MINGW32__
|
||||||
|
#ifndef _WIN32_IE
|
||||||
|
#define _WIN32_IE 0x0400
|
||||||
|
#endif
|
||||||
|
/* FIXME: these are copied from SWI-Prolog.h. */
|
||||||
|
#define PL_MSG_EXCEPTION_RAISED -1
|
||||||
|
#define PL_MSG_IGNORED 0
|
||||||
|
#define PL_MSG_HANDLED 1
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "pl-incl.h"
|
#include "pl-incl.h"
|
||||||
#include "pl-utf8.h"
|
#include "os/pl-utf8.h"
|
||||||
//#include <crtdbg.h>
|
|
||||||
#include <process.h>
|
#include <process.h>
|
||||||
#include "pl-ctype.h"
|
#include "os/pl-ctype.h"
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
#include "SWI-Stream.h"
|
#include "os/SWI-Stream.h"
|
||||||
#include <process.h>
|
#include <process.h>
|
||||||
#include <winbase.h>
|
#include <winbase.h>
|
||||||
|
#ifdef HAVE_CRTDBG_H
|
||||||
|
#include <crtdbg.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/*******************************
|
/*******************************
|
||||||
@ -135,8 +147,8 @@ PlMessage(const char *fm, ...)
|
|||||||
* WinAPI ERROR CODES *
|
* WinAPI ERROR CODES *
|
||||||
*******************************/
|
*******************************/
|
||||||
|
|
||||||
char *
|
const char *
|
||||||
WinError()
|
WinError(void)
|
||||||
{ int id = GetLastError();
|
{ int id = GetLastError();
|
||||||
char *msg;
|
char *msg;
|
||||||
static WORD lang;
|
static WORD lang;
|
||||||
@ -232,23 +244,21 @@ Pause(double t)
|
|||||||
* SET FILE SIZE *
|
* SET FILE SIZE *
|
||||||
*******************************/
|
*******************************/
|
||||||
|
|
||||||
|
#ifndef HAVE_FTRUNCATE
|
||||||
|
|
||||||
int
|
int
|
||||||
ftruncate(int fileno, int64_t length)
|
ftruncate(int fileno, int64_t length)
|
||||||
{ int e;
|
{ errno_t e;
|
||||||
|
|
||||||
#if HAVE__CHSIZE_S
|
|
||||||
/* not always available in mingw */
|
|
||||||
if ( (e=_chsize_s(fileno, length)) == 0 )
|
if ( (e=_chsize_s(fileno, length)) == 0 )
|
||||||
return 0;
|
return 0;
|
||||||
#else
|
|
||||||
if ( (e=_chsize(fileno, (long)length)) == 0 )
|
|
||||||
return 0;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
errno = e;
|
errno = e;
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/*******************************
|
/*******************************
|
||||||
* QUERY CPU TIME *
|
* QUERY CPU TIME *
|
||||||
@ -273,13 +283,14 @@ CpuTime(cputime_kind which)
|
|||||||
case CPU_SYSTEM:
|
case CPU_SYSTEM:
|
||||||
p = &kerneltime;
|
p = &kerneltime;
|
||||||
break;
|
break;
|
||||||
|
default:
|
||||||
|
assert(0);
|
||||||
|
return 0.0;
|
||||||
}
|
}
|
||||||
t = (double)p->dwHighDateTime * (4294967296.0 * ntick nano);
|
t = (double)p->dwHighDateTime * (4294967296.0 * ntick nano);
|
||||||
t += (double)p->dwLowDateTime * (ntick nano);
|
t += (double)p->dwLowDateTime * (ntick nano);
|
||||||
} else /* '95, Windows 3.1/win32s */
|
} else /* '95, Windows 3.1/win32s */
|
||||||
{ extern intptr_t clock_wait_ticks;
|
{ t = 0.0;
|
||||||
|
|
||||||
t = (double) (clock() - clock_wait_ticks) / (double) CLOCKS_PER_SEC;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return t;
|
return t;
|
||||||
@ -287,7 +298,7 @@ CpuTime(cputime_kind which)
|
|||||||
|
|
||||||
|
|
||||||
static int
|
static int
|
||||||
CpuCount()
|
CpuCount(void)
|
||||||
{ SYSTEM_INFO si;
|
{ SYSTEM_INFO si;
|
||||||
|
|
||||||
GetSystemInfo(&si);
|
GetSystemInfo(&si);
|
||||||
@ -297,7 +308,7 @@ CpuCount()
|
|||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
setOSPrologFlags()
|
setOSPrologFlags(void)
|
||||||
{ PL_set_prolog_flag("cpu_count", PL_INTEGER, CpuCount());
|
{ PL_set_prolog_flag("cpu_count", PL_INTEGER, CpuCount());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -310,7 +321,7 @@ findExecutable(const char *module, char *exe)
|
|||||||
|
|
||||||
if ( module )
|
if ( module )
|
||||||
{ if ( !(hmod = GetModuleHandle(module)) )
|
{ if ( !(hmod = GetModuleHandle(module)) )
|
||||||
{ hmod = GetModuleHandle("libpl.dll");
|
{ hmod = GetModuleHandle("libswipl.dll");
|
||||||
DEBUG(0,
|
DEBUG(0,
|
||||||
Sdprintf("Warning: could not find module from \"%s\"\n"
|
Sdprintf("Warning: could not find module from \"%s\"\n"
|
||||||
"Warning: Trying %s to find home\n",
|
"Warning: Trying %s to find home\n",
|
||||||
@ -340,7 +351,7 @@ findExecutable(const char *module, char *exe)
|
|||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
{ const char *name;
|
{ const char *name;
|
||||||
int id;
|
UINT id;
|
||||||
} showtype;
|
} showtype;
|
||||||
|
|
||||||
static int
|
static int
|
||||||
@ -348,12 +359,12 @@ get_showCmd(term_t show, UINT *cmd)
|
|||||||
{ char *s;
|
{ char *s;
|
||||||
showtype *st;
|
showtype *st;
|
||||||
static showtype types[] =
|
static showtype types[] =
|
||||||
{ { "hide", SW_HIDE },
|
{ { "hide", SW_HIDE },
|
||||||
{ "maximize", SW_MAXIMIZE },
|
{ "maximize", SW_MAXIMIZE },
|
||||||
{ "minimize", SW_MINIMIZE },
|
{ "minimize", SW_MINIMIZE },
|
||||||
{ "restore", SW_RESTORE },
|
{ "restore", SW_RESTORE },
|
||||||
{ "show", SW_SHOW },
|
{ "show", SW_SHOW },
|
||||||
{ "showdefault", SW_SHOWDEFAULT },
|
{ "showdefault", SW_SHOWDEFAULT },
|
||||||
{ "showmaximized", SW_SHOWMAXIMIZED },
|
{ "showmaximized", SW_SHOWMAXIMIZED },
|
||||||
{ "showminimized", SW_SHOWMINIMIZED },
|
{ "showminimized", SW_SHOWMINIMIZED },
|
||||||
{ "showminnoactive", SW_SHOWMINNOACTIVE },
|
{ "showminnoactive", SW_SHOWMINNOACTIVE },
|
||||||
@ -361,8 +372,8 @@ get_showCmd(term_t show, UINT *cmd)
|
|||||||
{ "shownoactive", SW_SHOWNOACTIVATE },
|
{ "shownoactive", SW_SHOWNOACTIVATE },
|
||||||
{ "shownormal", SW_SHOWNORMAL },
|
{ "shownormal", SW_SHOWNORMAL },
|
||||||
/* compatibility */
|
/* compatibility */
|
||||||
{ "normal", SW_SHOWNORMAL },
|
{ "normal", SW_SHOWNORMAL },
|
||||||
{ "iconic", SW_MINIMIZE },
|
{ "iconic", SW_MINIMIZE },
|
||||||
{ NULL, 0 },
|
{ NULL, 0 },
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -422,8 +433,9 @@ win_exec(size_t len, const wchar_t *cmd, UINT show)
|
|||||||
} else
|
} else
|
||||||
{ term_t tmp = PL_new_term_ref();
|
{ term_t tmp = PL_new_term_ref();
|
||||||
|
|
||||||
PL_unify_wchars(tmp, PL_ATOM, len, cmd);
|
return ( PL_unify_wchars(tmp, PL_ATOM, len, cmd) &&
|
||||||
return PL_error(NULL, 0, WinError(), ERR_SHELL_FAILED, tmp);
|
PL_error(NULL, 0, WinError(), ERR_SHELL_FAILED, tmp)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -524,7 +536,7 @@ static const shell_error se_errors[] =
|
|||||||
{ SE_ERR_DDETIMEOUT, "DDE request timed out" },
|
{ SE_ERR_DDETIMEOUT, "DDE request timed out" },
|
||||||
{ SE_ERR_DLLNOTFOUND, "DLL not found" },
|
{ SE_ERR_DLLNOTFOUND, "DLL not found" },
|
||||||
{ SE_ERR_FNF, "File not found (FNF)" },
|
{ SE_ERR_FNF, "File not found (FNF)" },
|
||||||
{ SE_ERR_NOASSOC, "No association" },
|
{ SE_ERR_NOASSOC, "No association" },
|
||||||
{ SE_ERR_OOM, "Not enough memory" },
|
{ SE_ERR_OOM, "Not enough memory" },
|
||||||
{ SE_ERR_PNF, "Path not found (PNF)" },
|
{ SE_ERR_PNF, "Path not found (PNF)" },
|
||||||
{ SE_ERR_SHARE, "Sharing violation" },
|
{ SE_ERR_SHARE, "Sharing violation" },
|
||||||
@ -550,7 +562,7 @@ win_shell(term_t op, term_t file, term_t how)
|
|||||||
{ const shell_error *se;
|
{ const shell_error *se;
|
||||||
|
|
||||||
for(se = se_errors; se->message; se++)
|
for(se = se_errors; se->message; se++)
|
||||||
{ if ( se->eno == (int)instance )
|
{ if ( se->eno == (int)(intptr_t)instance )
|
||||||
return PL_error(NULL, 0, se->message, ERR_SHELL_FAILED, file);
|
return PL_error(NULL, 0, se->message, ERR_SHELL_FAILED, file);
|
||||||
}
|
}
|
||||||
PL_error(NULL, 0, NULL, ERR_SHELL_FAILED, file);
|
PL_error(NULL, 0, NULL, ERR_SHELL_FAILED, file);
|
||||||
@ -621,22 +633,113 @@ need. They are used by pl-load.c, which defines the actual Prolog
|
|||||||
interface.
|
interface.
|
||||||
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
|
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
|
||||||
|
|
||||||
static char *dlmsg;
|
#ifdef HAVE_LIBLOADERAPI_H
|
||||||
|
#include <LibLoaderAPI.h>
|
||||||
|
#else
|
||||||
|
#ifndef LOAD_LIBRARY_SEARCH_DLL_LOAD_DIR
|
||||||
|
#define LOAD_LIBRARY_SEARCH_DLL_LOAD_DIR 0x00000100
|
||||||
|
#endif
|
||||||
|
#ifndef LOAD_LIBRARY_SEARCH_DEFAULT_DIRS
|
||||||
|
#define LOAD_LIBRARY_SEARCH_DEFAULT_DIRS 0x00001000
|
||||||
|
#endif
|
||||||
|
typedef void * DLL_DIRECTORY_COOKIE;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static const char *dlmsg;
|
||||||
|
static DLL_DIRECTORY_COOKIE WINAPI (*f_AddDllDirectoryW)(wchar_t* dir);
|
||||||
|
static BOOL WINAPI (*f_RemoveDllDirectory)(DLL_DIRECTORY_COOKIE);
|
||||||
|
|
||||||
|
static DWORD
|
||||||
|
load_library_search_flags(void)
|
||||||
|
{ static int done = FALSE;
|
||||||
|
static DWORD flags = 0;
|
||||||
|
|
||||||
|
if ( !done )
|
||||||
|
{ HMODULE kernel = GetModuleHandle(TEXT("kernel32.dll"));
|
||||||
|
|
||||||
|
if ( (f_AddDllDirectoryW = (void*)GetProcAddress(kernel, "AddDllDirectory")) &&
|
||||||
|
(f_RemoveDllDirectory = (void*)GetProcAddress(kernel, "RemoveDllDirectory")) )
|
||||||
|
{ flags = ( LOAD_LIBRARY_SEARCH_DLL_LOAD_DIR|
|
||||||
|
LOAD_LIBRARY_SEARCH_DEFAULT_DIRS );
|
||||||
|
}
|
||||||
|
done = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
return flags;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static
|
||||||
|
PRED_IMPL("win_add_dll_directory", 2, win_add_dll_directory, 0)
|
||||||
|
{ PRED_LD
|
||||||
|
char *dirs;
|
||||||
|
|
||||||
|
if ( PL_get_file_name(A1, &dirs, REP_UTF8) )
|
||||||
|
{ size_t len = utf8_strlen(dirs, strlen(dirs));
|
||||||
|
wchar_t *dirw = alloca((len+10)*sizeof(wchar_t));
|
||||||
|
DLL_DIRECTORY_COOKIE cookie;
|
||||||
|
|
||||||
|
if ( _xos_os_filenameW(dirs, dirw, len+10) == NULL )
|
||||||
|
return PL_representation_error("file_name");
|
||||||
|
if ( load_library_search_flags() )
|
||||||
|
{ if ( (cookie = (*f_AddDllDirectoryW)(dirw)) )
|
||||||
|
return PL_unify_int64(A2, (int64_t)cookie);
|
||||||
|
return PL_error(NULL, 0, WinError(), ERR_SYSCALL, "AddDllDirectory()");
|
||||||
|
} else
|
||||||
|
return FALSE;
|
||||||
|
} else
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static
|
||||||
|
PRED_IMPL("win_remove_dll_directory", 1, win_remove_dll_directory, 0)
|
||||||
|
{ int64_t icookie;
|
||||||
|
|
||||||
|
if ( PL_get_int64_ex(A1, &icookie) )
|
||||||
|
{ if ( f_RemoveDllDirectory )
|
||||||
|
{ if ( (*f_RemoveDllDirectory)((DLL_DIRECTORY_COOKIE)icookie) )
|
||||||
|
return TRUE;
|
||||||
|
|
||||||
|
return PL_error(NULL, 0, WinError(), ERR_SYSCALL, "RemoveDllDirectory()");
|
||||||
|
} else
|
||||||
|
return FALSE;
|
||||||
|
} else
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static int
|
||||||
|
is_windows_abs_path(const wchar_t *path)
|
||||||
|
{ if ( path[1] == ':' && path[0] < 0x80 && iswalpha(path[0]) )
|
||||||
|
return TRUE; /* drive */
|
||||||
|
if ( path[0] == '\\' && path[1] == '\\' )
|
||||||
|
return TRUE; /* UNC */
|
||||||
|
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
void *
|
void *
|
||||||
dlopen(const char *file, int flags) /* file is in UTF-8 */
|
dlopen(const char *file, int flags) /* file is in UTF-8, POSIX path */
|
||||||
{ HINSTANCE h;
|
{ HINSTANCE h;
|
||||||
|
DWORD llflags = 0;
|
||||||
size_t len = utf8_strlen(file, strlen(file));
|
size_t len = utf8_strlen(file, strlen(file));
|
||||||
wchar_t *wfile = alloca((len+1)*sizeof(wchar_t));
|
wchar_t *wfile = alloca((len+10)*sizeof(wchar_t));
|
||||||
|
|
||||||
if ( !wfile )
|
if ( !wfile )
|
||||||
{ dlmsg = "No memory";
|
{ dlmsg = "No memory";
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
utf8towcs(wfile, file);
|
if ( _xos_os_filenameW(file, wfile, len+10) == NULL )
|
||||||
|
{ dlmsg = "Name too long";
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
if ( (h = LoadLibraryW(wfile)) )
|
if ( is_windows_abs_path(wfile) )
|
||||||
|
llflags |= load_library_search_flags();
|
||||||
|
|
||||||
|
if ( (h = LoadLibraryExW(wfile, NULL, llflags)) )
|
||||||
{ dlmsg = "No Error";
|
{ dlmsg = "No Error";
|
||||||
return (void *)h;
|
return (void *)h;
|
||||||
}
|
}
|
||||||
@ -647,7 +750,7 @@ dlopen(const char *file, int flags) /* file is in UTF-8 */
|
|||||||
|
|
||||||
|
|
||||||
const char *
|
const char *
|
||||||
dlerror()
|
dlerror(void)
|
||||||
{ return dlmsg;
|
{ return dlmsg;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -676,11 +779,59 @@ dlclose(void *handle)
|
|||||||
#endif /*EMULATE_DLOPEN*/
|
#endif /*EMULATE_DLOPEN*/
|
||||||
|
|
||||||
|
|
||||||
|
/*******************************
|
||||||
|
* SNPRINTF MADNESS *
|
||||||
|
*******************************/
|
||||||
|
|
||||||
|
/* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
MS-Windows _snprintf() may look like C99 snprintf(), but is is not quite
|
||||||
|
the same: on overflow, the buffer is *not* 0-terminated and the return
|
||||||
|
is negative (unspecified how negative). The code below works around
|
||||||
|
this, returning count on overflow. This is still not the same as the C99
|
||||||
|
version that returns the number of characters that would have been
|
||||||
|
written, but it seems to be enough for our purposes.
|
||||||
|
|
||||||
|
See http://www.di-mgt.com.au/cprog.html#snprintf
|
||||||
|
|
||||||
|
The above came from the provided link, but it is even worse (copied from
|
||||||
|
VS2005 docs):
|
||||||
|
|
||||||
|
- If len < count, then len characters are stored in buffer, a
|
||||||
|
null-terminator is appended, and len is returned.
|
||||||
|
|
||||||
|
- If len = count, then len characters are stored in buffer, no
|
||||||
|
null-terminator is appended, and len is returned.
|
||||||
|
|
||||||
|
- If len > count, then count characters are stored in buffer, no
|
||||||
|
null-terminator is appended, and a negative value is returned.
|
||||||
|
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
|
||||||
|
|
||||||
|
int
|
||||||
|
ms_snprintf(char *buffer, size_t count, const char *fmt, ...)
|
||||||
|
{ va_list ap;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
va_start(ap, fmt);
|
||||||
|
ret = _vsnprintf(buffer, count-1, fmt, ap);
|
||||||
|
va_end(ap);
|
||||||
|
|
||||||
|
if ( ret < 0 || ret == count )
|
||||||
|
{ ret = (int)count;
|
||||||
|
buffer[count-1] = '\0';
|
||||||
|
}
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/*******************************
|
/*******************************
|
||||||
* FOLDERS *
|
* FOLDERS *
|
||||||
*******************************/
|
*******************************/
|
||||||
|
|
||||||
#include <Shlobj.h>
|
#ifdef HAVE_SHLOBJ_H
|
||||||
|
#include <shlobj.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
typedef struct folderid
|
typedef struct folderid
|
||||||
{ int csidl;
|
{ int csidl;
|
||||||
@ -727,7 +878,7 @@ static int
|
|||||||
unify_csidl_path(term_t t, int csidl)
|
unify_csidl_path(term_t t, int csidl)
|
||||||
{ wchar_t buf[MAX_PATH];
|
{ wchar_t buf[MAX_PATH];
|
||||||
|
|
||||||
if ( SHGetFolderPathW(0, csidl, NULL, FALSE, buf) )
|
if ( SHGetSpecialFolderPathW(0, buf, csidl, FALSE) )
|
||||||
{ wchar_t *p;
|
{ wchar_t *p;
|
||||||
|
|
||||||
for(p=buf; *p; p++)
|
for(p=buf; *p; p++)
|
||||||
@ -935,7 +1086,7 @@ setStacksFromKey(HKEY key)
|
|||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
getDefaultsFromRegistry()
|
getDefaultsFromRegistry(void)
|
||||||
{ HKEY key;
|
{ HKEY key;
|
||||||
|
|
||||||
if ( (key = reg_open_key(L"HKEY_LOCAL_MACHINE/Software/SWI/Prolog", FALSE)) )
|
if ( (key = reg_open_key(L"HKEY_LOCAL_MACHINE/Software/SWI/Prolog", FALSE)) )
|
||||||
@ -948,44 +1099,6 @@ getDefaultsFromRegistry()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static
|
|
||||||
PRED_IMPL("win_open_file_name", 3, win_open_file_name, 0)
|
|
||||||
{ GET_LD
|
|
||||||
OPENFILENAMEW ofn;
|
|
||||||
wchar_t szFileName[MAX_PATH];
|
|
||||||
void *x;
|
|
||||||
HWND hwnd;
|
|
||||||
wchar_t *yap_cwd;
|
|
||||||
|
|
||||||
if(!PL_get_pointer(A1, &x))
|
|
||||||
return FALSE;
|
|
||||||
if(!PL_get_wchars(A2, NULL, &yap_cwd, CVT_ATOM|CVT_EXCEPTION))
|
|
||||||
return FALSE;
|
|
||||||
hwnd = (HWND)x;
|
|
||||||
ZeroMemory(&ofn, sizeof(ofn));
|
|
||||||
|
|
||||||
ofn.lStructSize = sizeof(ofn); // SEE NOTE BELOW
|
|
||||||
ofn.hwndOwner = hwnd;
|
|
||||||
ofn.lpstrFilter = L"Prolog Files (*.pl;*.yap)\0*.pl;*.yap\0All Files (*.*)\0*.*\0";
|
|
||||||
ofn.lpstrFile = szFileName;
|
|
||||||
ofn.lpstrInitialDir = yap_cwd;
|
|
||||||
ofn.nMaxFile = MAX_PATH;
|
|
||||||
ofn.Flags = OFN_EXPLORER | OFN_FILEMUSTEXIST
|
|
||||||
//| OFN_HIDEREADONLY
|
|
||||||
//|OFN_ALLOWMULTISELECT
|
|
||||||
;
|
|
||||||
ofn.lpstrDefExt = "pl";
|
|
||||||
|
|
||||||
if(GetOpenFileNameW(&ofn))
|
|
||||||
{
|
|
||||||
// Do something usefull with the filename stored in szFileName
|
|
||||||
return PL_unify_wchars(A3, PL_ATOM,
|
|
||||||
MAX_PATH-1, szFileName);
|
|
||||||
}
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*******************************
|
/*******************************
|
||||||
* PUBLISH PREDICATES *
|
* PUBLISH PREDICATES *
|
||||||
*******************************/
|
*******************************/
|
||||||
@ -993,9 +1106,10 @@ PRED_IMPL("win_open_file_name", 3, win_open_file_name, 0)
|
|||||||
BeginPredDefs(win)
|
BeginPredDefs(win)
|
||||||
PRED_DEF("win_shell", 2, win_shell2, 0)
|
PRED_DEF("win_shell", 2, win_shell2, 0)
|
||||||
PRED_DEF("win_shell", 3, win_shell3, 0)
|
PRED_DEF("win_shell", 3, win_shell3, 0)
|
||||||
PRED_DEF("win_open_file_name", 3, win_open_file_name, 0)
|
|
||||||
PRED_DEF("win_registry_get_value", 3, win_registry_get_value, 0)
|
PRED_DEF("win_registry_get_value", 3, win_registry_get_value, 0)
|
||||||
PRED_DEF("win_folder", 2, win_folder, PL_FA_NONDETERMINISTIC)
|
PRED_DEF("win_folder", 2, win_folder, PL_FA_NONDETERMINISTIC)
|
||||||
|
PRED_DEF("win_add_dll_directory", 2, win_add_dll_directory, 0)
|
||||||
|
PRED_DEF("win_remove_dll_directory", 1, win_remove_dll_directory, 0)
|
||||||
EndPredDefs
|
EndPredDefs
|
||||||
|
|
||||||
#endif /*__WINDOWS__*/
|
#endif /*__WINDOWS__*/
|
||||||
|
Reference in New Issue
Block a user