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