libmicrohttpd

HTTP/1.x server C library (MHD 1.x, stable)
Log | Files | Refs | Submodules | README | LICENSE

commit 02dc5b39a1e27c94cedb5a8db622788d8873df59
parent 24687543ab73f35eb1bcd8e2858e2f940f40409f
Author: Christian Grothoff <christian@grothoff.org>
Date:   Thu, 19 Aug 2010 11:27:17 +0000

[libmicrohttpd] Patches for Windows version of libmicrohttpd
From: 
Gerrit Telkamp <g.telkamp@domologic.de>
  To: 
libmicrohttpd@gnu.org
  Date: 
Today 11:42:30
  Attachments: 
 libmicrohttpd-windows.patch
   
  It was a bit tricky to build libmicrohttpd (SVN trunk) for Windows. 
I'm using the newest MSYS/MinGW environment (GCC 4.5.1).
I've optimized the autoconf feature, so this should be easier in future. 
Please find enclosed my patches.

In detail:
1- libmicrohttpd needs the "PlibC" library under Windows (libplibc.a). 
Methods of PlibC are referenced by src/daemon/daemon.c.
autoconf assumes that PlibC is installed on the Build environment and 
does not check this.
If PlibC is not installed, the pthreads check (see "acinclude.m4") will 
fail and stops with the wrong error message "Your system is not 
supporting pthreads". This is very confusing.

The patch includes an additional check for PlibC, before pthreads is 
used. The check is only done under cygwin and mingw environments.

Furthermore, an older version of plibc.h was in the include directory. 
This gives some problems if you are using a newer version of the PlibC 
library. So I propose to exclude src/include/plibc.h from the SVN

Files affected:
acinclude.m4 (modified)
configure.ac (modified)
src/include/plibc.h (deleted)

2- setsockopt() uses a different parameter type under Windows ("optval" 
is const char). This caused an error when src/daemon/daemon.c was compiled.

The patch enclosed includes a different call of the setsockopt() on 
Windows machines.
Important: IPV6_V6ONLY is not available on Windows machines < Windows 7! 
So this parameter is "0". But there is a TODO comment, maybe someone has 
an idea how to solve this on Windows XP machines.

Files affected:
src/daemon/daemon.c (modified)

I have tested the patch on a MinGW / MSYS environment only.

Best regards

Gerrit.

libmicrohttpd-windows.patch


Diffstat:
MAUTHORS | 1+
MChangeLog | 3+++
Macinclude.m4 | 183+++++++++++++++++++++++++++++++++++++++++++++++++------------------------------
Mconfigure.ac | 20+++++++++++++++-----
Msrc/daemon/daemon.c | 17++++++++++++++++-
5 files changed, 148 insertions(+), 76 deletions(-)

diff --git a/AUTHORS b/AUTHORS @@ -24,6 +24,7 @@ Mike Crowe <mac@mcrowe.com> John Muth <muth@parascale.com> Geoffrey McRae <geoff@spacevs.com> Piotr Grzybowski <narsil.pl@gmail.com> +Gerrit Telkamp <g.telkamp@domologic.de> Documentation contributions also came from: Marco Maggi <marco.maggi-ipsu@poste.it> diff --git a/ChangeLog b/ChangeLog @@ -1,3 +1,6 @@ +Thu Aug 19 13:26:00 CEST 2010 + Patches for Windows to ease compilation trouble. -GT/CG + Sat Aug 14 15:43:30 CEST 2010 Fixed small, largely hypothetical leaks. Reduced calls to strlen for header processing. -CG diff --git a/acinclude.m4 b/acinclude.m4 @@ -1,75 +1,118 @@ +AC_DEFUN([CHECK_PLIBC], +[ + # On windows machines, check if PlibC is available. First try without -plibc + AC_TRY_LINK( + [ + #include <plibc.h> + ],[ + plibc_init("", ""); + ],[ + AC_MSG_RESULT(yes) + PLIBC_CPPFLAGS= + PLIBC_LDFLAGS= + PLIBC_LIBS= + ],[ + + # now with -plibc + AC_CHECK_LIB(plibc,plibc_init, + [ + PLIBC_CPPFLAGS= + PLIBC_LDFLAGS= + PLIBC_LIBS=-lplibc + ],[ + AC_MSG_CHECKING(if PlibC is installed) + save_CPPFLAGS="$CPPFLAGS" + CPPFLAGS="$CPPFLAGS -plibc" + AC_TRY_LINK( + [ + #include <plibc.h> + ],[ + plibc_init("", ""); + ],[ + AC_MSG_RESULT(yes) + PLIBC_CPPFLAGS=-plibc + PLIBC_LDFLAGS=-plibc + PLIBC_LIBS= + ],[ + AC_MSG_ERROR([PlibC is not available on your windows machine!]) + ]) + ]) + ]) + CPPFLAGS="$save_CPPFLAGS" +]) + # See: http://gcc.gnu.org/ml/gcc/2000-05/msg01141.html AC_DEFUN([CHECK_PTHREAD], [ - # first try without -pthread - AC_TRY_LINK( - [ - #include <pthread.h> - ],[ - pthread_create(0,0,0,0); - ],[ - AC_MSG_RESULT(yes) - PTHREAD_CPPFLAGS= - PTHREAD_LDFLAGS= - PTHREAD_LIBS= - ],[ - # now with -pthread - AC_CHECK_LIB(pthread,pthread_create, - [ - PTHREAD_CPPFLAGS= - PTHREAD_LDFLAGS= - PTHREAD_LIBS=-lpthread - ],[ - AC_MSG_CHECKING(if compiler supports -pthread) - save_CPPFLAGS="$CPPFLAGS" - CPPFLAGS="$CPPFLAGS -pthread" - AC_TRY_LINK( - [ - #include <pthread.h> - ],[ - pthread_create(0,0,0,0); - ],[ - AC_MSG_RESULT(yes) - PTHREAD_CPPFLAGS=-pthread - PTHREAD_LDFLAGS=-pthread - PTHREAD_LIBS= - ],[ - AC_MSG_RESULT(no) - AC_MSG_CHECKING(if compiler supports -pthreads) - save_CPPFLAGS="$CPPFLAGS" - CPPFLAGS="$save_CPPFLAGS -pthreads" - AC_TRY_LINK( - [ - #include <pthread.h> - ],[ - pthread_create(0,0,0,0); - ],[ - AC_MSG_RESULT(yes) - PTHREAD_CPPFLAGS=-pthreads - PTHREAD_LDFLAGS=-pthreads - PTHREAD_LIBS= - ],[ - AC_MSG_RESULT(no) - AC_MSG_CHECKING(if compiler supports -threads) - save_CPPFLAGS="$CPPFLAGS" - CPPFLAGS="$save_CPPFLAGS -threads" - AC_TRY_LINK( - [ - #include <pthread.h> - ],[ - pthread_create(0,0,0,0); - ],[ - AC_MSG_RESULT(yes) - PTHREAD_CPPFLAGS=-threads - PTHREAD_LDFLAGS=-threads - PTHREAD_LIBS= - ],[ - AC_MSG_ERROR([Your system is not supporting pthreads!]) - ]) - ]) - ]) - CPPFLAGS="$save_CPPFLAGS" - ]) - + # first try without -pthread + AC_TRY_LINK( + [ + #include <pthread.h> + ],[ + pthread_create(0,0,0,0); + ],[ + AC_MSG_RESULT(yes) + PTHREAD_CPPFLAGS= + PTHREAD_LDFLAGS= + PTHREAD_LIBS= + ],[ + + # now with -pthread + AC_CHECK_LIB(pthread,pthread_create, + [ + PTHREAD_CPPFLAGS= + PTHREAD_LDFLAGS= + PTHREAD_LIBS=-lpthread + ],[ + AC_MSG_CHECKING(if compiler supports -pthread) + save_CPPFLAGS="$CPPFLAGS" + CPPFLAGS="$CPPFLAGS -pthread" + AC_TRY_LINK( + [ + #include <pthread.h> + ],[ + pthread_create(0,0,0,0); + ],[ + AC_MSG_RESULT(yes) + PTHREAD_CPPFLAGS=-pthread + PTHREAD_LDFLAGS=-pthread + PTHREAD_LIBS= + ],[ + AC_MSG_RESULT(no) + AC_MSG_CHECKING(if compiler supports -pthreads) + save_CPPFLAGS="$CPPFLAGS" + CPPFLAGS="$save_CPPFLAGS -pthreads" + AC_TRY_LINK( + [ + #include <pthread.h> + ],[ + pthread_create(0,0,0,0); + ],[ + AC_MSG_RESULT(yes) + PTHREAD_CPPFLAGS=-pthreads + PTHREAD_LDFLAGS=-pthreads + PTHREAD_LIBS= + ],[ + AC_MSG_RESULT(no) + AC_MSG_CHECKING(if compiler supports -threads) + save_CPPFLAGS="$CPPFLAGS" + CPPFLAGS="$save_CPPFLAGS -threads" + AC_TRY_LINK( + [ + #include <pthread.h> + ],[ + pthread_create(0,0,0,0); + ],[ + AC_MSG_RESULT(yes) + PTHREAD_CPPFLAGS=-threads + PTHREAD_LDFLAGS=-threads + PTHREAD_LIBS= + ],[ + AC_MSG_ERROR([Your system is not supporting pthreads!]) + ]) + ]) + ]) + CPPFLAGS="$save_CPPFLAGS" ]) + ]) ]) diff --git a/configure.ac b/configure.ac @@ -72,6 +72,8 @@ then CFLAGS="-fno-strict-aliasing $CFLAGS" fi +# for pkg-config +MHD_LIBDEPS="" # Check system type case "$host_os" in @@ -115,12 +117,24 @@ netbsd*) AC_DEFINE_UNQUOTED(CYGWIN,1,[This is a Cygwin system]) AM_CONDITIONAL(HAVE_GNU_LD, false) LDFLAGS="$LDFLAGS -no-undefined" + # check if PlibC is available + CHECK_PLIBC + LIBS="$PLIBC_LIBS $LIBS" + AC_SUBST(PLIBC_LIBS) + AC_SUBST(PLIBC_LDFLAGS) + AC_SUBST(PLIBC_CPPFLAGS) ;; *mingw*) AC_DEFINE_UNQUOTED(MINGW,1,[This is a MinGW system]) AC_DEFINE_UNQUOTED(WINDOWS,1,[This is a Windows system]) - LDFLAGS="$LDFLAGS -no-undefined -Wl,--export-all-symbols -lws2_32 -lplibc" + LDFLAGS="$LDFLAGS -no-undefined -Wl,--export-all-symbols -lws2_32" AM_CONDITIONAL(HAVE_GNU_LD, true) + # check if PlibC is available + CHECK_PLIBC + LIBS="$PLIBC_LIBS $LIBS" + AC_SUBST(PLIBC_LIBS) + AC_SUBST(PLIBC_LDFLAGS) + AC_SUBST(PLIBC_CPPFLAGS) ;; *openedition*) AC_DEFINE_UNQUOTED(OS390,1,[This is a OS/390 system]) @@ -133,10 +147,6 @@ netbsd*) ;; esac - -# for pkg-config -MHD_LIBDEPS="" - CHECK_PTHREAD LIBS="$PTHREAD_LIBS $LIBS" AC_SUBST(PTHREAD_LIBS) diff --git a/src/daemon/daemon.c b/src/daemon/daemon.c @@ -1642,10 +1642,25 @@ MHD_start_daemon_va (unsigned int options, if ((options & MHD_USE_IPv6) != 0) { +#ifdef IPPROTO_IPV6 +#ifdef IPV6_V6ONLY + /* Note: "IPV6_V6ONLY" is declared by Windows Vista ff., see "IPPROTO_IPV6 Socket Options" + (http://msdn.microsoft.com/en-us/library/ms738574%28v=VS.85%29.aspx); + and may also be missing on older POSIX systems; good luck if you have any of those, + your IPv6 socket may then also bind against IPv4... */ +#ifndef WINDOWS const int on = 1; setsockopt (socket_fd, IPPROTO_IPV6, IPV6_V6ONLY, - &on, sizeof (on)); + &on, sizeof (on)); +#else + const char on = 1; + setsockopt (socket_fd, + IPPROTO_IPV6, IPV6_V6ONLY, + &on, sizeof (on)); +#endif +#endif +#endif } if (BIND (socket_fd, servaddr, addrlen) == -1) {