projects
/
sbcl.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
LDB/DPB do not check for negative indexes.
[sbcl.git]
/
tools-for-build
/
grovel-headers.c
diff --git
a/tools-for-build/grovel-headers.c
b/tools-for-build/grovel-headers.c
index
125f884
..
9be8744
100644
(file)
--- a/
tools-for-build/grovel-headers.c
+++ b/
tools-for-build/grovel-headers.c
@@
-30,6
+30,8
@@
#define WIN32_LEAN_AND_MEAN
#include <windows.h>
#include <shlobj.h>
#define WIN32_LEAN_AND_MEAN
#include <windows.h>
#include <shlobj.h>
+ #include <wincrypt.h>
+ #include <winsock2.h>
#undef boolean
#else
#include <poll.h>
#undef boolean
#else
#include <poll.h>
@@
-38,6
+40,7
@@
#include <sys/wait.h>
#include <sys/ioctl.h>
#include <sys/termios.h>
#include <sys/wait.h>
#include <sys/ioctl.h>
#include <sys/termios.h>
+ #include <sys/time.h>
#include <langinfo.h>
#include <dlfcn.h>
#endif
#include <langinfo.h>
#include <dlfcn.h>
#endif
@@
-47,6
+50,7
@@
#include <unistd.h>
#include <signal.h>
#include <errno.h>
#include <unistd.h>
#include <signal.h>
#include <errno.h>
+#include <time.h>
#ifdef LISP_FEATURE_HPUX
#include <sys/bsdtty.h> /* for TIOCGPGRP */
#ifdef LISP_FEATURE_HPUX
#include <sys/bsdtty.h> /* for TIOCGPGRP */
@@
-57,12
+61,26
@@
#include <sys/sysctl.h>
#endif
#include <sys/sysctl.h>
#endif
+#ifdef _WIN32
+ #include "pthreads_win32.h"
+#endif
+
#include "wrap.h"
#include "gc.h"
#define DEFTYPE(lispname,cname) { cname foo; \
printf("(define-alien-type " lispname " (%s %d))\n", (((foo=-1)<0) ? "sb!alien:signed" : "unsigned"), (8 * (sizeof foo))); }
#include "wrap.h"
#include "gc.h"
#define DEFTYPE(lispname,cname) { cname foo; \
printf("(define-alien-type " lispname " (%s %d))\n", (((foo=-1)<0) ? "sb!alien:signed" : "unsigned"), (8 * (sizeof foo))); }
+#define DEFSTRUCT(lispname,cname,body) { cname bar; \
+ printf("(define-alien-type nil\n (struct %s", #lispname); \
+ body; \
+ printf("))\n"); }
+#define DEFSLOT(lispname,cname) \
+ printf("\n (%s (%s %d))", \
+ #lispname, \
+ (((bar.cname=-1)<0) ? "sb!alien:signed" : "unsigned"), \
+ (8 * (sizeof bar.cname)))
+
void
defconstant(char* lisp_name, unsigned long unix_number)
{
void
defconstant(char* lisp_name, unsigned long unix_number)
{
@@
-186,8
+204,9
@@
main(int argc, char *argv[])
printf(";;; FormatMessage\n");
printf(";;; FormatMessage\n");
- defconstant ("FORMAT_MESSAGE_ALLOCATE_BUFFER", FORMAT_MESSAGE_ALLOCATE_BUFFER);
- defconstant ("FORMAT_MESSAGE_FROM_SYSTEM", FORMAT_MESSAGE_FROM_SYSTEM);
+ defconstant("FORMAT_MESSAGE_ALLOCATE_BUFFER", FORMAT_MESSAGE_ALLOCATE_BUFFER);
+ defconstant("FORMAT_MESSAGE_FROM_SYSTEM", FORMAT_MESSAGE_FROM_SYSTEM);
+ defconstant("FORMAT_MESSAGE_MAX_WIDTH_MASK", FORMAT_MESSAGE_MAX_WIDTH_MASK);
printf(";;; Errors\n");
printf(";;; Errors\n");
@@
-243,6
+262,10
@@
main(int argc, char *argv[])
defconstant("STD_OUTPUT_HANDLE", STD_OUTPUT_HANDLE);
defconstant("STD_ERROR_HANDLE", STD_ERROR_HANDLE);
defconstant("STD_OUTPUT_HANDLE", STD_OUTPUT_HANDLE);
defconstant("STD_ERROR_HANDLE", STD_ERROR_HANDLE);
+ printf(";;; WinCrypt\n");
+ defconstant("crypt-verifycontext", CRYPT_VERIFYCONTEXT);
+ defconstant("crypt-silent", CRYPT_SILENT);
+ defconstant("prov-rsa-full", PROV_RSA_FULL);
/* FIXME: SB-UNIX and SB-WIN32 really need to be untangled. */
printf("(in-package \"SB!UNIX\")\n\n");
/* FIXME: SB-UNIX and SB-WIN32 really need to be untangled. */
printf("(in-package \"SB!UNIX\")\n\n");
@@
-495,6
+518,15
@@
main(int argc, char *argv[])
#endif // !WIN32
printf("\n");
#endif // !WIN32
printf("\n");
+ printf(";;; structures\n");
+ DEFSTRUCT(timeval, struct timeval,
+ DEFSLOT(tv-sec, tv_sec);
+ DEFSLOT(tv-usec, tv_usec));
+ DEFSTRUCT(timespec, struct timespec,
+ DEFSLOT(tv-sec, tv_sec);
+ DEFSLOT(tv-nsec, tv_nsec));
+ printf("\n");
+
#ifdef LISP_FEATURE_BSD
printf(";;; sysctl(3) names\n");
printf("(in-package \"SB!IMPL\")\n");
#ifdef LISP_FEATURE_BSD
printf(";;; sysctl(3) names\n");
printf("(in-package \"SB!IMPL\")\n");