]> git.ipfire.org Git - thirdparty/apache/httpd.git/commitdiff
Integrate support for the Cygwin 1.x platform (a POSIX emulation layer
authorMartin Kraemer <martin@apache.org>
Mon, 2 Apr 2001 09:22:11 +0000 (09:22 +0000)
committerMartin Kraemer <martin@apache.org>
Mon, 2 Apr 2001 09:22:11 +0000 (09:22 +0000)
for Win32 systems, see http://www.cygwin.com)
[Stipe Tolj <tolj@wapme-systems.de>]

PR: #2936
Submitted by: Stipe Tolj <tolj@wapme-systems.de>
Reviewed by: Roy Fielding, Martin Kraemer

git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/branches/1.3.x@88643 13f79535-47bb-0310-9956-ffa450edef68

12 files changed:
STATUS
src/CHANGES
src/Configure
src/Makefile.tmpl
src/helpers/GuessOS
src/include/ap_config.h
src/main/http_main.c
src/os/cygwin/Makefile.tmpl [new file with mode: 0644]
src/os/cygwin/os-inline.c [new file with mode: 0644]
src/os/cygwin/os.c [new file with mode: 0644]
src/os/cygwin/os.h [new file with mode: 0644]
src/support/logresolve.c

diff --git a/STATUS b/STATUS
index dcd8a1f22b1688edd49840b6694c523a7462260a..fb799c2abae9a3e55a4989c7cdcb0e3072e5f284 100644 (file)
--- a/STATUS
+++ b/STATUS
@@ -1,5 +1,5 @@
 APACHE 1.3 STATUS:                                             -*-text-*-
-  Last modified at [$Date: 2001/03/28 12:20:20 $]
+  Last modified at [$Date: 2001/04/02 09:22:02 $]
 
 Release:
 
@@ -62,11 +62,6 @@ RELEASE NON-SHOWSTOPPERS BUT WOULD BE REAL NICE TO WRAP THESE UP:
         Message-ID: <199907080712.JAA28269@chill.innovation.ch>
         Status:
 
-    * Stipe Tolj's Cygwin32 port
-        Message-ID: <3AB10E79.8218ED79@wapme-systems.de> for 1.3.19
-       Original PR#: 2936
-        Status: Roy +1
-        Lame-o conceptual musings: +1 from Lars, Martin, Ken, Jim
 
 Documentation that needs writing:
 
index 9238f7f5748f16fca3143116f37846b7032db1e0..ef4d95fd2f5b698f9aa9fc795d51bd4edd31ab88 100644 (file)
@@ -1,5 +1,9 @@
 Changes with Apache 1.3.20
 
+  *) Integrate support for the Cygwin 1.x platform (a POSIX emulation layer
+     for Win32 systems, see http://www.cygwin.com)
+     [Stipe Tolj <tolj@wapme-systems.de>]
+
   *) Changes to 'ab'; fixed int overrun's, added statistics, output in
      csv/gnuplot format, rudimentary ssl support and various other tweaks
      to make results more true to what is measured. The upshot of this it
index 1bf5a6fc940e8b0c608f67d1f2df03ff997f4c5e..b458e41250e01f03c64f2fc77537ca13101fcbf9 100755 (executable)
@@ -835,6 +835,13 @@ case "$PLAT" in
        DEF_WANTHSREGEX=yes
        LIBS="$LIBS"
        ;;
+    *-cygwin*)
+       OS='Cygwin'
+       OSDIR="os/cygwin"
+       CFLAGS="$CFLAGS -DCYGWIN"
+       DEF_WANTHSREGEX=yes
+       LIBS="$LIBS -lcrypt"
+       ;;
     *) # default: Catch systems we don't know about
        OS='Unknown and unsupported OS'
        echo Sorry, but we cannot grok \"$PLAT\"
@@ -1378,6 +1385,19 @@ if [ "x$using_shlib" = "x1" ] ; then
            LDFLAGS_MOD_SHLIB=$LDFLAGS_SHLIB
            LDFLAGS_SHLIB_EXPORT=""
             ;;
+       *-cygwin*)
+           DEF_SHARED_CORE=yes
+           LDFLAGS_SHLIB="-g"
+           LDFLAGS_MOD_SHLIB=$LDFLAGS_SHLIB
+           SHLIB_SUFFIX_NAME=dll
+           SHLIB_SUFFIX_DEPTH=0
+           DLL_IMPORT_LIB='lib$(TARGET).a'
+           DLL_IMPORT_DEF='lib$(TARGET).def'
+           LD_SHLIB='dllwrap --export-all --output-def $(DLL_IMPORT_DEF) --implib $(DLL_IMPORT_LIB) --driver-name $(CC)'
+           LD_SHCORE_LIBS='$(LIBS)'
+           LIBS_SHLIB='$(EXTRA_LIBS)'
+           SHARED_CORE_EP=''
+           ;;
        *)
            ##  ok, no known explict support for shared objects
            ##  on this platform, but we give not up immediately.
@@ -1855,7 +1875,11 @@ if [ "x$using_shlib" = "x1" ] ; then
        RULE_SHARED_CORE=$DEF_SHARED_CORE
     fi
     if [ "x$RULE_SHARED_CORE" = "xyes" ]; then
-       echo " + enabling generation of Apache core as DSO"
+       DSO_STRING="DSO"
+       if [ "$OS" = "Cygwin" ]; then
+           DSO_STRING="DLL"
+       fi
+       echo " + enabling generation of Apache core as $DSO_STRING"
        #    shuffle compiler flags from shlib variant to standard
        CFLAGS="$CFLAGS $CFLAGS_SHLIB"
        CFLAGS_SHLIB=""
@@ -1899,6 +1923,12 @@ if [ "x$using_shlib" = "x1" ] ; then
     if [ "x$TCFLAGS_SHLIB" = "x" ]; then
        echo "CFLAGS_SHLIB=$CFLAGS_SHLIB -DSHARED_MODULE" >> Makefile.config
     fi
+    if [ "x$TDLL_IMPORT_DEF" = "x" ]; then
+       echo "DLL_IMPORT_DEF=$DLL_IMPORT_DEF" >> Makefile.config
+    fi
+    if [ "x$TDLL_IMPORT_LIB" = "x" ]; then
+       echo "DLL_IMPORT_LIB=$DLL_IMPORT_LIB" >> Makefile.config
+    fi
     if [ "x$TLD_SHLIB" = "x" ]; then
        echo "LD_SHLIB=$LD_SHLIB" >> Makefile.config
     fi
index b8aeb09ec9490e6b3c5180e2d64e308ac137147b..643e8982d84fa7815bc3f04c01bbe2cc87ec59e4 100644 (file)
@@ -41,7 +41,7 @@ target_compile_only: subdirs modules.o
 target_shared: $(SHCORE_IMPLIB) $(SHARED_CORE_EP) lib$(TARGET).$(SHLIB_SUFFIX_NAME)
        $(CC) $(INCLUDES) $(CFLAGS) $(LDFLAGS) $(LDFLAGS_SHLIB_EXPORT) \
              -o $(TARGET) -DSHARED_CORE_BOOTSTRAP main/http_main.c \
-             ap/libap.a $(LIBS) $(SHCORE_IMPLIB)
+             ap/libap.a $(LIBS) $(SHCORE_IMPLIB) $(DLL_IMPORT_LIB)
 
 lib$(TARGET).ep: lib$(TARGET).$(SHLIB_SUFFIX_NAME)
        $(CC) $(INCLUDES) $(CFLAGS) $(LDFLAGS) $(LDFLAGS_SHLIB_EXPORT) \
index 9ffcfe81bdfc9a1967b3917f0d44a363824d4a9f..49e6dfaa6e107c81ef226d68e28e3700d375fd10 100755 (executable)
@@ -313,6 +313,9 @@ case "${SYSTEM}:${RELEASE}:${VERSION}:${MACHINE}" in
     OS/390:*)
         echo "${MACHINE}-IBM-OS390-${RELEASE}-${VERSION}"; exit 0;
         ;;
+    CYGWIN*:*:*:*)
+       echo "${MACHINE}-whatever-cygwin"; exit 0
+       ;;
 esac
 
 #
index 877ff080a876a28dc8881885db4a4417531055c5..1cb89544222c636a153c7b98a4846e74c226c6ea 100644 (file)
@@ -1000,6 +1000,11 @@ typedef int rlim_t;
 #define NET_SIZE_T size_t
 #define NEED_HASHBANG_EMUL
 
+#elif defined(CYGWIN)               /* Cygwin 1.x POSIX layer for Win32 */
+#define JMP_BUF jmp_buf
+#define NO_KILLPG
+#define USE_LONGJMP
+
 #else
 /* Unknown system - Edit these to match */
 #ifdef BSD
index cb3fc6bb7cfbea65e9b49c6b32e1300a57ef72d2..d46db7e3601ee650aca25ddc5c4497925d743676 100644 (file)
@@ -117,7 +117,7 @@ int ap_main(int argc, char *argv[]);
 #endif
 #ifdef WIN32
 #include "../os/win32/getopt.h"
-#elif !defined(BEOS) && !defined(TPF) && !defined(NETWARE) && !defined(OS390)
+#elif !defined(BEOS) && !defined(TPF) && !defined(NETWARE) && !defined(OS390) && !defined(CYGWIN)
 #include <netinet/tcp.h>
 #endif
 #ifdef HAVE_BSTRING_H
@@ -7167,8 +7167,12 @@ int main(int argc, char *argv[])
 #endif /* ndef SHARED_CORE_TIESTATIC */
 #else  /* ndef SHARED_CORE_BOOTSTRAP */
 
-#ifdef OS2
-/* Shared core loader for OS/2 */
+#if defined(OS2) || defined(CYGWIN)
+/* Shared core loader for OS/2 and Cygwin */
+
+#if defined(CYGWIN)
+__declspec(dllimport) 
+#endif
 
 int ap_main(int argc, char *argv[]); /* Load time linked from libhttpd.dll */
 
diff --git a/src/os/cygwin/Makefile.tmpl b/src/os/cygwin/Makefile.tmpl
new file mode 100644 (file)
index 0000000..5123c5a
--- /dev/null
@@ -0,0 +1,46 @@
+CFLAGS=$(OPTIM) $(CFLAGS1) $(EXTRA_CFLAGS)
+LIBS=$(EXTRA_LIBS) $(LIBS1)
+INCLUDES=$(INCLUDES1) $(INCLUDES0) $(EXTRA_INCLUDES)
+LDFLAGS=$(LDFLAGS1) $(EXTRA_LDFLAGS)
+
+OBJS=  os.o os-inline.o
+
+LIB=   libos.a
+
+all:   $(LIB)
+
+$(LIB): $(OBJS)
+       rm -f $@
+       ar cr $@ $(OBJS)
+       $(RANLIB) $@
+
+.c.o:
+       $(CC) -c $(INCLUDES) $(CFLAGS) $<
+
+clean:
+       rm -f $(OBJS) $(LIB)
+
+distclean: clean
+       -rm -f Makefile
+
+# We really don't expect end users to use this rule.  It works only with
+# gcc, and rebuilds Makefile.tmpl.  You have to re-run Configure after
+# using it.
+depend:
+       cp Makefile.tmpl Makefile.tmpl.bak \
+           && sed -ne '1,/^# DO NOT REMOVE/p' Makefile.tmpl > Makefile.new \
+           && gcc -MM $(INCLUDES) $(CFLAGS) *.c >> Makefile.new \
+           && sed -e '1,$$s: $(INCDIR)/: $$(INCDIR)/:g' \
+                  -e '1,$$s: $(OSDIR)/: $$(OSDIR)/:g' Makefile.new \
+               > Makefile.tmpl \
+           && rm Makefile.new
+
+$(OBJS): Makefile
+
+# DO NOT REMOVE
+os-inline.o: os-inline.c $(INCDIR)/ap_config.h \
+ $(INCDIR)/ap_mmn.h $(INCDIR)/ap_config_auto.h \
+ $(OSDIR)/os.h $(INCDIR)/ap_ctype.h $(INCDIR)/hsregex.h
+os.o: os.c $(INCDIR)/ap_config.h $(INCDIR)/ap_mmn.h \
+ $(INCDIR)/ap_config_auto.h $(OSDIR)/os.h \
+ $(INCDIR)/ap_ctype.h $(INCDIR)/hsregex.h os.h
diff --git a/src/os/cygwin/os-inline.c b/src/os/cygwin/os-inline.c
new file mode 100644 (file)
index 0000000..54ff49a
--- /dev/null
@@ -0,0 +1,31 @@
+/*
+ * This file contains functions which can be inlined if the compiler
+ * has an "inline" modifier. Because of this, this file is both a
+ * header file and a compilable module.
+ *
+ * Only inlineable functions should be defined in here. They must all
+ * include the INLINE modifier. 
+ *
+ * If the compiler supports inline, this file will be #included as a
+ * header file from os.h to create all the inline function
+ * definitions. INLINE will be defined to whatever is required on
+ * function definitions to make them inline declarations.
+ *
+ * If the compiler does not support inline, this file will be compiled
+ * as a normal C file into libos.a (along with os.c). In this case
+ * INLINE will _not_ be set so we can use this to test if we are
+ * compiling this source file.  
+ */
+
+#ifndef INLINE
+#define INLINE
+
+/* Anything required only when compiling */
+#include "ap_config.h"
+
+#endif
+
+INLINE int ap_os_is_path_absolute(const char *file)
+{
+  return file[0] == '/';
+}
diff --git a/src/os/cygwin/os.c b/src/os/cygwin/os.c
new file mode 100644 (file)
index 0000000..e9457e9
--- /dev/null
@@ -0,0 +1,46 @@
+/*
+ * This file will include OS specific functions which are not inlineable.
+ * Any inlineable functions should be defined in os-inline.c instead.
+ */
+
+#include "ap_config.h"
+#include "os.h"
+
+
+/* some linkers complain unless there's at least one function in each
+ * .o file... and extra prototype is for gcc -Wmissing-prototypes
+ */
+extern void ap_is_not_here(void);
+void ap_is_not_here(void) {}
+
+/*
+ *  Abstraction layer for loading
+ *  Apache modules under run-time via 
+ *  dynamic shared object (DSO) mechanism
+ */
+
+void ap_os_dso_init(void)
+{
+}
+
+void *ap_os_dso_load(const char *path)
+{
+    return dlopen(path, RTLD_NOW | RTLD_GLOBAL);
+}
+
+void ap_os_dso_unload(void *handle)
+{
+    dlclose(handle);
+
+    return;
+}
+
+void *ap_os_dso_sym(void *handle, const char *symname)
+{
+    return dlsym(handle, symname);
+}
+
+const char *ap_os_dso_error(void)
+{
+    return dlerror();
+}
diff --git a/src/os/cygwin/os.h b/src/os/cygwin/os.h
new file mode 100644 (file)
index 0000000..19be8d0
--- /dev/null
@@ -0,0 +1,157 @@
+/* ====================================================================
+ * The Apache Software License, Version 1.1
+ *
+ * Copyright (c) 2000 The Apache Software Foundation.  All rights
+ * reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ *
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ *
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in
+ *    the documentation and/or other materials provided with the
+ *    distribution.
+ *
+ * 3. The end-user documentation included with the redistribution,
+ *    if any, must include the following acknowledgment:
+ *       "This product includes software developed by the
+ *        Apache Software Foundation (http://www.apache.org/)."
+ *    Alternately, this acknowledgment may appear in the software itself,
+ *    if and wherever such third-party acknowledgments normally appear.
+ *
+ * 4. The names "Apache" and "Apache Software Foundation" must
+ *    not be used to endorse or promote products derived from this
+ *    software without prior written permission. For written
+ *    permission, please contact apache@apache.org.
+ *
+ * 5. Products derived from this software may not be called "Apache",
+ *    nor may "Apache" appear in their name, without prior written
+ *    permission of the Apache Software Foundation.
+ *
+ * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+ * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
+ * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+ * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
+ * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
+ * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ * ====================================================================
+ *
+ * This software consists of voluntary contributions made by many
+ * individuals on behalf of the Apache Software Foundation.  For more
+ * information on the Apache Software Foundation, please see
+ * <http://www.apache.org/>.
+ *
+ * Portions of this software are based upon public domain software
+ * originally written at the National Center for Supercomputing Applications,
+ * University of Illinois, Urbana-Champaign.
+ */
+
+#ifndef APACHE_OS_H
+#define APACHE_OS_H
+
+#include "ap_config.h"
+
+/*
+ * Define the API_EXPORT declaration for creating a dynamic
+ * loadable library (DLL) version of Apache on Cygwin 1.x platforms.
+ */
+
+#ifndef API_EXPORT
+#ifdef SHARED_CORE
+# define API_EXPORT(type)    __declspec(dllexport) type
+#else /* Not SHARED_CORE */
+# define API_EXPORT(type)    __declspec(dllimport) type
+#endif /* def SHARED_CORE */ 
+#endif /* ndef API_EXPORT */
+
+/*
+ * We don't consider the Cygwin 1.x support neither an Unix nor
+ * a Win32 platform. Basicly it's something between both, so that
+ * is why we introduce our own PLATFORM define.
+ */
+#ifndef PLATFORM
+#define PLATFORM "Cygwin"
+#endif
+
+/*
+ * This file in included in all Apache source code. It contains definitions
+ * of facilities available on _this_ operating system (HAVE_* macros),
+ * and prototypes of OS specific functions defined in os.c or os-inline.c
+ */
+
+#if !defined(INLINE) && defined(USE_GNU_INLINE)
+/* Compiler supports inline, so include the inlineable functions as
+ * part of the header
+ */
+#define INLINE extern ap_inline
+
+INLINE int ap_os_is_path_absolute(const char *file);
+
+/*
+ * The inline things are the same as in the os/unix branch, so include
+ * that one rather than our own copy that would be the same.
+ */
+#include "os-inline.c"
+
+#else
+
+/* Compiler does not support inline, so prototype the inlineable functions
+ * as normal
+ */
+extern int ap_os_is_path_absolute(const char *file);
+#endif
+
+/* Other ap_os_ routines not used by this platform */
+
+#define ap_os_is_filename_valid(f)          (1)
+#define ap_os_kill(pid, sig)                kill(pid, sig)
+
+/*
+ *  Abstraction layer for loading
+ *  Apache modules under run-time via 
+ *  dynamic shared object (DSO) mechanism
+ */
+
+#ifdef HAVE_DL_H
+#include <dl.h>
+#endif
+
+#ifdef HAVE_DLFCN_H
+#include <dlfcn.h>
+#else
+void *dlopen(const char *, int);
+int dlclose(void *);
+void *dlsym(void *, const char *);
+const char *dlerror(void);
+#endif
+
+/* probably on an older system that doesn't support RTLD_NOW or RTLD_LAZY.
+ * The below define is a lie since we are really doing RTLD_LAZY since the
+ * system doesn't support RTLD_NOW.
+ */
+#ifndef RTLD_NOW
+#define RTLD_NOW 1
+#endif
+
+#ifndef RTLD_GLOBAL
+#define RTLD_GLOBAL 0
+#endif
+
+#define     ap_os_dso_handle_t  void *
+void        ap_os_dso_init(void);
+void *      ap_os_dso_load(const char *);
+void        ap_os_dso_unload(void *);
+void *      ap_os_dso_sym(void *, const char *);
+const char *ap_os_dso_error(void);
+
+#endif /* !APACHE_OS_H */
index f6c86953500a93d384fc11ff6d4c53f6436df4cf..489d717b02d62ae73ebc64d02be548c63702b23f 100644 (file)
@@ -101,7 +101,7 @@ struct nsrec {
  * statistics - obvious
  */
 
-#ifndef h_errno
+#if !defined(h_errno) && !defined(CYGWIN)
 extern int h_errno; /* some machines don't have this in their headers */
 #endif