# Declare the sub-directories to be built here
# Get the 'head' of the build environment. This includes default targets and
# build this level's files
# Make sure all needed macro's are defined
SSL_APP = $(NTLSSDK)/apps
$(error '$(NTLSSDK)' does NOT point to a valid NTLS SDK!)
SSL_INC = $(OSSLSDK)/outinc_nw_libc
SSL_LIB = $(OSSLSDK)/out_nw_libc
SSL_BIN = $(OSSLSDK)/out_nw_libc
SSL_APP = $(OSSLSDK)/apps
$(error '$(OSSLSDK)' does NOT point to a valid OpenSSL SDK!)
# These directories will be at the beginning of the include list, followed by
# These flags will come after CFLAGS
# These defines will come after DEFINES
# These flags will be added to the
link.opt file
# These values will be appended to the correct variables based on the value of
ifeq "$(RELEASE)" "debug"
ifeq "$(RELEASE)" "noopt"
ifeq "$(RELEASE)" "release"
# 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.
# This is used by the link '-desc ' directive.
# If left blank, NLM_NAME will be used.
NLM_DESCRIPTION = Apache $(VERSION_STR) SSL module (NTLS)
NLM_DESCRIPTION = Apache $(VERSION_STR) SSL module (OpenSSL)
# 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
# If this is specified, it will override the default of 64K
# If this is specified it will be used by the link '-entry' directive
# If this is specified it will be used by the link '-exit' directive
# If this is specified it will be used by the link '-check' directive
# If this is specified it will be used by the link '-flags' directive
# 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
# Declare all target files (you must add your files here)
# If there is an NLM target, put it here
$(OBJDIR)/$(NLM_NAME).nlm \
# If there is an LIB target, put it here
# These are the OBJ files needed to create the NLM target above.
# Paths must all use the '/' character
FILES_nlm_objs := $(patsubst %.c,$(OBJDIR)/%.o,$(filter-out $(wildcard *ssl_ct*.c),$(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.
# 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 += ntls \
# If the nlm has a msg file, put it's path here
# If the nlm has a hlp file put it's path here
# Any additional imports go here
# Don't link with Winsock if standard sockets are being used
ifneq "$(USE_STDSOCKETS)" "1"
GetSuperHighResolutionTimer \
# Any symbols exported to here
# These are the OBJ files needed to create the LIB target above.
# Paths must all use the '/' character
# implement targets and dependancies (leave this section alone)
libs :: $(OBJDIR) $(TARGET_lib)
nlms :: libs $(TARGET_nlm)
# Updated this target to create necessary directories and copy files to the
$(call COPY,$(OBJDIR)/*.nlm, $(INSTALLBASE)/modules/)
$(call COPY,$(SSL_BIN)/
openssl.nlm, $(INSTALLBASE)/bin/)
$(call COPY,$(SSL_APP)/
openssl.cnf, $(INSTALLBASE)/bin/)
# Any specialized rules here
# Include the 'tail' makefile that has targets that depend on variables defined