--- /dev/null
+PROJECT(HTTPD C)
+
+# Experimental cmake-based build support for Apache httpd on Windows
+#
+# General usage:
+# 0. Read the todos down below and make sure this is good enough for your
+# purposes.
+# 1. cd to a clean directory for building (i.e., don't build in your
+# source tree)
+# 2. cmake -G "some backend, like 'NMake Makefiles'" \
+# -DCMAKE_INSTALL_PREFIX=d:/path/to/httpdinst \
+# -DPCRE_INCLUDE_DIR=d:/path/to/pcreinst/include \
+# -DPCRE_LIBRARIES=d:/path/to/pcreinst/lib/pcre[d].lib \
+# -DAPR_INCLUDE_DIR=d:/path/to/aprinst/include \
+# -DAPR_LIBRARIES=d:/path/to/aprinst/lib/libapr2.lib \
+# -DENABLE_MOD_foo="A|I|O" \
+# d:/path/to/httpdsource
+# Alternately, use cmake-gui and update settings in the GUI.
+#
+# Other flags of interest:
+# CMAKE_C_FLAGS_RELEASE, _DEBUG, _RELWITHDEBINFO, _MINSIZEREL
+# CMAKE_BUILD_TYPE
+# For NMake Makefiles the choices are at least DEBUG, RELEASE,
+# RELWITHDEBINFO, and MINSIZEREL
+# Other backends make have other selections.
+# 3. build using chosen backend (e.g., "nmake install")
+#
+# PCRE_INCLUDE_DIR, PCRE_LIBRARIES, APR_INCLUDE_DIR, APR_LIBRARIES:
+# cmake doesn't bundle FindXXX for these packages, so the crucial
+# information has to be specified in this manner
+#
+# ENABLE_MOD_foo:
+# Each module has a default setting which can be overridden with one of the
+# following values:
+# A build and Activate module
+# I build module but leave it Inactive (commented-out LoadModule)
+# O Omit module completely
+# Example: -DENABLE_MOD_ALLOWHANDLERS="O" (Omit the module)
+#
+# Todos for Windows build:
+# . Support APR 1.x in addition to APR trunk
+# . Handling of module prerequisites
+# . Find support libraries:
+# + "Find" PCRE and APR (no bundled cmake FindXXX macros)
+# + LUA, libxml2, zlib, distcache
+# . Modules not yet supported:
+# + mod_ldap, mod_authnz_ldap, mod_socache_dc, mod_deflate, mod_proxy_html, mod_xml2enc,
+# mod_lua, mod_serf, apreq+mod_apreq, mod_session_crypto
+# + mod_lbmethod_rr and mod_firehose, which don't compile on Windows
+# . Add a way to configure additional statically-linked modules (like --with-module on Unix)
+# . Build buildmark.c when httpd.exe is regenerated
+# . ab + HAVE_OPENSSL isn't working at all, even for plain
+# . ApacheMonitor has a build error
+# . install/customize .conf files
+# . install docroot and CGI examples
+# . install .h fils that are in odd places
+# . Generally: go through the existing Windows build and see what is missing, whether a
+# feature or some build nuance
+
+CMAKE_MINIMUM_REQUIRED(VERSION 2.8)
+
+FIND_PACKAGE(OpenSSL)
+
+# Options for support libraries not supported by cmake-bundled FindFOO
+SET(APR_INCLUDE_DIR "C:/APR/include" CACHE STRING "Directory with APR[-Util] include files")
+SET(APR_LIBRARIES "C:/APR/lib/libapr-2.lib" CACHE STRING "APR libraries to link with")
+SET(PCRE_INCLUDE_DIR "C:/PCRE/include" CACHE STRING "Directory with PCRE include files")
+SET(PCRE_LIBRARIES "C:/PCRE/lib/pcred.lib" CACHE STRING "PCRE libraries to link with")
+# end support library configuration
+
+# Options for each available module
+# "A" ("A"ctive) means installed and active in default .conf, fail if can't be built
+# "I" ("I"nactive) means installed and inactive (LoadModule commented out) in default .conf, fail if can't be built
+# "O" ("O"mit) means not installed, no LoadModule
+# Options to be added later:
+# "a" - like "A", but ignore with a warning if any prereqs aren't available
+# "i" - like "I", but ignore with a warning if any prereqs aren't available
+
+SET(MODULE_LIST
+ "modules/aaa/mod_access_compat.c+A+mod_access compatibility"
+ "modules/aaa/mod_allowhandlers.c+I+restrict allowed handlers"
+ "modules/aaa/mod_allowmethods.c+I+restrict allowed HTTP methods"
+ "modules/aaa/mod_auth_basic.c+A+basic authentication"
+ "modules/aaa/mod_auth_digest.c+I+RFC2617 Digest authentication"
+ "modules/aaa/mod_auth_form.c+I+form authentication"
+ "modules/aaa/mod_authn_anon.c+A+anonymous user authentication control"
+ "modules/aaa/mod_authn_core.c+A+core authentication module"
+ "modules/aaa/mod_authn_dbd.c+I+SQL-based authentication control"
+ "modules/aaa/mod_authn_dbm.c+I+DBM-based authentication control"
+ "modules/aaa/mod_authn_file.c+A+file-based authentication control"
+ "modules/aaa/mod_authn_socache.c+A+Cached authentication control"
+ "modules/aaa/mod_authnz_fcgi.c+I+FastCGI authorizer-based authentication and authorization"
+ "modules/aaa/mod_authnz_ldap.c+O+LDAP based authentication"
+ "modules/aaa/mod_authz_core.c+A+core authorization provider vector module"
+ "modules/aaa/mod_authz_dbd.c+I+SQL based authorization and Login/Session support"
+ "modules/aaa/mod_authz_dbm.c+I+DBM-based authorization control"
+ "modules/aaa/mod_authz_groupfile.c+A+'require group' authorization control"
+ "modules/aaa/mod_authz_host.c+A+host-based authorization control"
+ "modules/aaa/mod_authz_owner.c+I+'require file-owner' authorization control"
+ "modules/aaa/mod_authz_user.c+I+'require user' authorization control"
+ "modules/arch/win32/mod_isapi.c+I+isapi extension support"
+ "modules/cache/mod_cache.c+I+dynamic file caching. At least one storage management module (e.g. mod_cache_disk) is also necessary."
+ "modules/cache/mod_cache_disk.c+I+disk caching module"
+ "modules/cache/mod_cache_socache.c+A+shared object caching module"
+ "modules/cache/mod_file_cache.c+A+File cache"
+ "modules/cache/mod_socache_dbm.c+I+dbm small object cache provider"
+ "modules/cache/mod_socache_dc.c+O+distcache small object cache provider"
+ "modules/cache/mod_socache_memcache.c+I+memcache small object cache provider"
+ "modules/cache/mod_socache_shmcb.c+A+ shmcb small object cache provider"
+ "modules/cluster/mod_heartbeat.c+I+Generates Heartbeats"
+ "modules/cluster/mod_heartmonitor.c+I+Collects Heartbeats"
+ "modules/core/mod_macro.c+I+Define and use macros in configuration files"
+ "modules/core/mod_watchdog.c+I+Watchdog module"
+ "modules/database/mod_dbd.c+I+Apache DBD Framework"
+ "modules/dav/fs/mod_dav_fs.c+I+DAV provider for the filesystem."
+ "modules/dav/lock/mod_dav_lock.c+I+DAV provider for generic locking"
+ "modules/dav/main/mod_dav.c+I+WebDAV protocol handling."
+ "modules/debugging/mod_bucketeer.c+I+buckets manipulation filter. Useful only for developers and testing purposes."
+ "modules/debugging/mod_dumpio.c+I+I/O dump filter"
+ "modules/debugging/mod_firehose.c+O+Firehose dump filter"
+ "modules/echo/mod_echo.c+I+ECHO server"
+ "modules/examples/mod_case_filter.c+I+Example uppercase conversion filter"
+ "modules/examples/mod_case_filter_in.c+I+Example uppercase conversion input filter"
+ "modules/examples/mod_example_hooks.c+I+Example hook callback handler module"
+ "modules/examples/mod_example_ipc.c+I+Example of shared memory and mutex usage"
+ "modules/filters/mod_buffer.c+A+Filter Buffering"
+ "modules/filters/mod_charset_lite.c+O+character set translation"
+ "modules/filters/mod_data.c+I+RFC2397 data encoder"
+ "modules/filters/mod_deflate.c+O+Deflate transfer encoding support"
+ "modules/filters/mod_ext_filter.c+I+external filter module"
+ "modules/filters/mod_filter.c+A+Smart Filtering"
+ "modules/filters/mod_include.c+A+Server Side Includes"
+ "modules/filters/mod_proxy_html.c+O+Fix HTML Links in a Reverse Proxy"
+ "modules/filters/mod_ratelimit.c+I+Output Bandwidth Limiting"
+ "modules/filters/mod_reflector.c+I+Reflect request through the output filter stack"
+ "modules/filters/mod_reqtimeout.c+A+Limit time waiting for request from client"
+ "modules/filters/mod_request.c+I+Request Body Filtering"
+ "modules/filters/mod_sed.c+I+filter request and/or response bodies through sed"
+ "modules/filters/mod_substitute.c+I+response content rewrite-like filtering"
+ "modules/filters/mod_xml2enc.c+O+i18n support for markup filters"
+ "modules/generators/mod_asis.c+A+as-is filetypes"
+ "modules/generators/mod_autoindex.c+A+directory listing"
+ "modules/generators/mod_cgi.c+A+CGI scripts"
+ "modules/generators/mod_info.c+A+server information"
+ "modules/generators/mod_status.c+A+process/thread monitoring"
+ "modules/http/mod_mime.c+A+mapping of file-extension to MIME. Disabling this module is normally not recommended."
+ "modules/ldap/mod_ldap.c+O+LDAP caching and connection pooling services"
+ "modules/loggers/mod_log_config.c+A+logging configuration. You won't be able to log requests to the server without this module."
+ "modules/loggers/mod_log_debug.c+A+configurable debug logging"
+ "modules/loggers/mod_log_forensic.c+I+forensic logging"
+ "modules/loggers/mod_logio.c+I+input and output logging"
+ "modules/lua/mod_lua.c+O+Apache Lua Framework"
+ "modules/mappers/mod_actions.c+A+Action triggering on requests"
+ "modules/mappers/mod_alias.c+A+mapping of requests to different filesystem parts"
+ "modules/mappers/mod_dir.c+A+directory request handling"
+ "modules/mappers/mod_imagemap.c+I+server-side imagemaps"
+ "modules/mappers/mod_negotiation.c+A+content negotiation"
+ "modules/mappers/mod_rewrite.c+A+rule based URL manipulation"
+ "modules/mappers/mod_speling.c+A+correct common URL misspellings"
+ "modules/mappers/mod_userdir.c+A+mapping of requests to user-specific directories"
+ "modules/mappers/mod_vhost_alias.c+I+mass virtual hosting module"
+ "modules/metadata/mod_cern_meta.c+I+CERN-type meta files"
+ "modules/metadata/mod_env.c+A+clearing/setting of ENV vars"
+ "modules/metadata/mod_expires.c+A+Expires header control"
+ "modules/metadata/mod_headers.c+A+HTTP header control"
+ "modules/metadata/mod_ident.c+I+RFC 1413 identity check"
+ "modules/metadata/mod_mime_magic.c+I+automagically determining MIME type"
+ "modules/metadata/mod_remoteip.c+A+translate header contents to an apparent client remote_ip"
+ "modules/metadata/mod_setenvif.c+A+basing ENV vars on headers"
+ "modules/metadata/mod_unique_id.c+A+per-request unique ids"
+ "modules/metadata/mod_usertrack.c+A+user-session tracking"
+ "modules/metadata/mod_version.c+A+determining httpd version in config files"
+ "modules/proxy/balancers/mod_lbmethod_bybusyness.c+A+Apache proxy Load balancing by busyness"
+ "modules/proxy/balancers/mod_lbmethod_byrequests.c+A+Apache proxy Load balancing by request counting"
+ "modules/proxy/balancers/mod_lbmethod_bytraffic.c+A+Apache proxy Load balancing by traffic counting"
+ "modules/proxy/balancers/mod_lbmethod_heartbeat.c+A+Apache proxy Load balancing from Heartbeats"
+ "modules/proxy/mod_proxy_ajp.c+I+Apache proxy AJP module. Requires and is enabled by --enable-proxy."
+ "modules/proxy/mod_proxy_balancer.c+A+Apache proxy BALANCER module. Requires and is enabled by --enable-proxy."
+ "modules/proxy/mod_proxy.c+A+Apache proxy module"
+ "modules/proxy/mod_proxy_connect.c+I+Apache proxy CONNECT module. Requires and is enabled by --enable-proxy."
+ "modules/proxy/mod_proxy_express.c+I+mass reverse-proxy module. Requires --enable-proxy."
+ "modules/proxy/mod_proxy_fcgi.c+I+Apache proxy FastCGI module. Requires and is enabled by --enable-proxy."
+ "modules/proxy/mod_proxy_ftp.c+I+Apache proxy FTP module. Requires and is enabled by --enable-proxy."
+ "modules/proxy/mod_proxy_http.c+A+Apache proxy HTTP module. Requires and is enabled by --enable-proxy."
+ "modules/proxy/mod_proxy_scgi.c+I+Apache proxy SCGI module. Requires and is enabled by --enable-proxy."
+ "modules/proxy/mod_proxy_wstunnel.c+I+Apache proxy Websocket Tunnel module. Requires and is enabled by --enable-proxy."
+ "modules/proxy/mod_serf.c+O+Reverse proxy module using Serf"
+ "modules/session/mod_session.c+I+session module"
+ "modules/session/mod_session_cookie.c+I+session cookie module"
+ "modules/session/mod_session_crypto.c+O+session crypto module"
+ "modules/session/mod_session_dbd.c+I+session dbd module"
+ "modules/slotmem/mod_slotmem_plain.c+A+slotmem provider that uses plain memory"
+ "modules/slotmem/mod_slotmem_shm.c+A+slotmem provider that uses shared memory"
+ "modules/ssl/mod_ssl.c+A+SSL/TLS support"
+ "modules/test/mod_dialup.c+I+rate limits static files to dialup modem speeds"
+ "modules/test/mod_optional_fn_export.c+I+example optional function exporter"
+ "modules/test/mod_optional_fn_import.c+I+example optional function importer"
+ "modules/test/mod_optional_hook_export.c+I+example optional hook exporter"
+ "modules/test/mod_optional_hook_import.c+I+example optional hook importer"
+ "modules/test/mod_policy.c+I+HTTP protocol compliance filters"
+)
+
+# Define extra definitions, sources, headers, etc. required by some modules.
+# This could be included in the master list of modules above, though it
+# certainly would get a lot more unreadable.
+SET(mod_authz_dbd_extra_defines AUTHZ_DBD_DECLARE_EXPORT)
+SET(mod_cache_extra_defines CACHE_DECLARE_EXPORT)
+SET(mod_cache_extra_sources
+ modules/cache/cache_storage.c modules/cache/cache_util.c
+)
+SET(mod_cache_disk_extra_libs mod_cache)
+SET(mod_cache_socache_extra_libs mod_cache)
+SET(mod_dav_extra_defines DAV_DECLARE_EXPORT)
+SET(mod_dav_extra_sources
+ modules/dav/main/liveprop.c modules/dav/main/props.c
+ modules/dav/main/std_liveprop.c modules/dav/main/providers.c
+ modules/dav/main/util.c modules/dav/main/util_lock.c
+)
+SET(mod_dav_fs_extra_sources
+ modules/dav/fs/dbm.c modules/dav/fs/lock.c
+ modules/dav/fs/repos.c
+)
+SET(mod_dav_fs_extra_libs mod_dav)
+SET(mod_dav_lock_extra_sources modules/dav/lock/locks.c)
+SET(mod_dav_lock_extra_libs mod_dav)
+SET(mod_dbd_extra_defines DBD_DECLARE_EXPORT)
+SET(mod_heartbeat_extra_libs mod_watchdog)
+SET(mod_optional_hook_export_extra_defines AP_DECLARE_EXPORT) # bogus reuse of core API prefix
+SET(mod_proxy_extra_defines PROXY_DECLARE_EXPORT)
+SET(mod_proxy_extra_sources modules/proxy/proxy_util.c)
+SET(mod_proxy_ajp_extra_sources
+ modules/proxy/ajp_header.c modules/proxy/ajp_link.c
+ modules/proxy/ajp_msg.c modules/proxy/ajp_utils.c
+)
+SET(mod_proxy_ajp_extra_libs mod_proxy)
+SET(mod_proxy_balancer_extra_libs mod_proxy)
+SET(mod_proxy_connect_extra_libs mod_proxy)
+SET(mod_proxy_express_extra_libs mod_proxy)
+SET(mod_proxy_fcgi_extra_libs mod_proxy)
+SET(mod_proxy_ftp_extra_libs mod_proxy)
+SET(mod_proxy_http_extra_libs mod_proxy)
+SET(mod_proxy_scgi_extra_libs mod_proxy)
+SET(mod_proxy_wstunnel_extra_libs mod_proxy)
+SET(mod_ratelimit_extra_defines AP_RL_DECLARE_EXPORT)
+SET(mod_sed_extra_sources
+ modules/filters/regexp.c modules/filters/sed0.c
+ modules/filters/sed1.c
+)
+SET(mod_session_extra_defines SESSION_DECLARE_EXPORT)
+SET(mod_session_cookie_extra_libs mod_session)
+SET(mod_session_dbd_extra_libs mod_session)
+SET(mod_ssl_extra_includes ${OPENSSL_INCLUDE_DIR})
+SET(mod_ssl_extra_sources
+ modules/ssl/ssl_engine_config.c modules/ssl/ssl_engine_dh.c
+ modules/ssl/ssl_engine_init.c modules/ssl/ssl_engine_io.c
+ modules/ssl/ssl_engine_kernel.c modules/ssl/ssl_engine_log.c
+ modules/ssl/ssl_engine_mutex.c modules/ssl/ssl_engine_ocsp.c
+ modules/ssl/ssl_engine_pphrase.c modules/ssl/ssl_engine_rand.c
+ modules/ssl/ssl_engine_vars.c modules/ssl/ssl_scache.c
+ modules/ssl/ssl_util.c modules/ssl/ssl_util_ocsp.c
+ modules/ssl/ssl_util_ssl.c modules/ssl/ssl_util_stapling.c
+)
+SET(mod_ssl_extra_libs ${OPENSSL_LIBRARIES})
+SET(mod_status_extra_defines STATUS_DECLARE_EXPORT)
+SET(mod_watchdog_extra_defines AP_WD_DECLARE_EXPORT)
+
+SET(MODULE_SRCS)
+
+SET(moduleselections)
+FOREACH (modinfo ${MODULE_LIST})
+ STRING(REGEX REPLACE "([^+]*)\\+([^+]*)\\+([^+]*)" "\\1;\\2;\\3" modinfolist ${modinfo})
+ LIST(LENGTH modinfolist modinfolen)
+ SET(primarysourcefile)
+ SET(defaultenable)
+ SET(helptext)
+ FOREACH(i ${modinfolist})
+ IF("${primarysourcefile}" STREQUAL "")
+ SET(primarysourcefile ${i})
+ ELSEIF("${defaultenable}" STREQUAL "")
+ SET(defaultenable ${i})
+ ELSEIF("${helptext}" STREQUAL "")
+ SET(helptext ${i})
+ ELSE()
+ MESSAGE(FATAL " Unexpected field or plus sign in >${modinfo}<")
+ ENDIF()
+ ENDFOREACH()
+
+ # MESSAGE(" primary source file: ${primarysourcefile}")
+ # MESSAGE("enablement by default: ${defaultenable}")
+ # MESSAGE(" help text: ${helptext}")
+
+ STRING(REGEX MATCH "[^/]+\\.c" mod_basename ${primarysourcefile})
+ STRING(REGEX MATCH "[^.]+" mod_name ${mod_basename})
+
+ STRING(TOUPPER "ENABLE_${mod_name}" mod_option_name)
+
+ SET(${mod_option_name} ${defaultenable} CACHE STRING ${helptext})
+ SET(MODULE_SRCS "${MODULE_SRCS};${primarysourcefile}")
+ SET(moduleselections "${moduleselections};${mod_option_name}")
+
+ENDFOREACH()
+
+SET(install_targets)
+SET(install_modules) # special handling vs. other installed targets
+
+ADD_EXECUTABLE(gen_test_char server/gen_test_char.c)
+GET_TARGET_PROPERTY(GEN_TEST_CHAR_EXE gen_test_char LOCATION)
+ADD_CUSTOM_COMMAND(
+ COMMENT "Generating character tables, test_char.h, for current locale"
+ DEPENDS gen_test_char
+ COMMAND ${GEN_TEST_CHAR_EXE} > ${PROJECT_BINARY_DIR}/test_char.h
+ OUTPUT ${PROJECT_BINARY_DIR}/test_char.h
+)
+ADD_CUSTOM_TARGET(
+ test_char_header ALL
+ DEPENDS ${PROJECT_BINARY_DIR}/test_char.h
+)
+
+SET(HTTPD_MAIN_SOURCES
+ server/main.c
+)
+
+SET(LIBHTTPD_SOURCES
+ modules/arch/win32/mod_win32.c
+ modules/core/mod_so.c
+ modules/http/byterange_filter.c
+ modules/http/chunk_filter.c
+ modules/http/http_core.c
+ modules/http/http_etag.c
+ modules/http/http_filters.c
+ modules/http/http_protocol.c
+ modules/http/http_request.c
+ os/win32/ap_regkey.c
+ os/win32/modules.c
+ os/win32/util_win32.c
+ server/buildmark.c
+ server/config.c
+ server/connection.c
+ server/core.c
+ server/core_filters.c
+ server/eoc_bucket.c
+ server/eor_bucket.c
+ server/error_bucket.c
+ server/listen.c
+ server/log.c
+ server/mpm/winnt/child.c
+ server/mpm/winnt/mpm_winnt.c
+ server/mpm/winnt/nt_eventlog.c
+ server/mpm/winnt/service.c
+ server/mpm_common.c
+ server/protocol.c
+ server/provider.c
+ server/request.c
+ server/scoreboard.c
+ server/util.c
+ server/util_cfgtree.c
+ server/util_cookies.c
+ server/util_expr_eval.c
+ server/util_expr_parse.c
+ server/util_expr_scan.c
+ server/util_fcgi.c
+ server/util_filter.c
+ server/util_md5.c
+ server/util_mutex.c
+ server/util_pcre.c
+ server/util_regex.c
+ server/util_script.c
+ server/util_time.c
+ server/util_xml.c
+ server/vhost.c
+)
+
+CONFIGURE_FILE(os/win32/win32_config_layout.h
+ ${PROJECT_BINARY_DIR}/ap_config_layout.h)
+
+SET(HTTPD_INCLUDE_DIRECTORIES
+ ${PROJECT_BINARY_DIR}
+ # see discussion in cmake bug 13188 regarding oddities with relative paths
+ ${CMAKE_CURRENT_SOURCE_DIR}/include
+ ${CMAKE_CURRENT_SOURCE_DIR}/os/win32
+ ${CMAKE_CURRENT_SOURCE_DIR}/modules/core
+ ${CMAKE_CURRENT_SOURCE_DIR}/modules/database
+ ${CMAKE_CURRENT_SOURCE_DIR}/modules/dav/main
+ ${CMAKE_CURRENT_SOURCE_DIR}/modules/filters
+ ${CMAKE_CURRENT_SOURCE_DIR}/modules/generators
+ ${CMAKE_CURRENT_SOURCE_DIR}/modules/proxy
+ ${CMAKE_CURRENT_SOURCE_DIR}/modules/session
+ ${CMAKE_CURRENT_SOURCE_DIR}/modules/ssl
+ ${CMAKE_CURRENT_SOURCE_DIR}/server
+ ${APR_INCLUDE_DIR}
+ ${APR_PRIVATE_INCLUDE_DIRS}
+ ${PCRE_INCLUDE_DIR}
+)
+
+INCLUDE_DIRECTORIES(${HTTPD_INCLUDE_DIRECTORIES})
+
+SET(HTTPD_SYSTEM_LIBS
+ ws2_32
+ mswsock
+)
+
+########### HTTPD MODULES ############
+SET(LoadModules)
+FOREACH (mod ${MODULE_SRCS})
+ # Build different forms of the module name; e.g.,
+ # mod_short_name->mod_cgi.c, mod_name->mod_cgi, mod_module_name->cgi_module
+ STRING(REGEX MATCH "[^/]+\\.c" mod_basename ${mod})
+ STRING(REGEX MATCH "[^.]+" mod_name ${mod_basename})
+ STRING(REGEX REPLACE "^mod_(.*)" "\\1_module" mod_module_name ${mod_name})
+
+ # Is it enabled?
+ STRING(TOUPPER "ENABLE_${mod_name}" enable_mod)
+
+ IF("${${enable_mod}}" STREQUAL "")
+ MESSAGE(FATAL " ENABLE_MOD_foo VAR not set for module ${mod}")
+ ENDIF()
+
+ IF(${${enable_mod}} STREQUAL "O")
+ # ignore
+ ELSE()
+ # Handle whether or not the LoadModule is commented out.
+ IF(${${enable_mod}} STREQUAL "A")
+ SET(LoadModules ${LoadModules} "LoadModule ${mod_module_name} modules/${mod_name}.so\n")
+ ELSEIF(${${enable_mod}} STREQUAL "I")
+ SET(LoadModules ${LoadModules} "# LoadModule ${mod_module_name} modules/${mod_name}.so\n")
+ ELSE()
+ MESSAGE(FATAL " ${enable_mod} must be set to \"A\", \"I\", or \"O\" instead of \"${${enable_mod}}\"")
+ ENDIF()
+
+ # Handle building it.
+ SET(mod_extra_sources "${mod_name}_extra_sources")
+ SET(all_mod_sources ${mod} ${${mod_extra_sources}})
+ ADD_LIBRARY(${mod_name} SHARED ${all_mod_sources})
+ SET(install_modules ${install_modules} ${mod_name})
+ SET(mod_extra_libs "${mod_name}_extra_libs")
+ SET_TARGET_PROPERTIES(${mod_name} PROPERTIES SUFFIX .so)
+ TARGET_LINK_LIBRARIES(${mod_name} ${${mod_extra_libs}} libhttpd ${APR_LIBRARIES} ${HTTPD_SYSTEM_LIBS})
+
+ # Extra defines?
+ SET(mod_extra_defines "${mod_name}_extra_defines")
+ IF(NOT ${${mod_extra_defines}} STREQUAL "")
+ SET_TARGET_PROPERTIES(${mod_name} PROPERTIES COMPILE_DEFINITIONS ${${mod_extra_defines}})
+ ENDIF()
+
+ # Extra includes?
+ SET(mod_extra_includes "${mod_name}_extra_includes")
+ IF(NOT ${${mod_extra_includes}} STREQUAL "")
+ SET(tmp_includes ${${mod_extra_includes}} ${HTTPD_INCLUDE_DIRECTORIES})
+ SET_TARGET_PROPERTIES(${mod_name} PROPERTIES INCLUDE_DIRECTORIES "${tmp_includes}")
+ GET_PROPERTY(tmp_includes TARGET ${mod_name} PROPERTY INCLUDE_DIRECTORIES)
+ ENDIF()
+
+ ENDIF()
+ENDFOREACH()
+
+########### HTTPD LIBRARIES ############
+ADD_LIBRARY(libhttpd SHARED ${LIBHTTPD_SOURCES})
+SET(install_targets ${install_targets} libhttpd)
+TARGET_LINK_LIBRARIES(libhttpd ${APR_LIBRARIES} ${PCRE_LIBRARIES} ${HTTPD_SYSTEM_LIBS})
+SET_TARGET_PROPERTIES(libhttpd PROPERTIES COMPILE_FLAGS -DAP_DECLARE_EXPORT)
+ADD_DEPENDENCIES(libhttpd test_char_header)
+
+########### HTTPD EXECUTABLES ##########
+ADD_EXECUTABLE(httpd server/main.c build/win32/httpd.rc)
+SET(install_targets ${install_targets} httpd)
+TARGET_LINK_LIBRARIES(httpd libhttpd)
+
+ADD_EXECUTABLE(ab support/ab.c)
+SET(install_targets ${install_targets} ab)
+IF(OPENSSL_FOUND)
+ SET_TARGET_PROPERTIES(ab PROPERTIES COMPILE_DEFINITIONS HAVE_OPENSSL)
+ SET(tmp_includes ${HTTPD_INCLUDE_DIRECTORIES} ${OPENSSL_INCLUDE_DIR})
+ SET_TARGET_PROPERTIES(ab PROPERTIES INCLUDE_DIRECTORIES "${tmp_includes}")
+ TARGET_LINK_LIBRARIES(ab ${APR_LIBRARIES} ${OPENSSL_LIBRARIES})
+ELSE()
+ TARGET_LINK_LIBRARIES(ab ${APR_LIBRARIES})
+ENDIF()
+GET_PROPERTY(tmp_includes TARGET ab PROPERTY INCLUDE_DIRECTORIES)
+
+# getting duplicate manifest error with ApacheMonitor
+# ADD_EXECUTABLE(ApacheMonitor support/win32/ApacheMonitor.c support/win32/ApacheMonitor.rc)
+# SET(install_targets ${install_targets} ApacheMonitor)
+# SET_TARGET_PROPERTIES(ApacheMonitor PROPERTIES WIN32_EXECUTABLE TRUE)
+# TARGET_LINK_LIBRARIES(ApacheMonitor ${HTTPD_SYSTEM_LIBS} comctl32 wtsapi32)
+
+ADD_EXECUTABLE(htcacheclean support/htcacheclean.c)
+SET(install_targets ${install_targets} htcacheclean)
+TARGET_LINK_LIBRARIES(htcacheclean ${APR_LIBRARIES})
+
+ADD_EXECUTABLE(htdbm support/htdbm.c support/passwd_common.c)
+SET(install_targets ${install_targets} htdbm)
+TARGET_LINK_LIBRARIES(htdbm ${APR_LIBRARIES})
+
+ADD_EXECUTABLE(htdigest support/htdigest.c)
+SET(install_targets ${install_targets} htdigest)
+TARGET_LINK_LIBRARIES(htdigest ${APR_LIBRARIES})
+
+ADD_EXECUTABLE(htpasswd support/htpasswd.c support/passwd_common.c)
+SET(install_targets ${install_targets} htpasswd)
+TARGET_LINK_LIBRARIES(htpasswd ${APR_LIBRARIES})
+
+ADD_EXECUTABLE(logresolve support/logresolve.c)
+SET(install_targets ${install_targets} logresolve)
+TARGET_LINK_LIBRARIES(logresolve ${APR_LIBRARIES})
+
+ADD_EXECUTABLE(rotatelogs support/rotatelogs.c)
+SET(install_targets ${install_targets} rotatelogs)
+TARGET_LINK_LIBRARIES(rotatelogs ${APR_LIBRARIES})
+
+INSTALL(TARGETS ${install_targets}
+ RUNTIME DESTINATION bin
+ LIBRARY DESTINATION lib
+ ARCHIVE DESTINATION lib
+ )
+INSTALL(TARGETS ${install_modules}
+ RUNTIME DESTINATION modules
+ )
+INSTALL(DIRECTORY include/ DESTINATION include
+ FILES_MATCHING PATTERN "*.h"
+)
+INSTALL(DIRECTORY docs/icons/ DESTINATION icons)
+INSTALL(DIRECTORY docs/error/ DESTINATION error)
+INSTALL(DIRECTORY docs/manual/ DESTINATION manual
+ FILES_MATCHING PATTERN "BUILDING" EXCLUDE
+)
+INSTALL(DIRECTORY DESTINATION logs)
+INSTALL(DIRECTORY DESTINATION cgi-bin)
+
+MESSAGE(STATUS "Module selections:")
+FOREACH(modsel ${moduleselections})
+ MESSAGE(STATUS " ${modsel} ${${modsel}}")
+ENDFOREACH()