diff options
-rw-r--r-- | CMakeLists.txt | 31 | ||||
-rw-r--r-- | README.cmake | 3 | ||||
-rw-r--r-- | build/build-modules-c.cmake | 83 |
3 files changed, 96 insertions, 21 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt index 91260d62c7..649d474ec9 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -23,6 +23,7 @@ PROJECT(HTTPD C) INCLUDE(CheckSymbolExists) INCLUDE(CheckCSourceCompiles) +INCLUDE("build/build-modules-c.cmake") FIND_PACKAGE(LibXml2) FIND_PACKAGE(Lua51) @@ -656,26 +657,20 @@ SET(install_targets) SET(install_bin_pdb) SET(install_modules) # special handling vs. other installed targets SET(install_modules_pdb) -SET(builtin_module_shortnames "win32 mpm_winnt http so") # core added automatically +SET(builtin_module_shortnames) +LIST(APPEND builtin_module_shortnames "win32" "mpm_winnt" "http" "so") # core added automatically SET(extra_builtin_modules) # the ones specified with -DWITH_MODULES= -IF(WITH_MODULES) # modules statically linked with the server - STRING(REPLACE "," ";" WITH_MODULE_LIST ${WITH_MODULES}) - FOREACH(static_mod ${WITH_MODULE_LIST}) - STRING(REGEX MATCH "[^/]+\\.c" mod_basename ${static_mod}) - STRING(REGEX REPLACE "^mod_(.*)\\.c" "\\1" mod_module_name ${mod_basename}) - SET(builtin_module_shortnames "${builtin_module_shortnames} ${mod_module_name}") - CONFIGURE_FILE(${static_mod} ${PROJECT_BINARY_DIR}/ COPYONLY) - SET(extra_builtin_modules ${extra_builtin_modules} ${PROJECT_BINARY_DIR}/${mod_basename}) - ENDFOREACH() - EXECUTE_PROCESS(COMMAND cmd /c "echo ${builtin_module_shortnames}| awk -f ${CMAKE_CURRENT_SOURCE_DIR}/build/build-modules-c.awk > ${PROJECT_BINARY_DIR}/modules.c" RESULT_VARIABLE rv) - IF(rv) - MESSAGE(FATAL_ERROR "build-modules-c.awk failed (${rv})") - ENDIF() -ELSE() - # no extra built-in modules; use the default modules.c to avoid the awk prereq - CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/os/win32/modules.c ${PROJECT_BINARY_DIR}/ COPYONLY) -ENDIF() +STRING(REPLACE "," ";" WITH_MODULE_LIST "${WITH_MODULES}") +FOREACH(static_mod ${WITH_MODULE_LIST}) + STRING(REGEX MATCH "[^/]+\\.c" mod_basename ${static_mod}) + STRING(REGEX REPLACE "^mod_(.*)\\.c" "\\1" mod_module_name ${mod_basename}) + LIST(APPEND builtin_module_shortnames "${mod_module_name}") + CONFIGURE_FILE(${static_mod} ${PROJECT_BINARY_DIR}/ COPYONLY) + SET(extra_builtin_modules ${extra_builtin_modules} ${PROJECT_BINARY_DIR}/${mod_basename}) +ENDFOREACH() + +generate_builtin_modules_c("${PROJECT_BINARY_DIR}/modules.c" "${builtin_module_shortnames}") # for easy reference from .dll/.so builds CONFIGURE_FILE(os/win32/BaseAddr.ref ${PROJECT_BINARY_DIR}/ COPYONLY) diff --git a/README.cmake b/README.cmake index 938da37d37..01ab6e6a21 100644 --- a/README.cmake +++ b/README.cmake @@ -34,7 +34,6 @@ The following tools must be in PATH: cmake version 3.1.3 or later is required to work with current OpenSSL releases. (OpenSSL is an optional prerequisite of httpd.) * Perl -* If the WITH_MODULES feature is used: awk * If using a command-line compiler: compiler and linker and related tools (Refer to the cmake documentation for more information.) @@ -100,8 +99,6 @@ How to build 2. Make sure cmake and Perl are in PATH. Additionally, some backends require compile tools in PATH. (Hint: "Visual Studio Command Prompt") - In the unlikely event that you use -DWITH_MODULES, described below, make - sure awk is in PATH. 3. cmake -G "some backend, like 'NMake Makefiles'" -DCMAKE_INSTALL_PREFIX=d:/path/to/httpdinst diff --git a/build/build-modules-c.cmake b/build/build-modules-c.cmake new file mode 100644 index 0000000000..9d4ac6cc2d --- /dev/null +++ b/build/build-modules-c.cmake @@ -0,0 +1,83 @@ +# Licensed to the Apache Software Foundation (ASF) under one or more +# contributor license agreements. See the NOTICE file distributed with +# this work for additional information regarding copyright ownership. +# The ASF licenses this file to You under the Apache License, Version 2.0 +# (the "License"); you may not use this file except in compliance with +# the License. You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +function(generate_builtin_modules_c output_filename module_list) + list(PREPEND module_list "core") + + set(content "") + + string(APPEND content "/*\n") + string(APPEND content " * modules.c --- automatically generated by Apache\n") + string(APPEND content " * configuration script. DO NOT HAND EDIT!!!!!\n") + string(APPEND content " */\n") + string(APPEND content "\n") + string(APPEND content "#include \"ap_config.h\"\n") + string(APPEND content "#include \"httpd.h\"\n") + string(APPEND content "#include \"http_config.h\"\n") + string(APPEND content "\n") + + foreach(module ${module_list}) + string(APPEND content "extern module ${module}_module\;\n") + endforeach() + + string(APPEND content "\n") + string(APPEND content "/*\n") + string(APPEND content " * Modules which implicitly form the\n") + string(APPEND content " * list of activated modules on startup,\n") + string(APPEND content " * i.e. these are the modules which are\n") + string(APPEND content " * initially linked into the Apache processing\n") + string(APPEND content " * [extendable under run-time via AddModule]\n") + string(APPEND content " */\n") + + string(APPEND content "AP_DECLARE_DATA module *ap_prelinked_modules[] = {\n") + foreach(module ${module_list}) + string(APPEND content " &${module}_module,\n") + endforeach() + string(APPEND content " NULL\n") + string(APPEND content "}\;\n") + + string(APPEND content "\n") + string(APPEND content "/*\n") + string(APPEND content " * We need the symbols as strings for <IfModule> containers\n") + string(APPEND content " */\n") + string(APPEND content "\n") + string(APPEND content "ap_module_symbol_t ap_prelinked_module_symbols[] = {\n") + + foreach(module ${module_list}) + string(APPEND content " {\"${module}_module\", &${module}_module},\n") + endforeach() + + string(APPEND content " {NULL, NULL}\n") + string(APPEND content "}\;\n") + string(APPEND content "\n") + string(APPEND content "/*\n") + string(APPEND content " * Modules which initially form the\n") + string(APPEND content " * list of available modules on startup,\n") + string(APPEND content " * i.e. these are the modules which are\n") + string(APPEND content " * initially loaded into the Apache process\n") + string(APPEND content " * [extendable under run-time via LoadModule]\n") + string(APPEND content " */\n") + string(APPEND content "module *ap_preloaded_modules[] = {\n") + + foreach(module ${module_list}) + string(APPEND content " &${module}_module,\n") + endforeach() + + string(APPEND content " NULL\n") + string(APPEND content "}\;\n") + string(APPEND content "\n") + + file(WRITE ${output_filename} ${content}) +endfunction() |