]> granicus.if.org Git - apache/commitdiff
NetWare build bits for mod_h2
authorGregg Lewis Smith <gsmith@apache.org>
Fri, 21 Aug 2015 19:47:27 +0000 (19:47 +0000)
committerGregg Lewis Smith <gsmith@apache.org>
Fri, 21 Aug 2015 19:47:27 +0000 (19:47 +0000)
Submitted by normw gknw net

git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@1697051 13f79535-47bb-0310-9956-ffa450edef68

build/NWGNUenvironment.inc
modules/NWGNUmakefile
modules/http2/NWGNUmakefile [new file with mode: 0644]

index 52295608fdaf9c9a75e0a84ff2b8adc3b12552f4..0e510c0b859ff4b6358c1ae12990af342fa8377b 100644 (file)
@@ -49,6 +49,12 @@ ifneq "$(wildcard $(LDAPSDK)/inc/ldap.h)" "$(LDAPSDK)/inc/ldap.h"
 $(error LDAPSDK does not point to a valid Novell CLDAP SDK) 
 endif
 
+ifdef WITH_HTTP2
+ifneq "$(wildcard $(NGH2SRC)/lib/nghttp2_hd.h)" "$(NGH2SRC)/lib/nghttp2_hd.h"
+$(error NGH2SRC does not point to a valid NGHTTP2 source tree)
+endif
+endif
+
 ifndef PCRESRC
 PCRESRC = $(AP_WORK)/srclib/pcre
 endif
index 0cc2abdefd06813535b9c9769842abb8be44d084..179cec3cde31261280b03e79868076b8b5fb7def 100644 (file)
@@ -5,7 +5,8 @@
 #  variable WITH_SSL=1
 # To build with the mod_lua module set the environment
 #  variable WITH_LUA=1
-
+# To build with the mod_h2 module set the environment
+#  variable WITH_HTTP2=1
 #
 # Check if LDAP is enabled in APR-UTIL
 #
@@ -73,6 +74,13 @@ SUBDIRS += lua
 endif
 endif
 
+# Allow the mod_h2 module to be built if WITH_HTTP2 is defined
+ifeq "$(WITH_HTTP2)" "1"
+ifneq "$(NGH2SRC)" ""
+SUBDIRS += http2
+endif
+endif
+
 # Allow the experimental modules to be built if WITH_EXPERIMENTAL is defined
 ifeq "$(WITH_EXPERIMENTAL)" "1"
 SUBDIRS += experimental
diff --git a/modules/http2/NWGNUmakefile b/modules/http2/NWGNUmakefile
new file mode 100644 (file)
index 0000000..cc08702
--- /dev/null
@@ -0,0 +1,331 @@
+#
+# This Makefile requires the environment var NGH2SRC
+# pointing to the base directory of nghttp2 source tree.
+#
+
+#
+# Declare the sub-directories to be built here
+#
+
+SUBDIRS = \
+       $(EOLIST)
+
+#
+# Get the 'head' of the build environment.  This includes default targets and
+# paths to tools
+#
+
+include $(AP_WORK)/build/NWGNUhead.inc
+
+#
+# build this level's files
+#
+# Make sure all needed macro's are defined
+#
+
+#
+# These directories will be at the beginning of the include list, followed by
+# INCDIRS
+#
+XINCDIRS       += \
+                       $(APR)/include \
+                       $(APRUTIL)/include \
+                       $(SRC)/include \
+                       $(NGH2SRC)/lib/ \
+                       $(NGH2SRC)/lib/includes \
+                       $(SERVER)/mpm/NetWare \
+                       $(NWOS) \
+                       $(EOLIST)
+
+#
+# These flags will come after CFLAGS
+#
+XCFLAGS                += \
+                       $(EOLIST)
+
+#
+# These defines will come after DEFINES
+#
+XDEFINES       += \
+                       -DHAVE_CONFIG_H \
+                       $(EOLIST)
+
+#
+# These flags will be added to the link.opt file
+#
+XLFLAGS                += \
+                       -L$(OBJDIR) \
+                       $(EOLIST)
+
+#
+# These values will be appended to the correct variables based on the value of
+# RELEASE
+#
+ifeq "$(RELEASE)" "debug"
+XINCDIRS       += \
+                       $(EOLIST)
+
+XCFLAGS                += \
+                       $(EOLIST)
+
+XDEFINES       += \
+                       $(EOLIST)
+
+XLFLAGS                += \
+                       $(EOLIST)
+endif
+
+ifeq "$(RELEASE)" "noopt"
+XINCDIRS       += \
+                       $(EOLIST)
+
+XCFLAGS                += \
+                       $(EOLIST)
+
+XDEFINES       += \
+                       $(EOLIST)
+
+XLFLAGS                += \
+                       $(EOLIST)
+endif
+
+ifeq "$(RELEASE)" "release"
+XINCDIRS       += \
+                       $(EOLIST)
+
+XCFLAGS                += \
+                       $(EOLIST)
+
+XDEFINES       += \
+                       $(EOLIST)
+
+XLFLAGS                += \
+                       $(EOLIST)
+endif
+
+#
+# These are used by the link target if an NLM is being generated
+# This is used by the link 'name' directive to name the nlm.  If left blank
+# TARGET_nlm (see below) will be used.
+#
+NLM_NAME       = mod_h2
+
+#
+# This is used by the link '-desc ' directive.
+# If left blank, NLM_NAME will be used.
+#
+NLM_DESCRIPTION        = Apache $(VERSION_STR) HTTP2 Support module (w/ NGHTTP2 Lib)
+
+#
+# This is used by the '-threadname' directive.  If left blank,
+# NLM_NAME Thread will be used.
+#
+NLM_THREAD_NAME        = $(NLM_NAME)
+
+#
+# If this is specified, it will override VERSION value in
+# $(AP_WORK)/build/NWGNUenvironment.inc
+#
+NLM_VERSION    =
+
+#
+# If this is specified, it will override the default of 64K
+#
+NLM_STACK_SIZE = 65536
+
+#
+# If this is specified it will be used by the link '-entry' directive
+#
+NLM_ENTRY_SYM  =
+
+#
+# If this is specified it will be used by the link '-exit' directive
+#
+NLM_EXIT_SYM   =
+
+#
+# If this is specified it will be used by the link '-check' directive
+#
+NLM_CHECK_SYM  =
+
+#
+# If this is specified it will be used by the link '-flags' directive
+#
+NLM_FLAGS      =
+
+#
+# If this is specified it will be linked in with the XDCData option in the def
+# file instead of the default of $(NWOS)/apache.xdc.  XDCData can be disabled
+# by setting APACHE_UNIPROC in the environment
+#
+XDCDATA                =
+
+#
+# Declare all target files (you must add your files here)
+#
+
+#
+# If there is an NLM target, put it here
+#
+TARGET_nlm = \
+       $(OBJDIR)/$(NLM_NAME).nlm \
+       $(EOLIST)
+
+#
+# If there is an LIB target, put it here
+#
+TARGET_lib = \
+       $(OBJDIR)/nghttp2.lib \
+       $(EOLIST)
+
+#
+# These are the OBJ files needed to create the NLM target above.
+# Paths must all use the '/' character
+#
+FILES_nlm_objs := $(sort $(patsubst %.c,$(OBJDIR)/%.o,$(wildcard *.c)))
+
+#
+# These are the LIB files needed to create the NLM target above.
+# These will be added as a library command in the link.opt file.
+#
+FILES_nlm_libs = \
+       $(PRELUDE) \
+       $(OBJDIR)/nghttp2.lib \
+       $(EOLIST)
+
+#
+# These are the modules that the above NLM target depends on to load.
+# These will be added as a module command in the link.opt file.
+#
+FILES_nlm_modules = \
+       Libc \
+       Apache2 \
+       $(EOLIST)
+
+#
+# If the nlm has a msg file, put it's path here
+#
+FILE_nlm_msg =
+
+#
+# If the nlm has a hlp file put it's path here
+#
+FILE_nlm_hlp =
+
+#
+# If this is specified, it will override $(NWOS)\copyright.txt.
+#
+FILE_nlm_copyright =
+
+#
+# Any additional imports go here
+#
+FILES_nlm_Ximports = \
+       @libc.imp \
+       @aprlib.imp \
+       @httpd.imp \
+       $(EOLIST)
+
+#
+# Any symbols exported to here
+#
+FILES_nlm_exports = \
+       h2_module \
+       $(EOLIST)
+
+#
+# These are the OBJ files needed to create the LIB target above.
+# Paths must all use the '/' character
+#
+FILES_lib_objs := $(sort $(patsubst $(NGH2SRC)/lib/%.c,$(OBJDIR)/%.o,$(wildcard $(NGH2SRC)/lib/*.c)))
+#
+# implement targets and dependancies (leave this section alone)
+#
+
+libs :: $(OBJDIR) $(NGH2SRC)/lib/config.h $(TARGET_lib)
+
+nlms :: libs $(TARGET_nlm)
+
+#
+# Updated this target to create necessary directories and copy files to the
+# correct place.  (See $(AP_WORK)/build/NWGNUhead.inc for examples)
+#
+install :: nlms FORCE
+       $(call COPY,$(OBJDIR)/*.nlm,        $(INSTALLBASE)/modules/)
+
+clean ::
+       $(call DEL,$(NGH2SRC)/lib/config.h)
+#
+# Any specialized rules here
+#
+vpath %.c $(NGH2SRC)/lib
+
+$(NGH2SRC)/lib/config.h : NWGNUmakefile
+       @echo $(DL)GEN  $@$(DL)
+       @echo $(DL)/* For NetWare target.$(DL) > $@
+       @echo $(DL)** Do not edit - created by Make!$(DL) >> $@
+       @echo $(DL)*/$(DL) >> $@
+       @echo $(DL)#ifndef NGH2_CONFIG_H$(DL) >> $@
+       @echo $(DL)#define NGH2_CONFIG_H$(DL) >> $@
+       @echo #define HAVE_ARPA_INET_H 1 >> $@
+       @echo #define HAVE_CHOWN 1 >> $@
+       @echo #define HAVE_DECL_STRERROR_R 1 >> $@
+       @echo #define HAVE_DLFCN_H 1 >> $@
+       @echo #define HAVE_DUP2 1 >> $@
+       @echo #define HAVE_FCNTL_H 1 >> $@
+       @echo #define HAVE_GETCWD 1 >> $@
+       @echo #define HAVE_INTTYPES_H 1 >> $@
+       @echo #define HAVE_LIMITS_H 1 >> $@
+       @echo #define HAVE_LOCALTIME_R 1 >> $@
+       @echo #define HAVE_MALLOC 1 >> $@
+       @echo #define HAVE_MEMCHR 1 >> $@
+       @echo #define HAVE_MEMMOVE 1 >> $@
+       @echo #define HAVE_MEMORY_H 1 >> $@
+       @echo #define HAVE_MEMSET 1 >> $@
+       @echo #define HAVE_NETDB_H 1 >> $@
+       @echo #define HAVE_NETINET_IN_H 1 >> $@
+       @echo #define HAVE_PTRDIFF_T 1 >> $@
+       @echo #define HAVE_PWD_H 1 >> $@
+       @echo #define HAVE_SOCKET 1 >> $@
+       @echo #define HAVE_SQRT 1 >> $@
+       @echo #define HAVE_STDDEF_H 1 >> $@
+       @echo #define HAVE_STDINT_H 1 >> $@
+       @echo #define HAVE_STDLIB_H 1 >> $@
+       @echo #define HAVE_STRCHR 1 >> $@
+       @echo #define HAVE_STRDUP 1 >> $@
+       @echo #define HAVE_STRERROR 1 >> $@
+       @echo #define HAVE_STRERROR_R 1 >> $@
+       @echo #define HAVE_STRINGS_H 1 >> $@
+       @echo #define HAVE_STRING_H 1 >> $@
+       @echo #define HAVE_STRSTR 1 >> $@
+       @echo #define HAVE_STRTOL 1 >> $@
+       @echo #define HAVE_STRTOUL 1 >> $@
+       @echo #define HAVE_SYSLOG_H 1 >> $@
+       @echo #define HAVE_SYS_SOCKET_H 1 >> $@
+       @echo #define HAVE_SYS_STAT_H 1 >> $@
+       @echo #define HAVE_SYS_TIME_H 1 >> $@
+       @echo #define HAVE_SYS_TYPES_H 1 >> $@
+       @echo #define HAVE_TIME_H 1 >> $@
+       @echo #define HAVE_UNISTD_H 1 >> $@
+
+       @echo #define SIZEOF_INT_P 4 >> $@
+       @echo #define STDC_HEADERS 1 >> $@
+       @echo #define STRERROR_R_CHAR_P 4 >> $@
+
+# Hint to compiler a function parameter is not used
+       @echo #define _U_ >> $@
+
+       @echo #ifndef __cplusplus >> $@
+       @echo #define inline __inline >> $@
+       @echo #endif >> $@
+
+       @echo $(DL)#endif /* NGH2_CONFIG_H */$(DL) >> $@
+
+#
+# Include the 'tail' makefile that has targets that depend on variables defined
+# in this makefile
+#
+
+include $(APBUILD)/NWGNUtail.inc
+
+