Joakim Soderberg | 08e434e | 2013-02-01 14:52:53 +0100 | [diff] [blame] | 1 | cmake_minimum_required(VERSION 2.6) |
| 2 | |
| 3 | project(libwebsockets) |
| 4 | |
| 5 | set(PACKAGE "libwebsockets") |
Joakim Soderberg | b37827b | 2013-02-22 09:28:08 +0800 | [diff] [blame] | 6 | set(CPACK_PACKAGE_NAME "${PACKAGE}") |
| 7 | set(CPACK_PACKAGE_VERSION_MAJOR "1") |
Andy Green | 19c1a99 | 2013-03-10 06:59:01 +0800 | [diff] [blame] | 8 | set(CPACK_PACKAGE_VERSION_MINOR "3") |
Joakim Soderberg | b37827b | 2013-02-22 09:28:08 +0800 | [diff] [blame] | 9 | set(CPACK_PACKAGE_VERSION "${CPACK_PACKAGE_VERSION_MAJOR}.${CPACK_PACKAGE_VERSION_MINOR}") |
| 10 | set(CPACK_PACKAGE_VENDOR "andy@warmcat.com") |
| 11 | set(CPACK_PACKAGE_DESCRIPTION_SUMMARY "${PACKAGE} ${PACKAGE_VERSION}") |
Andy Green | 19c1a99 | 2013-03-10 06:59:01 +0800 | [diff] [blame] | 12 | set(SOVERSION "4.0.0") |
Joakim Soderberg | b37827b | 2013-02-22 09:28:08 +0800 | [diff] [blame] | 13 | set(CPACK_SOURCE_GENERATOR "TGZ") |
| 14 | set(CPACK_SOURCE_PACKAGE_FILE_NAME "${CPACK_PACKAGE_NAME}-${CPACK_PACKAGE_VERSION}") |
| 15 | set(VERSION "${CPACK_PACKAGE_VERSION}") |
Joakim Soderberg | 08e434e | 2013-02-01 14:52:53 +0100 | [diff] [blame] | 16 | |
Joakim Soderberg | b37827b | 2013-02-22 09:28:08 +0800 | [diff] [blame] | 17 | set(LWS_LIBRARY_VERSION ${CPACK_PACKAGE_VERSION}) |
Edwin van den Oetelaar | d6bf73c | 2013-02-18 20:20:05 +0800 | [diff] [blame] | 18 | set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} "${PROJECT_SOURCE_DIR}/cmake/") |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 19 | |
Andy Green | 5b479ac | 2013-03-30 10:30:03 +0800 | [diff] [blame] | 20 | message(STATUS "CMAKE_TOOLCHAIN_FILE='${CMAKE_TOOLCHAIN_FILE}'") |
| 21 | |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 22 | # Try to find the current Git hash. |
| 23 | find_package(Git) |
| 24 | if(GIT_EXECUTABLE) |
| 25 | execute_process( |
Markus Elfring | 299244f | 2013-10-26 20:03:43 +0800 | [diff] [blame] | 26 | WORKING_DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}" |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 27 | COMMAND "${GIT_EXECUTABLE}" log -n 1 --pretty=%h |
| 28 | OUTPUT_VARIABLE GIT_HASH |
| 29 | OUTPUT_STRIP_TRAILING_WHITESPACE |
| 30 | ) |
| 31 | |
| 32 | set(LWS_BUILD_HASH ${GIT_HASH}) |
| 33 | message("Git commit hash: ${LWS_BUILD_HASH}") |
| 34 | endif() |
| 35 | |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 36 | option(LWS_WITH_SSL "Include SSL support (default OpenSSL, CyaSSL if LWS_USE_CYASSL is set)" ON) |
| 37 | option(LWS_USE_EXTERNAL_ZLIB "Search the system for ZLib instead of using the included one (on Windows)" OFF) |
| 38 | option(LWS_USE_CYASSL "Use CyaSSL replacement for OpenSSL. When settings this, you also need to specify LWS_CYASSL_LIB and LWS_CYASSL_INCLUDE_DIRS" OFF) |
| 39 | option(LWS_WITHOUT_BUILTIN_GETIFADDRS "Don't use BSD getifaddrs implementation from libwebsockets if it is missing (this will result in a compilation error) ... Default is your libc provides it. On some systems such as uclibc it doesn't exist." OFF) |
| 40 | option(LWS_WITHOUT_CLIENT "Don't build the client part of the library" OFF) |
| 41 | option(LWS_WITHOUT_SERVER "Don't build the server part of the library" OFF) |
| 42 | #option(LWS_WITH_LIBCRYPTO "Use libcrypto MD5 and SHA1 implementations" ON) |
| 43 | option(LWS_LINK_TESTAPPS_DYNAMIC "Link the test apps to the shared version of the library. Default is to link statically" OFF) |
| 44 | option(LWS_WITHOUT_TESTAPPS "Don't build the libwebsocket-test-apps" OFF) |
| 45 | option(LWS_WITHOUT_TEST_SERVER "Don't build the test server" OFF) |
| 46 | option(LWS_WITHOUT_TEST_SERVER_EXTPOLL "Don't build the test server version that uses external poll" OFF) |
| 47 | option(LWS_WITHOUT_TEST_PING "Don't build the ping test application" OFF) |
| 48 | option(LWS_WITHOUT_TEST_CLIENT "Don't build the client test application" OFF) |
| 49 | option(LWS_WITHOUT_TEST_FRAGGLE "Don't build the ping test application" OFF) |
| 50 | option(LWS_WITHOUT_DEBUG "Don't compile debug related code" OFF) |
| 51 | option(LWS_WITHOUT_EXTENSIONS "Don't compile with extensions" OFF) |
| 52 | option(LWS_WITH_LATENCY "Build latency measuring code into the library" OFF) |
| 53 | option(LWS_WITHOUT_DAEMONIZE "Don't build the daemonization api" OFF) |
Joakim Soderberg | add3926 | 2013-02-06 15:25:26 +0900 | [diff] [blame] | 54 | |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 55 | # Allow the user to override installation directories. |
| 56 | set(LWS_INSTALL_LIB_DIR lib CACHE PATH "Installation directory for libraries") |
| 57 | set(LWS_INSTALL_BIN_DIR bin CACHE PATH "Installation directory for executables") |
| 58 | set(LWS_INSTALL_INCLUDE_DIR include CACHE PATH "Installation directory for header files") |
| 59 | set(LWS_INSTALL_EXAMPLES_DIR bin CACHE PATH "Installation directory for example files") |
| 60 | |
| 61 | if (LWS_WITHOUT_CLIENT AND LWS_WITHOUT_SERVER) |
Joakim Soderberg | 7eadd58 | 2013-02-22 09:28:04 +0800 | [diff] [blame] | 62 | message(FATAL_ERROR "Makes no sense to compile without both client or server.") |
| 63 | endif() |
| 64 | |
Joakim Soderberg | b37827b | 2013-02-22 09:28:08 +0800 | [diff] [blame] | 65 | # The base dir where the test-apps look for the SSL certs. |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 66 | set(LWS_OPENSSL_CLIENT_CERTS ../share CACHE PATH "Server SSL certificate directory") |
| 67 | if (WIN32) |
| 68 | set(LWS_OPENSSL_CLIENT_CERTS . CACHE PATH "Client SSL certificate directory") |
Joakim Soderberg | d2edfec | 2013-02-06 15:27:27 +0900 | [diff] [blame] | 69 | else() |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 70 | set(LWS_OPENSSL_CLIENT_CERTS /etc/pki/tls/certs/ CACHE PATH "Client SSL certificate directory") |
Joakim Soderberg | d2edfec | 2013-02-06 15:27:27 +0900 | [diff] [blame] | 71 | endif() |
| 72 | |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 73 | set(LWS_CYASSL_LIB CACHE PATH "Path to the CyaSSL library") |
| 74 | set(LWS_CYASSL_INCLUDE_DIRS CACHE PATH "Path to the CyaSSL include directory") |
Joakim Soderberg | 08e434e | 2013-02-01 14:52:53 +0100 | [diff] [blame] | 75 | |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 76 | if (LWS_USE_CYASSL) |
| 77 | if ("${LWS_CYASSL_LIB}" STREQUAL "" OR "${LWS_CYASSL_INCLUDE_DIRS}" STREQUAL "") |
| 78 | message(FATAL_ERROR "You must set LWS_CYASSL_LIB and LWS_CYASSL_INCLUDE_DIRS when LWS_USE_CYASSL is turned on") |
Joakim Soderberg | add3926 | 2013-02-06 15:25:26 +0900 | [diff] [blame] | 79 | endif() |
| 80 | endif() |
| 81 | |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 82 | if (LWS_WITHOUT_EXTENSIONS) |
Joakim Soderberg | d2edfec | 2013-02-06 15:27:27 +0900 | [diff] [blame] | 83 | set(LWS_NO_EXTENSIONS 1) |
| 84 | endif() |
| 85 | |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 86 | if (LWS_WITH_SSL) |
Joakim Soderberg | d2edfec | 2013-02-06 15:27:27 +0900 | [diff] [blame] | 87 | set(LWS_OPENSSL_SUPPORT 1) |
| 88 | endif() |
| 89 | |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 90 | if (LWS_WITH_LATENCY) |
Joakim Soderberg | d2edfec | 2013-02-06 15:27:27 +0900 | [diff] [blame] | 91 | set(LWS_LATENCY 1) |
| 92 | endif() |
| 93 | |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 94 | if (LWS_WITHOUT_DAEMONIZE OR WIN32) |
Joakim Soderberg | d2edfec | 2013-02-06 15:27:27 +0900 | [diff] [blame] | 95 | set(LWS_NO_DAEMONIZE 1) |
| 96 | endif() |
| 97 | |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 98 | if (LWS_WITHOUT_SERVER) |
Joakim Soderberg | e9a4211 | 2013-02-06 15:29:59 +0900 | [diff] [blame] | 99 | set(LWS_NO_SERVER 1) |
| 100 | endif() |
| 101 | |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 102 | if (LWS_WITHOUT_CLIENT) |
Joakim Soderberg | e9a4211 | 2013-02-06 15:29:59 +0900 | [diff] [blame] | 103 | set(LWS_NO_CLIENT 1) |
| 104 | endif() |
| 105 | |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 106 | if (LWS_WITHOUT_DEBUG) |
Joakim Söderberg | 51197c0 | 2013-02-22 09:28:13 +0800 | [diff] [blame] | 107 | set(_DEBUG 0) |
| 108 | else() |
| 109 | set(_DEBUG 1) |
| 110 | endif() |
| 111 | |
Joakim Soderberg | d2edfec | 2013-02-06 15:27:27 +0900 | [diff] [blame] | 112 | if (MINGW) |
| 113 | set(LWS_MINGW_SUPPORT 1) |
| 114 | endif() |
| 115 | |
Markus Elfring | 299244f | 2013-10-26 20:03:43 +0800 | [diff] [blame] | 116 | include_directories("${PROJECT_BINARY_DIR}") |
Joakim Soderberg | 08e434e | 2013-02-01 14:52:53 +0100 | [diff] [blame] | 117 | |
Joakim Soderberg | 4f4a38b | 2013-02-06 15:28:07 +0900 | [diff] [blame] | 118 | include(CheckCSourceCompiles) |
| 119 | |
| 120 | # Check for different inline keyword versions. |
| 121 | foreach(KEYWORD "inline" "__inline__" "__inline") |
| 122 | set(CMAKE_REQUIRED_DEFINITIONS "-DKEYWORD=${KEYWORD}") |
| 123 | CHECK_C_SOURCE_COMPILES( |
| 124 | " |
| 125 | #include <stdio.h> |
| 126 | KEYWORD void a() {} |
| 127 | int main(int argc, char **argv) { a(); return 0; } |
| 128 | " HAVE_${KEYWORD}) |
| 129 | endforeach() |
| 130 | |
| 131 | if (NOT HAVE_inline) |
| 132 | if (HAVE___inline__) |
| 133 | set(inline __inline__) |
| 134 | elseif(HAVE___inline) |
| 135 | set(inline __inline) |
| 136 | endif() |
| 137 | endif() |
| 138 | |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 139 | # Put the libaries and binaries that get built into directories at the |
| 140 | # top of the build tree rather than in hard-to-find leaf directories. |
Markus Elfring | 299244f | 2013-10-26 20:03:43 +0800 | [diff] [blame] | 141 | SET(CMAKE_RUNTIME_OUTPUT_DIRECTORY "${PROJECT_BINARY_DIR}/bin") |
| 142 | SET(CMAKE_LIBRARY_OUTPUT_DIRECTORY "${PROJECT_BINARY_DIR}/lib") |
| 143 | SET(CMAKE_ARCHIVE_OUTPUT_DIRECTORY "${PROJECT_BINARY_DIR}/lib") |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 144 | |
thinkski | d34bae1 | 2013-04-16 19:48:05 +0800 | [diff] [blame] | 145 | # Put absolute path of dynamic libraries into the object code. Some |
| 146 | # architectures, notably Mac OS X, need this. |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 147 | SET(CMAKE_INSTALL_NAME_DIR "${CMAKE_INSTALL_PREFIX}/${LWS_INSTALL_LIB_DIR}${LIB_SUFFIX}") |
thinkski | d34bae1 | 2013-04-16 19:48:05 +0800 | [diff] [blame] | 148 | |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 149 | # So we can include the CMake generated config file only when |
| 150 | # building with CMAKE. |
| 151 | add_definitions(-DCMAKE_BUILD) |
| 152 | |
Joakim Soderberg | 08e434e | 2013-02-01 14:52:53 +0100 | [diff] [blame] | 153 | include(CheckFunctionExists) |
| 154 | include(CheckIncludeFile) |
| 155 | include(CheckIncludeFiles) |
| 156 | include(CheckLibraryExists) |
| 157 | |
| 158 | CHECK_FUNCTION_EXISTS(bzero HAVE_BZERO) |
| 159 | CHECK_FUNCTION_EXISTS(fork HAVE_FORK) |
| 160 | CHECK_FUNCTION_EXISTS(malloc HAVE_MALLOC) |
| 161 | CHECK_FUNCTION_EXISTS(memset HAVE_MEMSET) |
| 162 | CHECK_FUNCTION_EXISTS(realloc HAVE_REALLOC) |
| 163 | CHECK_FUNCTION_EXISTS(socket HAVE_SOCKET) |
| 164 | CHECK_FUNCTION_EXISTS(strerror HAVE_STRERROR) |
| 165 | CHECK_FUNCTION_EXISTS(vfork HAVE_VFORK) |
| 166 | CHECK_FUNCTION_EXISTS(getifaddrs HAVE_GETIFADDRS) |
| 167 | |
Joakim Soderberg | fcec61c | 2013-02-22 09:28:02 +0800 | [diff] [blame] | 168 | if (NOT HAVE_GETIFADDRS) |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 169 | if (LWS_WITHOUT_BUILTIN_GETIFADDRS) |
| 170 | message(FATAL_ERROR "No getifaddrs was found on the system. Turn off the LWS_WITHOUT_BUILTIN_GETIFADDRS compile option to use the supplied BSD version.") |
Joakim Soderberg | d2edfec | 2013-02-06 15:27:27 +0900 | [diff] [blame] | 171 | endif() |
Joakim Soderberg | fcec61c | 2013-02-22 09:28:02 +0800 | [diff] [blame] | 172 | |
Joakim Soderberg | d2edfec | 2013-02-06 15:27:27 +0900 | [diff] [blame] | 173 | set(LWS_BUILTIN_GETIFADDRS 1) |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 174 | endif() |
| 175 | |
Joakim Soderberg | 08e434e | 2013-02-01 14:52:53 +0100 | [diff] [blame] | 176 | CHECK_INCLUDE_FILE(dlfcn.h HAVE_DLFCN_H) |
| 177 | CHECK_INCLUDE_FILE(fcntl.h HAVE_FCNTL_H) |
| 178 | CHECK_INCLUDE_FILE(inttypes.h HAVE_INTTYPES_H) |
| 179 | CHECK_INCLUDE_FILE(memory.h HAVE_MEMORY_H) |
| 180 | CHECK_INCLUDE_FILE(netinet/in.h HAVE_NETINET_IN_H) |
| 181 | CHECK_INCLUDE_FILE(stdint.h HAVE_STDINT_H) |
| 182 | CHECK_INCLUDE_FILE(stdlib.h HAVE_STDLIB_H) |
| 183 | CHECK_INCLUDE_FILE(strings.h HAVE_STRINGS_H) |
| 184 | CHECK_INCLUDE_FILE(string.h HAVE_STRING_H) |
| 185 | CHECK_INCLUDE_FILE(sys/prctl.h HAVE_SYS_PRCTL_H) |
| 186 | CHECK_INCLUDE_FILE(sys/socket.h HAVE_SYS_SOCKET_H) |
| 187 | CHECK_INCLUDE_FILE(sys/stat.h HAVE_SYS_STAT_H) |
| 188 | CHECK_INCLUDE_FILE(sys/types.h HAVE_SYS_TYPES_H) |
| 189 | CHECK_INCLUDE_FILE(unistd.h HAVE_UNISTD_H) |
| 190 | CHECK_INCLUDE_FILE(vfork.h HAVE_VFORK_H) |
| 191 | CHECK_INCLUDE_FILE(zlib.h HAVE_ZLIB_H) |
| 192 | |
| 193 | # TODO: These can be tested if they actually work also... |
| 194 | set(HAVE_WORKING_FORK HAVE_FORK) |
| 195 | set(HAVE_WORKING_VFORK HAVE_VFORK) |
| 196 | |
| 197 | CHECK_INCLUDE_FILES("stdlib.h;stdarg.h;string.h;float.h" STDC_HEADERS) |
| 198 | |
| 199 | if (NOT HAVE_SYS_TYPES_H) |
| 200 | set(pid_t int) |
| 201 | set(size_t "unsigned int") |
| 202 | endif() |
| 203 | |
| 204 | if (NOT HAVE_MALLOC) |
| 205 | set(malloc rpl_malloc) |
| 206 | endif() |
| 207 | |
| 208 | if (NOT HAVE_REALLOC) |
| 209 | set(realloc rpl_realloc) |
| 210 | endif() |
| 211 | |
Joakim Soderberg | 08e434e | 2013-02-01 14:52:53 +0100 | [diff] [blame] | 212 | # Generate the config.h that includes all the compilation settings. |
| 213 | configure_file( |
Markus Elfring | 299244f | 2013-10-26 20:03:43 +0800 | [diff] [blame] | 214 | "${PROJECT_SOURCE_DIR}/config.h.cmake" |
| 215 | "${PROJECT_BINARY_DIR}/lws_config.h") |
Joakim Soderberg | 08e434e | 2013-02-01 14:52:53 +0100 | [diff] [blame] | 216 | |
Joakim Soderberg | 08e434e | 2013-02-01 14:52:53 +0100 | [diff] [blame] | 217 | if (MSVC) |
| 218 | # Turn off stupid microsoft security warnings. |
| 219 | add_definitions(-D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE) |
Edwin van den Oetelaar | 15a38a7 | 2013-03-10 06:53:57 +0800 | [diff] [blame] | 220 | endif(MSVC) |
Joakim Soderberg | 08e434e | 2013-02-01 14:52:53 +0100 | [diff] [blame] | 221 | |
Markus Elfring | 299244f | 2013-10-26 20:03:43 +0800 | [diff] [blame] | 222 | include_directories("${PROJECT_SOURCE_DIR}/lib") |
Joakim Soderberg | 08e434e | 2013-02-01 14:52:53 +0100 | [diff] [blame] | 223 | |
Joakim Soderberg | add3926 | 2013-02-06 15:25:26 +0900 | [diff] [blame] | 224 | # Group headers and sources. |
| 225 | # Some IDEs use this for nicer file structure. |
Joakim Soderberg | 08e434e | 2013-02-01 14:52:53 +0100 | [diff] [blame] | 226 | set(HDR_PRIVATE |
Joakim Soderberg | add3926 | 2013-02-06 15:25:26 +0900 | [diff] [blame] | 227 | lib/private-libwebsockets.h |
Markus Elfring | 299244f | 2013-10-26 20:03:43 +0800 | [diff] [blame] | 228 | "${PROJECT_BINARY_DIR}/lws_config.h" |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 229 | ) |
Joakim Soderberg | add3926 | 2013-02-06 15:25:26 +0900 | [diff] [blame] | 230 | |
| 231 | set(HDR_PUBLIC |
Markus Elfring | 299244f | 2013-10-26 20:03:43 +0800 | [diff] [blame] | 232 | "${PROJECT_SOURCE_DIR}/lib/libwebsockets.h" |
Joakim Soderberg | 08e434e | 2013-02-01 14:52:53 +0100 | [diff] [blame] | 233 | ) |
| 234 | |
| 235 | set(SOURCES |
| 236 | lib/base64-decode.c |
Joakim Soderberg | 08e434e | 2013-02-01 14:52:53 +0100 | [diff] [blame] | 237 | lib/handshake.c |
| 238 | lib/libwebsockets.c |
Joakim Soderberg | 08e434e | 2013-02-01 14:52:53 +0100 | [diff] [blame] | 239 | lib/output.c |
| 240 | lib/parsers.c |
Joakim Soderberg | 08e434e | 2013-02-01 14:52:53 +0100 | [diff] [blame] | 241 | lib/sha-1.c |
| 242 | ) |
| 243 | |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 244 | if (NOT LWS_WITHOUT_CLIENT) |
Joakim Soderberg | 7eadd58 | 2013-02-22 09:28:04 +0800 | [diff] [blame] | 245 | list(APPEND SOURCES |
| 246 | lib/client.c |
| 247 | lib/client-handshake.c |
| 248 | lib/client-parser.c |
| 249 | ) |
| 250 | endif() |
| 251 | |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 252 | if (NOT LWS_WITHOUT_SERVER) |
Joakim Soderberg | 7eadd58 | 2013-02-22 09:28:04 +0800 | [diff] [blame] | 253 | list(APPEND SOURCES |
| 254 | lib/server.c |
| 255 | lib/server-handshake.c |
| 256 | ) |
| 257 | endif() |
| 258 | |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 259 | if (NOT LWS_WITHOUT_EXTENSIONS) |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 260 | list(APPEND HDR_PRIVATE |
| 261 | lib/extension-deflate-frame.h |
| 262 | lib/extension-deflate-stream.h |
| 263 | ) |
| 264 | |
| 265 | list(APPEND SOURCES |
| 266 | lib/extension.c |
| 267 | lib/extension-deflate-frame.c |
| 268 | lib/extension-deflate-stream.c |
| 269 | ) |
| 270 | endif() |
| 271 | |
Joakim Soderberg | add3926 | 2013-02-06 15:25:26 +0900 | [diff] [blame] | 272 | # Add helper files for Windows. |
| 273 | if (WIN32) |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 274 | set(WIN32_HELPERS_PATH win32port/win32helpers) |
Joakim Soderberg | add3926 | 2013-02-06 15:25:26 +0900 | [diff] [blame] | 275 | |
Andy Green | a833494 | 2013-03-09 09:16:41 +0800 | [diff] [blame] | 276 | list(APPEND HDR_PUBLIC |
Joakim Soderberg | add3926 | 2013-02-06 15:25:26 +0900 | [diff] [blame] | 277 | ${WIN32_HELPERS_PATH}/websock-w32.h |
| 278 | ${WIN32_HELPERS_PATH}/gettimeofday.h |
| 279 | ) |
Edwin van den Oetelaar | 15a38a7 | 2013-03-10 06:53:57 +0800 | [diff] [blame] | 280 | if (MINGW) |
| 281 | list(APPEND SOURCES |
| 282 | ${WIN32_HELPERS_PATH}/gettimeofday.c |
| 283 | ) |
| 284 | else(MINGW) |
| 285 | list(APPEND SOURCES |
| 286 | ${WIN32_HELPERS_PATH}/websock-w32.c |
| 287 | ${WIN32_HELPERS_PATH}/gettimeofday.c |
| 288 | ) |
| 289 | endif(MINGW) |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 290 | include_directories(${WIN32_HELPERS_PATH}) |
Edwin van den Oetelaar | 15a38a7 | 2013-03-10 06:53:57 +0800 | [diff] [blame] | 291 | else(WIN32) |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 292 | # Unix. |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 293 | if (NOT LWS_WITHOUT_DAEMONIZE) |
Joakim Soderberg | d2edfec | 2013-02-06 15:27:27 +0900 | [diff] [blame] | 294 | list(APPEND SOURCES |
| 295 | lib/daemonize.c |
| 296 | ) |
| 297 | endif() |
Edwin van den Oetelaar | 15a38a7 | 2013-03-10 06:53:57 +0800 | [diff] [blame] | 298 | endif(WIN32) |
Joakim Soderberg | add3926 | 2013-02-06 15:25:26 +0900 | [diff] [blame] | 299 | |
| 300 | if (UNIX) |
Joakim Soderberg | fcec61c | 2013-02-22 09:28:02 +0800 | [diff] [blame] | 301 | if (NOT HAVE_GETIFADDRS) |
Joakim Soderberg | add3926 | 2013-02-06 15:25:26 +0900 | [diff] [blame] | 302 | list(APPEND HDR_PRIVATE lib/getifaddrs.h) |
| 303 | list(APPEND SOURCES lib/getifaddrs.c) |
| 304 | endif() |
Edwin van den Oetelaar | 15a38a7 | 2013-03-10 06:53:57 +0800 | [diff] [blame] | 305 | endif(UNIX) |
Joakim Soderberg | add3926 | 2013-02-06 15:25:26 +0900 | [diff] [blame] | 306 | |
Andy Green | da3f6ff | 2013-03-16 12:32:59 +0800 | [diff] [blame] | 307 | |
Joakim Soderberg | c2012e4 | 2013-03-23 08:55:02 +0800 | [diff] [blame] | 308 | if (CMAKE_COMPILER_IS_GNUCC OR CMAKE_COMPILER_IS_GNUCXX) |
pmcdona | 0a0a7eb | 2013-12-18 10:17:25 +0800 | [diff] [blame] | 309 | if (UNIX) |
Erland Isaksson | 578a24d | 2013-09-18 09:00:52 +0800 | [diff] [blame] | 310 | set( CMAKE_C_FLAGS "-Wall -Werror -O4 -fvisibility=hidden ${CMAKE_C_FLAGS}" ) |
pmcdona | 0a0a7eb | 2013-12-18 10:17:25 +0800 | [diff] [blame] | 311 | else(UNIX) |
| 312 | set( CMAKE_C_FLAGS "-Wall -O4 -fvisibility=hidden ${CMAKE_C_FLAGS}" ) |
| 313 | endif(UNIX) |
Joakim Soderberg | c2012e4 | 2013-03-23 08:55:02 +0800 | [diff] [blame] | 314 | endif () |
Andy Green | da3f6ff | 2013-03-16 12:32:59 +0800 | [diff] [blame] | 315 | |
Joakim Soderberg | 08e434e | 2013-02-01 14:52:53 +0100 | [diff] [blame] | 316 | source_group("Headers Private" FILES ${HDR_PRIVATE}) |
| 317 | source_group("Headers Public" FILES ${HDR_PUBLIC}) |
| 318 | source_group("Sources" FILES ${SOURCES}) |
| 319 | |
Joakim Soderberg | add3926 | 2013-02-06 15:25:26 +0900 | [diff] [blame] | 320 | # |
| 321 | # Create the lib. |
| 322 | # |
Joakim Söderberg | 68e8d73 | 2013-02-06 15:27:39 +0900 | [diff] [blame] | 323 | add_library(websockets STATIC |
Joakim Soderberg | add3926 | 2013-02-06 15:25:26 +0900 | [diff] [blame] | 324 | ${HDR_PRIVATE} |
| 325 | ${HDR_PUBLIC} |
| 326 | ${SOURCES}) |
Joakim Soderberg | 0848353 | 2013-02-13 09:29:17 +0800 | [diff] [blame] | 327 | add_library(websockets_shared SHARED |
| 328 | ${HDR_PRIVATE} |
| 329 | ${HDR_PUBLIC} |
| 330 | ${SOURCES}) |
| 331 | |
Joakim Soderberg | 0848353 | 2013-02-13 09:29:17 +0800 | [diff] [blame] | 332 | if (WIN32) |
Joakim Soderberg | f272cb0 | 2013-02-13 09:29:26 +0800 | [diff] [blame] | 333 | # On Windows libs have the same file ending (.lib) |
| 334 | # for both static and shared libraries, so we |
| 335 | # need a unique name for the static one. |
Joakim Soderberg | 0848353 | 2013-02-13 09:29:17 +0800 | [diff] [blame] | 336 | set_target_properties(websockets |
Joakim Soderberg | f272cb0 | 2013-02-13 09:29:26 +0800 | [diff] [blame] | 337 | PROPERTIES |
Joakim Soderberg | 0848353 | 2013-02-13 09:29:17 +0800 | [diff] [blame] | 338 | OUTPUT_NAME websockets_static) |
Joakim Soderberg | f272cb0 | 2013-02-13 09:29:26 +0800 | [diff] [blame] | 339 | |
| 340 | # Compile as DLL (export function declarations) |
| 341 | set_property( |
| 342 | TARGET websockets_shared |
| 343 | PROPERTY COMPILE_DEFINITIONS |
| 344 | LWS_DLL |
| 345 | LWS_INTERNAL |
| 346 | ) |
Edwin van den Oetelaar | 15a38a7 | 2013-03-10 06:53:57 +0800 | [diff] [blame] | 347 | endif(WIN32) |
Joakim Soderberg | 0848353 | 2013-02-13 09:29:17 +0800 | [diff] [blame] | 348 | |
| 349 | # We want the shared lib to be named "libwebsockets" |
| 350 | # not "libwebsocket_shared". |
| 351 | set_target_properties(websockets_shared |
| 352 | PROPERTIES |
| 353 | OUTPUT_NAME websockets) |
Joakim Soderberg | f83585f | 2013-02-13 09:29:09 +0800 | [diff] [blame] | 354 | |
| 355 | # Set the so version of the lib. |
Andy Green | 19c1a99 | 2013-03-10 06:59:01 +0800 | [diff] [blame] | 356 | # Equivalent to LDFLAGS=-version-info x:x:x |
Joakim Soderberg | f83585f | 2013-02-13 09:29:09 +0800 | [diff] [blame] | 357 | if(CMAKE_COMPILER_IS_GNUCC OR CMAKE_COMPILER_IS_GNUCXX) |
Joakim Soderberg | f272cb0 | 2013-02-13 09:29:26 +0800 | [diff] [blame] | 358 | foreach(lib websockets websockets_shared) |
| 359 | set_target_properties(${lib} |
| 360 | PROPERTIES |
| 361 | SOVERSION ${SOVERSION}) |
| 362 | endforeach() |
Joakim Soderberg | f83585f | 2013-02-13 09:29:09 +0800 | [diff] [blame] | 363 | endif() |
Joakim Soderberg | add3926 | 2013-02-06 15:25:26 +0900 | [diff] [blame] | 364 | |
Joakim Soderberg | 0848353 | 2013-02-13 09:29:17 +0800 | [diff] [blame] | 365 | set(LIB_LIST) |
| 366 | |
Joakim Soderberg | add3926 | 2013-02-06 15:25:26 +0900 | [diff] [blame] | 367 | # |
| 368 | # Find libraries. |
| 369 | # |
Joakim Soderberg | 08e434e | 2013-02-01 14:52:53 +0100 | [diff] [blame] | 370 | |
| 371 | # |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 372 | # ZLIB (Only needed for deflate extensions). |
Joakim Soderberg | 08e434e | 2013-02-01 14:52:53 +0100 | [diff] [blame] | 373 | # |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 374 | if (NOT LWS_WITHOUT_EXTENSIONS) |
| 375 | if (WIN32 AND NOT LWS_USE_EXTERNAL_ZLIB) |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 376 | message("Using included Zlib version") |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 377 | |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 378 | # Compile ZLib if needed. |
| 379 | set(WIN32_ZLIB_PATH "win32port/zlib") |
| 380 | set(ZLIB_SRCS |
| 381 | ${WIN32_ZLIB_PATH}/adler32.c |
| 382 | ${WIN32_ZLIB_PATH}/compress.c |
| 383 | ${WIN32_ZLIB_PATH}/crc32.c |
| 384 | ${WIN32_ZLIB_PATH}/deflate.c |
| 385 | ${WIN32_ZLIB_PATH}/gzclose.c |
| 386 | ${WIN32_ZLIB_PATH}/gzio.c |
| 387 | ${WIN32_ZLIB_PATH}/gzlib.c |
| 388 | ${WIN32_ZLIB_PATH}/gzread.c |
| 389 | ${WIN32_ZLIB_PATH}/gzwrite.c |
| 390 | ${WIN32_ZLIB_PATH}/infback.c |
| 391 | ${WIN32_ZLIB_PATH}/inffast.c |
| 392 | ${WIN32_ZLIB_PATH}/inflate.c |
| 393 | ${WIN32_ZLIB_PATH}/inftrees.c |
| 394 | ${WIN32_ZLIB_PATH}/trees.c |
| 395 | ${WIN32_ZLIB_PATH}/uncompr.c |
| 396 | ${WIN32_ZLIB_PATH}/zutil.c |
| 397 | ) |
Joakim Soderberg | 08e434e | 2013-02-01 14:52:53 +0100 | [diff] [blame] | 398 | |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 399 | # Create the library. |
| 400 | add_library(ZLIB STATIC ${ZLIB_SRCS}) |
Joakim Soderberg | 08e434e | 2013-02-01 14:52:53 +0100 | [diff] [blame] | 401 | |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 402 | # Set the same variables as find_package would. |
| 403 | set(ZLIB_INCLUDE_DIRS ${WIN32_ZLIB_PATH}) |
| 404 | get_property(ZLIB_LIBRARIES TARGET ZLIB PROPERTY LOCATION) |
| 405 | set(ZLIB_FOUND 1) |
| 406 | else() |
| 407 | find_package(ZLIB REQUIRED) |
| 408 | endif() |
Joakim Soderberg | 08e434e | 2013-02-01 14:52:53 +0100 | [diff] [blame] | 409 | |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 410 | # Make sure ZLib is compiled before the libs. |
| 411 | foreach (lib websockets websockets_shared) |
| 412 | add_dependencies(${lib} ZLIB) |
| 413 | endforeach() |
Joakim Soderberg | f272cb0 | 2013-02-13 09:29:26 +0800 | [diff] [blame] | 414 | |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 415 | message("ZLib include dirs: ${ZLIB_INCLUDE_DIRS}") |
| 416 | message("ZLib libraries: ${ZLIB_LIBRARIES}") |
| 417 | include_directories(${ZLIB_INCLUDE_DIRS}) |
| 418 | list(APPEND LIB_LIST ${ZLIB_LIBRARIES}) |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 419 | endif(NOT LWS_WITHOUT_EXTENSIONS) |
Joakim Soderberg | 08e434e | 2013-02-01 14:52:53 +0100 | [diff] [blame] | 420 | |
| 421 | # |
| 422 | # OpenSSL |
| 423 | # |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 424 | if (LWS_WITH_SSL) |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 425 | message("Compiling with SSL support") |
| 426 | |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 427 | if (LWS_USE_CYASSL) |
Joakim Soderberg | 08e434e | 2013-02-01 14:52:53 +0100 | [diff] [blame] | 428 | # Use CyaSSL as OpenSSL replacement. |
Joakim Söderberg | cb4156d | 2013-02-06 15:30:56 +0900 | [diff] [blame] | 429 | # TODO: Add a find_package command for this also. |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 430 | message("CyaSSL include dir: ${LWS_CYASSL_INCLUDE_DIRS}") |
| 431 | message("CyaSSL libraries: ${LWS_CYASSL_LIB}") |
Joakim Söderberg | cb4156d | 2013-02-06 15:30:56 +0900 | [diff] [blame] | 432 | |
Joakim Soderberg | 7df9908 | 2013-02-07 20:24:19 +0800 | [diff] [blame] | 433 | # Additional to the root directory we need to include |
| 434 | # the cyassl/ subdirectory which contains the OpenSSL |
| 435 | # compatability layer headers. |
| 436 | foreach(inc ${CYASSL_INCLUDE_DIRS}) |
Markus Elfring | 299244f | 2013-10-26 20:03:43 +0800 | [diff] [blame] | 437 | include_directories("${inc}" "${inc}/cyassl") |
Joakim Soderberg | 7df9908 | 2013-02-07 20:24:19 +0800 | [diff] [blame] | 438 | endforeach() |
| 439 | |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 440 | list(APPEND LIB_LIST "${LWS_CYASSL_LIB}") |
Joakim Soderberg | 08e434e | 2013-02-01 14:52:53 +0100 | [diff] [blame] | 441 | else() |
| 442 | # TODO: Add support for STATIC also. |
| 443 | find_package(OpenSSL REQUIRED) |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 444 | |
Joakim Söderberg | cb4156d | 2013-02-06 15:30:56 +0900 | [diff] [blame] | 445 | message("OpenSSL include dir: ${OPENSSL_INCLUDE_DIR}") |
| 446 | message("OpenSSL libraries: ${OPENSSL_LIBRARIES}") |
Joakim Soderberg | add3926 | 2013-02-06 15:25:26 +0900 | [diff] [blame] | 447 | |
Markus Elfring | 299244f | 2013-10-26 20:03:43 +0800 | [diff] [blame] | 448 | include_directories("${OPENSSL_INCLUDE_DIR}") |
Joakim Soderberg | 0848353 | 2013-02-13 09:29:17 +0800 | [diff] [blame] | 449 | list(APPEND LIB_LIST ${OPENSSL_LIBRARIES}) |
Joakim Söderberg | cb4156d | 2013-02-06 15:30:56 +0900 | [diff] [blame] | 450 | endif() |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 451 | endif(LWS_WITH_SSL) |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 452 | |
| 453 | # |
| 454 | # Platform specific libs. |
| 455 | # |
| 456 | if (WIN32) |
Joakim Soderberg | 0848353 | 2013-02-13 09:29:17 +0800 | [diff] [blame] | 457 | list(APPEND LIB_LIST ws2_32.lib) |
Joakim Soderberg | 08e434e | 2013-02-01 14:52:53 +0100 | [diff] [blame] | 458 | endif() |
| 459 | |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 460 | if (UNIX) |
Joakim Soderberg | 0848353 | 2013-02-13 09:29:17 +0800 | [diff] [blame] | 461 | list(APPEND LIB_LIST m) |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 462 | endif() |
Joakim Soderberg | 08e434e | 2013-02-01 14:52:53 +0100 | [diff] [blame] | 463 | |
Joakim Soderberg | f272cb0 | 2013-02-13 09:29:26 +0800 | [diff] [blame] | 464 | # Setup the linking for all libs. |
| 465 | foreach (lib websockets websockets_shared) |
| 466 | target_link_libraries(${lib} ${LIB_LIST}) |
| 467 | endforeach() |
Joakim Soderberg | 0848353 | 2013-02-13 09:29:17 +0800 | [diff] [blame] | 468 | |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 469 | # |
| 470 | # Test applications |
| 471 | # |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 472 | set(TEST_APP_LIST) |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 473 | if (NOT LWS_WITHOUT_TESTAPPS) |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 474 | # |
| 475 | # Helper function for adding a test app. |
| 476 | # |
Joakim Soderberg | 11a8cda | 2013-02-22 09:28:06 +0800 | [diff] [blame] | 477 | macro(create_test_app TEST_NAME MAIN_SRC WIN32_SRCS WIN32_HDRS) |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 478 | |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 479 | set(TEST_SRCS ${MAIN_SRC}) |
| 480 | set(TEST_HDR) |
| 481 | |
| 482 | if (WIN32) |
| 483 | list(APPEND TEST_SRCS |
| 484 | ${WIN32_HELPERS_PATH}/getopt.c |
| 485 | ${WIN32_HELPERS_PATH}/getopt_long.c |
| 486 | ${WIN32_HELPERS_PATH}/gettimeofday.c |
| 487 | ${WIN32_SRCS}) |
| 488 | |
| 489 | list(APPEND TEST_HDR |
| 490 | ${WIN32_HELPERS_PATH}/getopt.h |
| 491 | ${WIN32_HELPERS_PATH}/gettimeofday.h |
| 492 | ${WIN32_HDRS}) |
| 493 | endif(WIN32) |
| 494 | |
Joakim Soderberg | 0848353 | 2013-02-13 09:29:17 +0800 | [diff] [blame] | 495 | source_group("Headers Private" FILES ${TEST_HDR}) |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 496 | source_group("Sources" FILES ${TEST_SRCS}) |
| 497 | add_executable(${TEST_NAME} ${TEST_SRCS} ${TEST_HDR}) |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 498 | |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 499 | if (LWS_LINK_TESTAPPS_DYNAMIC) |
Joakim Soderberg | b37827b | 2013-02-22 09:28:08 +0800 | [diff] [blame] | 500 | target_link_libraries(${TEST_NAME} websockets_shared) |
| 501 | add_dependencies(${TEST_NAME} websockets_shared) |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 502 | else(LWS_LINK_TESTAPPS_DYNAMIC) |
Joakim Soderberg | b37827b | 2013-02-22 09:28:08 +0800 | [diff] [blame] | 503 | target_link_libraries(${TEST_NAME} websockets) |
| 504 | add_dependencies(${TEST_NAME} websockets) |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 505 | endif(LWS_LINK_TESTAPPS_DYNAMIC) |
Joakim Soderberg | b37827b | 2013-02-22 09:28:08 +0800 | [diff] [blame] | 506 | |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 507 | # Set test app specific defines. |
| 508 | set_property(TARGET ${TEST_NAME} |
Joakim Soderberg | f272cb0 | 2013-02-13 09:29:26 +0800 | [diff] [blame] | 509 | PROPERTY COMPILE_DEFINITIONS |
Andy Green | 63b3b95 | 2013-03-09 12:51:43 +0800 | [diff] [blame] | 510 | INSTALL_DATADIR="${CMAKE_INSTALL_PREFIX}/share" |
Joakim Soderberg | d2edfec | 2013-02-06 15:27:27 +0900 | [diff] [blame] | 511 | ) |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 512 | |
| 513 | # Prefix the binary names with libwebsockets. |
| 514 | set_target_properties(${TEST_NAME} |
| 515 | PROPERTIES |
| 516 | OUTPUT_NAME libwebsockets-${TEST_NAME}) |
| 517 | |
| 518 | # Add to the list of tests. |
Joakim Soderberg | 7eadd58 | 2013-02-22 09:28:04 +0800 | [diff] [blame] | 519 | list(APPEND TEST_APP_LIST ${TEST_NAME}) |
Joakim Soderberg | 11a8cda | 2013-02-22 09:28:06 +0800 | [diff] [blame] | 520 | endmacro() |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 521 | |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 522 | if (LWS_WITH_SSL AND NOT LWS_USE_CYASSL) |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 523 | message("Searching for OpenSSL executable and dlls") |
| 524 | find_package(OpenSSLbins) |
| 525 | message("OpenSSL executable: ${OPENSSL_EXECUTABLE}") |
| 526 | endif() |
| 527 | |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 528 | if (NOT LWS_WITHOUT_SERVER) |
Joakim Soderberg | 7eadd58 | 2013-02-22 09:28:04 +0800 | [diff] [blame] | 529 | # |
| 530 | # test-server |
| 531 | # |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 532 | if (NOT LWS_WITHOUT_TEST_SERVER) |
Joakim Soderberg | 7eadd58 | 2013-02-22 09:28:04 +0800 | [diff] [blame] | 533 | create_test_app(test-server |
| 534 | "test-server/test-server.c" |
| 535 | "" |
| 536 | "${WIN32_HELPERS_PATH}/netdb.h;${WIN32_HELPERS_PATH}/strings.h;${WIN32_HELPERS_PATH}/unistd.h;${WIN32_HELPERS_PATH}/websock-w32.h") |
| 537 | endif() |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 538 | |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 539 | # |
| 540 | # test-server-extpoll |
| 541 | # |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 542 | if (NOT LWS_WITHOUT_TEST_SERVER_EXTPOLL) |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 543 | create_test_app(test-server-extpoll |
| 544 | "test-server/test-server.c" |
| 545 | "win32port/win32helpers/websock-w32.c" |
| 546 | "${WIN32_HELPERS_PATH}/netdb.h;${WIN32_HELPERS_PATH}/strings.h;${WIN32_HELPERS_PATH}/unistd.h;${WIN32_HELPERS_PATH}/websock-w32.h") |
| 547 | # Set defines for this executable only. |
| 548 | set_property( |
| 549 | TARGET test-server-extpoll |
| 550 | PROPERTY COMPILE_DEFINITIONS |
| 551 | EXTERNAL_POLL |
Andy Green | 63b3b95 | 2013-03-09 12:51:43 +0800 | [diff] [blame] | 552 | INSTALL_DATADIR="${CMAKE_INSTALL_PREFIX}/share" |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 553 | ) |
Joakim Soderberg | f272cb0 | 2013-02-13 09:29:26 +0800 | [diff] [blame] | 554 | |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 555 | # We need to link against winsock code. |
| 556 | if (WIN32) |
| 557 | target_link_libraries(test-server-extpoll ws2_32.lib) |
Edwin van den Oetelaar | 15a38a7 | 2013-03-10 06:53:57 +0800 | [diff] [blame] | 558 | endif(WIN32) |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 559 | endif() |
| 560 | |
| 561 | # Data files for running the test server. |
| 562 | set(TEST_SERVER_DATA |
Markus Elfring | 299244f | 2013-10-26 20:03:43 +0800 | [diff] [blame] | 563 | "${PROJECT_SOURCE_DIR}/test-server/favicon.ico" |
| 564 | "${PROJECT_SOURCE_DIR}/test-server/leaf.jpg" |
| 565 | "${PROJECT_SOURCE_DIR}/test-server/libwebsockets.org-logo.png" |
| 566 | "${PROJECT_SOURCE_DIR}/test-server/test.html") |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 567 | |
| 568 | # Generate self-signed SSL certs for the test-server. |
Joakim Soderberg | 6596e4b | 2014-02-18 13:38:14 +0100 | [diff] [blame] | 569 | if (LWS_WITH_SSL AND OPENSSL_EXECUTABLE AND NOT LWS_WITHOUT_TEST_SERVER) |
Joakim Soderberg | 20aedc8 | 2013-02-22 09:28:11 +0800 | [diff] [blame] | 570 | message("Generating SSL Certificates for the test-server...") |
| 571 | |
Markus Elfring | 299244f | 2013-10-26 20:03:43 +0800 | [diff] [blame] | 572 | set(TEST_SERVER_SSL_KEY "${PROJECT_BINARY_DIR}/libwebsockets-test-server.key.pem") |
| 573 | set(TEST_SERVER_SSL_CERT "${PROJECT_BINARY_DIR}/libwebsockets-test-server.pem") |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 574 | |
| 575 | if (WIN32) |
Markus Elfring | 299244f | 2013-10-26 20:03:43 +0800 | [diff] [blame] | 576 | file(WRITE "${PROJECT_BINARY_DIR}/openssl_input.txt" |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 577 | "GB\n" |
| 578 | "Erewhon\n" |
| 579 | "All around\n" |
| 580 | "libwebsockets-test\n" |
| 581 | "localhost\n" |
Joakim Soderberg | 20aedc8 | 2013-02-22 09:28:11 +0800 | [diff] [blame] | 582 | "none@invalid.org\n\n" |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 583 | ) |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 584 | |
Joakim Soderberg | 20aedc8 | 2013-02-22 09:28:11 +0800 | [diff] [blame] | 585 | # The "type" command is a bit picky with paths. |
| 586 | file(TO_NATIVE_PATH "${PROJECT_BINARY_DIR}/openssl_input.txt" OPENSSL_INPUT_WIN_PATH) |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 587 | message("OPENSSL_INPUT_WIN_PATH = ${OPENSSL_INPUT_WIN_PATH}") |
| 588 | message("cmd = \"${OPENSSL_EXECUTABLE}\" req -new -newkey rsa:1024 -days 10000 -nodes -x509 -keyout \"${TEST_SERVER_SSL_KEY}\" -out \"${TEST_SERVER_SSL_CERT}\"") |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 589 | |
| 590 | execute_process( |
Joakim Soderberg | 20aedc8 | 2013-02-22 09:28:11 +0800 | [diff] [blame] | 591 | COMMAND cmd /c type "${OPENSSL_INPUT_WIN_PATH}" |
| 592 | COMMAND "${OPENSSL_EXECUTABLE}" req -new -newkey rsa:1024 -days 10000 -nodes -x509 -keyout "${TEST_SERVER_SSL_KEY}" -out "${TEST_SERVER_SSL_CERT}" |
| 593 | RESULT_VARIABLE OPENSSL_RETURN_CODE) |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 594 | |
Joakim Soderberg | c7ed2be | 2013-02-22 09:28:17 +0800 | [diff] [blame] | 595 | message("\n") |
| 596 | |
Joakim Soderberg | 20aedc8 | 2013-02-22 09:28:11 +0800 | [diff] [blame] | 597 | if (OPENSSL_RETURN_CODE) |
Joakim Soderberg | 6596e4b | 2014-02-18 13:38:14 +0100 | [diff] [blame] | 598 | message(WARNING "!!! Failed to generate SSL certificate for Test Server using cmd.exe !!!:\nOpenSSL return code = ${OPENSSL_RETURN_CODE}") |
| 599 | else() |
| 600 | message("SUCCSESFULLY generated SSL certificate") |
Joakim Soderberg | 20aedc8 | 2013-02-22 09:28:11 +0800 | [diff] [blame] | 601 | endif() |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 602 | else() |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 603 | # Unix. |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 604 | execute_process( |
| 605 | COMMAND printf "GB\\nErewhon\\nAll around\\nlibwebsockets-test\\n\\nlocalhost\\nnone@invalid.org\\n" |
Markus Elfring | 299244f | 2013-10-26 20:03:43 +0800 | [diff] [blame] | 606 | COMMAND "${OPENSSL_EXECUTABLE}" |
| 607 | req -new -newkey rsa:1024 -days 10000 -nodes -x509 -keyout "${TEST_SERVER_SSL_KEY}" -out "${TEST_SERVER_SSL_CERT}" |
Joakim Soderberg | 6596e4b | 2014-02-18 13:38:14 +0100 | [diff] [blame] | 608 | RESULT_VARIABLE OPENSSL_RETURN_CODE) |
| 609 | |
| 610 | if (OPENSSL_RETURN_CODE) |
| 611 | message(WARNING "!!! Failed to generate SSL certificate for Test Server!!!:\nOpenSSL return code = ${OPENSSL_RETURN_CODE}") |
| 612 | else() |
| 613 | message("SUCCSESFULLY generated SSL certificate") |
| 614 | endif() |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 615 | endif() |
| 616 | |
| 617 | list(APPEND TEST_SERVER_DATA |
Markus Elfring | 299244f | 2013-10-26 20:03:43 +0800 | [diff] [blame] | 618 | "${TEST_SERVER_SSL_KEY}" |
| 619 | "${TEST_SERVER_SSL_CERT}") |
Joakim Soderberg | f272cb0 | 2013-02-13 09:29:26 +0800 | [diff] [blame] | 620 | endif() |
Joakim Soderberg | c7ed2be | 2013-02-22 09:28:17 +0800 | [diff] [blame] | 621 | |
Joakim Soderberg | 6596e4b | 2014-02-18 13:38:14 +0100 | [diff] [blame] | 622 | add_custom_command(TARGET test-server |
| 623 | POST_BUILD |
| 624 | COMMAND "${CMAKE_COMMAND}" -E make_directory "$<TARGET_FILE_DIR:test-server>/../share/libwebsockets-test-server") |
| 625 | |
Joakim Soderberg | c7ed2be | 2013-02-22 09:28:17 +0800 | [diff] [blame] | 626 | # Copy the file needed to run the server so that the test apps can |
| 627 | # reach them from their default output location |
| 628 | foreach (TEST_FILE ${TEST_SERVER_DATA}) |
Joakim Soderberg | 6596e4b | 2014-02-18 13:38:14 +0100 | [diff] [blame] | 629 | if (EXISTS ${TEST_FILE}) |
| 630 | add_custom_command(TARGET test-server |
| 631 | POST_BUILD |
| 632 | COMMAND "${CMAKE_COMMAND}" -E copy "${TEST_FILE}" "$<TARGET_FILE_DIR:test-server>/../share/libwebsockets-test-server" VERBATIM) |
| 633 | endif() |
Joakim Soderberg | c7ed2be | 2013-02-22 09:28:17 +0800 | [diff] [blame] | 634 | endforeach() |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 635 | endif(NOT LWS_WITHOUT_SERVER) |
Joakim Söderberg | 68e8d73 | 2013-02-06 15:27:39 +0900 | [diff] [blame] | 636 | |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 637 | if (NOT LWS_WITHOUT_CLIENT) |
Joakim Soderberg | 7eadd58 | 2013-02-22 09:28:04 +0800 | [diff] [blame] | 638 | # |
| 639 | # test-client |
| 640 | # |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 641 | if (NOT LWS_WITHOUT_TEST_CLIENT) |
Joakim Soderberg | 7eadd58 | 2013-02-22 09:28:04 +0800 | [diff] [blame] | 642 | create_test_app(test-client |
| 643 | "test-server/test-client.c" |
| 644 | "" |
| 645 | "") |
| 646 | endif() |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 647 | |
Joakim Soderberg | 7eadd58 | 2013-02-22 09:28:04 +0800 | [diff] [blame] | 648 | # |
| 649 | # test-fraggle |
| 650 | # |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 651 | if (NOT LWS_WITHOUT_TEST_FRAGGLE) |
Joakim Soderberg | 7eadd58 | 2013-02-22 09:28:04 +0800 | [diff] [blame] | 652 | create_test_app(test-fraggle |
| 653 | "test-server/test-fraggle.c" |
| 654 | "" |
| 655 | "${WIN32_HELPERS_PATH}/unistd.h;${WIN32_HELPERS_PATH}/sys/time.h") |
| 656 | endif() |
| 657 | |
| 658 | # |
| 659 | # test-ping |
| 660 | # |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 661 | if (NOT LWS_WITHOUT_TEST_PING) |
Joakim Soderberg | 7eadd58 | 2013-02-22 09:28:04 +0800 | [diff] [blame] | 662 | create_test_app(test-ping |
| 663 | "test-server/test-ping.c" |
| 664 | "" |
| 665 | "${WIN32_HELPERS_PATH}/unistd.h;${WIN32_HELPERS_PATH}/sys/time.h") |
| 666 | endif() |
Andy Green | 27696f2 | 2013-03-10 08:09:25 +0800 | [diff] [blame] | 667 | # |
| 668 | # test-echo |
| 669 | # |
| 670 | if (NOT WITHOUT_TEST_ECHO) |
| 671 | create_test_app(test-echo |
| 672 | "test-server/test-echo.c" |
| 673 | "" |
| 674 | "${WIN32_HELPERS_PATH}/unistd.h;${WIN32_HELPERS_PATH}/sys/time.h") |
| 675 | endif() |
| 676 | |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 677 | endif(NOT LWS_WITHOUT_CLIENT) |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 678 | |
| 679 | # |
| 680 | # Copy OpenSSL dlls to the output directory on Windows. |
| 681 | # (Otherwise we'll get an error when trying to run) |
| 682 | # |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 683 | if (WIN32 AND LWS_WITH_SSL AND NOT LWS_USE_CYASSL) |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 684 | if(OPENSSL_BIN_FOUND) |
Joakim Soderberg | 20aedc8 | 2013-02-22 09:28:11 +0800 | [diff] [blame] | 685 | message("OpenSSL dlls found:") |
| 686 | message(" Libeay: ${LIBEAY_BIN}") |
| 687 | message(" SSLeay: ${SSLEAY_BIN}") |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 688 | |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 689 | foreach(TARGET_BIN ${TEST_APP_LIST}) |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 690 | add_custom_command(TARGET ${TARGET_BIN} |
| 691 | POST_BUILD |
Markus Elfring | 299244f | 2013-10-26 20:03:43 +0800 | [diff] [blame] | 692 | COMMAND "${CMAKE_COMMAND}" -E copy "${LIBEAY_BIN}" "$<TARGET_FILE_DIR:${TARGET_BIN}>" VERBATIM) |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 693 | |
| 694 | add_custom_command(TARGET ${TARGET_BIN} |
| 695 | POST_BUILD |
Markus Elfring | 299244f | 2013-10-26 20:03:43 +0800 | [diff] [blame] | 696 | COMMAND "${CMAKE_COMMAND}" -E copy "${SSLEAY_BIN}" "$<TARGET_FILE_DIR:${TARGET_BIN}>" VERBATIM) |
Joakim Soderberg | 4c53123 | 2013-02-06 15:26:58 +0900 | [diff] [blame] | 697 | endforeach() |
| 698 | endif() |
| 699 | endif() |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 700 | endif(NOT LWS_WITHOUT_TESTAPPS) |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 701 | |
| 702 | if (UNIX) |
| 703 | # Generate documentation. |
| 704 | # TODO: Fix this on Windows. |
| 705 | message("Generating API documentation") |
Markus Elfring | 299244f | 2013-10-26 20:03:43 +0800 | [diff] [blame] | 706 | file(GLOB C_FILES "${PROJECT_SOURCE_DIR}/lib/*.c") |
| 707 | execute_process(COMMAND "${CMAKE_COMMAND}" -E make_directory "${PROJECT_BINARY_DIR}/doc/") |
Joakim Söderberg | 455e451 | 2013-02-19 10:14:54 +0800 | [diff] [blame] | 708 | |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 709 | execute_process( |
Markus Elfring | 299244f | 2013-10-26 20:03:43 +0800 | [diff] [blame] | 710 | COMMAND "${PROJECT_SOURCE_DIR}/scripts/kernel-doc" -html ${C_FILES} ${HDR_PUBLIC} |
| 711 | OUTPUT_FILE "${PROJECT_BINARY_DIR}/doc/libwebsockets-api-doc.html" |
Joakim Soderberg | 7eadd58 | 2013-02-22 09:28:04 +0800 | [diff] [blame] | 712 | ERROR_QUIET) |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 713 | |
| 714 | execute_process( |
Markus Elfring | 299244f | 2013-10-26 20:03:43 +0800 | [diff] [blame] | 715 | COMMAND "${PROJECT_SOURCE_DIR}/scripts/kernel-doc" -text ${C_FILES} ${HDR_PUBLIC} |
| 716 | OUTPUT_FILE "${PROJECT_BINARY_DIR}/doc/libwebsockets-api-doc.txt" |
Joakim Soderberg | 7eadd58 | 2013-02-22 09:28:04 +0800 | [diff] [blame] | 717 | ERROR_QUIET) |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 718 | |
| 719 | # Generate and install pkgconfig. |
| 720 | # (This is not indented, because the tabs will be part of the output) |
Markus Elfring | 299244f | 2013-10-26 20:03:43 +0800 | [diff] [blame] | 721 | file(WRITE "${PROJECT_BINARY_DIR}/libwebsockets.pc" |
thinkski | dd93a0c | 2013-04-12 10:31:46 +0800 | [diff] [blame] | 722 | "prefix="${CMAKE_INSTALL_PREFIX}" |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 723 | exec_prefix=\${prefix} |
Andy Green | 975423c | 2013-02-26 11:58:45 +0800 | [diff] [blame] | 724 | libdir=\${exec_prefix}/lib${LIB_SUFFIX} |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 725 | includedir=\${prefix}/include |
| 726 | |
| 727 | Name: libwebsockets |
| 728 | Description: Websockets server and client library |
Andy Green | e919af8 | 2014-02-15 14:45:14 +0800 | [diff] [blame] | 729 | Version: ${CPACK_PACKAGE_VERSION_MAJOR}.${CPACK_PACKAGE_VERSION_MINOR} |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 730 | |
| 731 | Libs: -L\${libdir} -lwebsockets |
| 732 | Cflags: -I\${includedir}" |
| 733 | ) |
| 734 | |
Markus Elfring | 299244f | 2013-10-26 20:03:43 +0800 | [diff] [blame] | 735 | install(FILES "${PROJECT_BINARY_DIR}/libwebsockets.pc" |
Andy Green | c8c1662 | 2013-03-10 08:10:19 +0800 | [diff] [blame] | 736 | DESTINATION lib${LIB_SUFFIX}/pkgconfig) |
Edwin van den Oetelaar | 15a38a7 | 2013-03-10 06:53:57 +0800 | [diff] [blame] | 737 | endif(UNIX) |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 738 | |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 739 | # |
| 740 | # Installation preparations. |
| 741 | # |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 742 | |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 743 | if(WIN32 AND NOT CYGWIN) |
| 744 | set(DEF_INSTALL_CMAKE_DIR cmake) |
| 745 | else() |
| 746 | set(DEF_INSTALL_CMAKE_DIR lib/cmake/libwebsockets) |
| 747 | endif() |
| 748 | |
| 749 | set(LWS_INSTALL_CMAKE_DIR ${DEF_INSTALL_CMAKE_DIR} CACHE PATH "Installation directory for CMake files") |
| 750 | |
| 751 | # Make sure the paths are absolute. |
| 752 | foreach(p LIB BIN INCLUDE CMAKE) |
| 753 | set(var LWS_INSTALL_${p}_DIR) |
| 754 | if(NOT IS_ABSOLUTE "${${var}}") |
| 755 | set(${var} "${CMAKE_INSTALL_PREFIX}/${${var}}") |
| 756 | endif() |
| 757 | endforeach() |
| 758 | |
| 759 | # Export targets (This is used for other CMake projects to easily find the libraries and include files). |
| 760 | export(TARGETS websockets websockets_shared |
| 761 | FILE "${PROJECT_BINARY_DIR}/LibwebsocketsTargets.cmake") |
| 762 | export(PACKAGE libwebsockets) |
| 763 | |
| 764 | # Generate the config file for the build-tree. |
| 765 | set(LWS__INCLUDE_DIRS |
| 766 | "${PROJECT_SOURCE_DIR}/lib" |
| 767 | "${PROJECT_BINARY_DIR}") |
| 768 | set(LIBWEBSOCKETS_INCLUDE_DIRS ${LWS__INCLUDE_DIRS} CACHE PATH "Libwebsockets include directories") |
| 769 | configure_file(${PROJECT_SOURCE_DIR}/cmake/LibwebsocketsConfig.cmake.in |
| 770 | ${PROJECT_BINARY_DIR}/LibwebsocketsConfig.cmake |
| 771 | @ONLY) |
| 772 | |
| 773 | # Generate the config file for the installation tree. |
| 774 | file(RELATIVE_PATH |
| 775 | REL_INCLUDE_DIR |
| 776 | "${LWS_INSTALL_CMAKE_DIR}" |
| 777 | "${LWS_INSTALL_INCLUDE_DIR}") # Calculate the relative directory from the Cmake dir. |
| 778 | |
| 779 | # Note the EVENT_CMAKE_DIR is defined in JanssonConfig.cmake.in, |
| 780 | # we escape it here so it's evaluated when it is included instead |
| 781 | # so that the include dirs are given relative to where the |
| 782 | # config file is located. |
| 783 | set(LWS__INCLUDE_DIRS |
| 784 | "\${LWS_CMAKE_DIR}/${REL_INCLUDE_DIR}") |
| 785 | configure_file(${PROJECT_SOURCE_DIR}/cmake/LibwebsocketsConfig.cmake.in |
| 786 | ${PROJECT_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/LibwebsocketsConfig.cmake |
| 787 | @ONLY) |
| 788 | |
| 789 | # Generate version info for both build-tree and install-tree. |
| 790 | configure_file(${PROJECT_SOURCE_DIR}/cmake/LibwebsocketsConfigVersion.cmake.in |
| 791 | ${PROJECT_BINARY_DIR}/LibwebsocketsConfigVersion.cmake |
| 792 | @ONLY) |
| 793 | |
| 794 | set_target_properties(websockets websockets_shared |
| 795 | PROPERTIES PUBLIC_HEADER "${HDR_PUBLIC}") |
| 796 | |
| 797 | # |
| 798 | # Installation. |
| 799 | # |
| 800 | |
| 801 | # Install libs and headers. |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 802 | install(TARGETS websockets websockets_shared |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 803 | EXPORT LibwebsocketsTargets |
| 804 | LIBRARY DESTINATION "${LWS_INSTALL_LIB_DIR}${LIB_SUFFIX}" COMPONENT libraries |
| 805 | ARCHIVE DESTINATION "${LWS_INSTALL_LIB_DIR}${LIB_SUFFIX}" COMPONENT libraries |
| 806 | RUNTIME DESTINATION "${LWS_INSTALL_BIN_DIR}" COMPONENT libraries # Windows DLLs |
| 807 | PUBLIC_HEADER DESTINATION "${LWS_INSTALL_INCLUDE_DIR}" COMPONENT dev) |
Joakim Soderberg | b37827b | 2013-02-22 09:28:08 +0800 | [diff] [blame] | 808 | set(CPACK_COMPONENT_LIBRARIES_DISPLAY_NAME "Libraries") |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 809 | set(CPACK_COMPONENT_DEV_DISPLAY_NAME "Development files") |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 810 | |
| 811 | # Install test apps. |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 812 | if (NOT LWS_WITHOUT_TESTAPPS) |
Joakim Soderberg | b37827b | 2013-02-22 09:28:08 +0800 | [diff] [blame] | 813 | install(TARGETS test-client ${TEST_APP_LIST} |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 814 | RUNTIME DESTINATION ${LWS_INSTALL_EXAMPLES_DIR} |
Joakim Soderberg | b37827b | 2013-02-22 09:28:08 +0800 | [diff] [blame] | 815 | COMPONENT examples) |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 816 | set(CPACK_COMPONENT_EXAMPLES_DISPLAY_NAME "Example files") |
Joakim Söderberg | 6ac9709 | 2013-02-19 10:14:37 +0800 | [diff] [blame] | 817 | endif() |
| 818 | |
Joakim Soderberg | b37827b | 2013-02-22 09:28:08 +0800 | [diff] [blame] | 819 | # Programs shared files used by the test-server. |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 820 | if (NOT LWS_WITHOUT_TESTAPPS AND NOT LWS_WITHOUT_SERVER) |
Joakim Soderberg | b37827b | 2013-02-22 09:28:08 +0800 | [diff] [blame] | 821 | install(FILES ${TEST_SERVER_DATA} |
| 822 | DESTINATION share/libwebsockets-test-server |
| 823 | COMPONENT examples) |
| 824 | endif() |
| 825 | |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 826 | # Install exports for the install-tree. |
| 827 | install(EXPORT LibwebsocketsTargets |
| 828 | DESTINATION "${LWS_INSTALL_CMAKE_DIR}" COMPONENT dev) |
| 829 | |
Andy Green | 2aab3f9 | 2013-03-10 08:11:48 +0800 | [diff] [blame] | 830 | # build subdir is not part of sources |
| 831 | set(CPACK_SOURCE_IGNORE_FILES $(CPACK_SOURCE_IGNORE_FILES) ".git" "build" "tgz" "tar.gz") |
| 832 | |
Joakim Soderberg | b37827b | 2013-02-22 09:28:08 +0800 | [diff] [blame] | 833 | # Most people are more used to "make dist" compared to "make package_source" |
Markus Elfring | 299244f | 2013-10-26 20:03:43 +0800 | [diff] [blame] | 834 | add_custom_target(dist COMMAND "${CMAKE_MAKE_PROGRAM}" package_source) |
Joakim Soderberg | b37827b | 2013-02-22 09:28:08 +0800 | [diff] [blame] | 835 | |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 836 | include(UseRPMTools) |
| 837 | if (RPMTools_FOUND) |
Tomas Cejka | efda177 | 2013-04-11 08:13:13 +0800 | [diff] [blame] | 838 | RPMTools_ADD_RPM_TARGETS(libwebsockets libwebsockets.spec) |
Joakim Soderberg | 6744555 | 2014-02-15 13:48:56 +0800 | [diff] [blame] | 839 | endif() |
| 840 | |
| 841 | message("---------------------------------------------------------------------") |
| 842 | message(" Settings: (For more help do cmake -LH <srcpath>") |
| 843 | message("---------------------------------------------------------------------") |
| 844 | message(" LWS_WITH_SSL = ${LWS_WITH_SSL} (SSL Support)") |
| 845 | message(" LWS_USE_CYASSL = ${LWS_USE_CYASSL} (CyaSSL replacement for OpenSSL)") |
| 846 | if (LWS_USE_CYASSL) |
| 847 | message(" LWS_CYASSL_LIB = ${LWS_CYASSL_LIB}") |
| 848 | message(" LWS_CYASSL_INCLUDE_DIRS = ${LWS_CYASSL_INCLUDE_DIRS}") |
| 849 | endif() |
| 850 | message(" LWS_WITHOUT_BUILTIN_GETIFADDRS = ${LWS_WITHOUT_BUILTIN_GETIFADDRS}") |
| 851 | message(" LWS_WITHOUT_CLIENT = ${LWS_WITHOUT_CLIENT}") |
| 852 | message(" LWS_WITHOUT_SERVER = ${LWS_WITHOUT_SERVER}") |
| 853 | message(" LWS_LINK_TESTAPPS_DYNAMIC = ${LWS_LINK_TESTAPPS_DYNAMIC}") |
| 854 | message(" LWS_WITHOUT_TESTAPPS = ${LWS_WITHOUT_TESTAPPS}") |
| 855 | message(" LWS_WITHOUT_TEST_SERVER = ${LWS_WITHOUT_TEST_SERVER}") |
| 856 | message(" LWS_WITHOUT_TEST_SERVER_EXTPOLL = ${LWS_WITHOUT_TEST_SERVER_EXTPOLL}") |
| 857 | message(" LWS_WITHOUT_TEST_PING = ${LWS_WITHOUT_TEST_PING}") |
| 858 | message(" LWS_WITHOUT_TEST_CLIENT = ${LWS_WITHOUT_TEST_CLIENT}") |
| 859 | message(" LWS_WITHOUT_TEST_FRAGGLE = ${LWS_WITHOUT_TEST_FRAGGLE}") |
| 860 | message(" LWS_WITHOUT_DEBUG = ${LWS_WITHOUT_DEBUG}") |
| 861 | message(" LWS_WITHOUT_EXTENSIONS = ${LWS_WITHOUT_EXTENSIONS}") |
| 862 | message(" LWS_WITH_LATENCY = ${LWS_WITH_LATENCY}") |
| 863 | message(" LWS_WITHOUT_DAEMONIZE = ${LWS_WITHOUT_DAEMONIZE}") |
| 864 | message("---------------------------------------------------------------------") |
| 865 | |
| 866 | # These will be available to parent projects including libwebsockets using add_subdirectory() |
| 867 | set(LIBWEBSOCKETS_LIBRARIES websocket websockets_shared CACHE STRING "Libwebsocket libraries") |
| 868 | set(LIBWEBSOCKETS_LIBRARIES_STATIC websocket CACHE STRING "Libwebsocket static library") |
| 869 | set(LIBWEBSOCKETS_LIBRARIES_SHARED websockets_shared CACHE STRING "Libwebsocket shared library") |
Tomas Cejka | efda177 | 2013-04-11 08:13:13 +0800 | [diff] [blame] | 870 | |
Joakim Soderberg | b37827b | 2013-02-22 09:28:08 +0800 | [diff] [blame] | 871 | # This must always be last! |
| 872 | include(CPack) |