|
|
@ -6,6 +6,11 @@ project ( "i2pd" ) |
|
|
|
# for debugging |
|
|
|
# for debugging |
|
|
|
#set(CMAKE_VERBOSE_MAKEFILE on) |
|
|
|
#set(CMAKE_VERBOSE_MAKEFILE on) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Win32 build with cmake is not supported |
|
|
|
|
|
|
|
if(WIN32 OR MSVC OR MSYS OR MINGW) |
|
|
|
|
|
|
|
message(SEND_ERROR "cmake build for windows is not supported. Please use MSYS2 with makefiles in project root.") |
|
|
|
|
|
|
|
endif() |
|
|
|
|
|
|
|
|
|
|
|
# configurale options |
|
|
|
# configurale options |
|
|
|
option(WITH_AESNI "Use AES-NI instructions set" OFF) |
|
|
|
option(WITH_AESNI "Use AES-NI instructions set" OFF) |
|
|
|
option(WITH_AVX "Use AVX instructions" OFF) |
|
|
|
option(WITH_AVX "Use AVX instructions" OFF) |
|
|
@ -15,7 +20,6 @@ option(WITH_BINARY "Build binary" ON) |
|
|
|
option(WITH_STATIC "Static build" OFF) |
|
|
|
option(WITH_STATIC "Static build" OFF) |
|
|
|
option(WITH_UPNP "Include support for UPnP client" OFF) |
|
|
|
option(WITH_UPNP "Include support for UPnP client" OFF) |
|
|
|
option(WITH_PCH "Use precompiled header" OFF) |
|
|
|
option(WITH_PCH "Use precompiled header" OFF) |
|
|
|
option(WITH_GUI "Include GUI (currently MS Windows only)" ON) |
|
|
|
|
|
|
|
option(WITH_MESHNET "Build for cjdns test network" OFF) |
|
|
|
option(WITH_MESHNET "Build for cjdns test network" OFF) |
|
|
|
option(WITH_ADDRSANITIZER "Build with address sanitizer unix only" OFF) |
|
|
|
option(WITH_ADDRSANITIZER "Build with address sanitizer unix only" OFF) |
|
|
|
option(WITH_THREADSANITIZER "Build with thread sanitizer unix only" OFF) |
|
|
|
option(WITH_THREADSANITIZER "Build with thread sanitizer unix only" OFF) |
|
|
@ -30,63 +34,61 @@ target_architecture(ARCHITECTURE) |
|
|
|
|
|
|
|
|
|
|
|
set(LIBI2PD_SRC_DIR ../libi2pd) |
|
|
|
set(LIBI2PD_SRC_DIR ../libi2pd) |
|
|
|
set(LIBI2PD_CLIENT_SRC_DIR ../libi2pd_client) |
|
|
|
set(LIBI2PD_CLIENT_SRC_DIR ../libi2pd_client) |
|
|
|
|
|
|
|
set(DAEMON_SRC_DIR ../daemon) |
|
|
|
|
|
|
|
|
|
|
|
include_directories(${LIBI2PD_SRC_DIR}) |
|
|
|
include_directories(${LIBI2PD_SRC_DIR}) |
|
|
|
include_directories(${LIBI2PD_CLIENT_SRC_DIR}) |
|
|
|
include_directories(${LIBI2PD_CLIENT_SRC_DIR}) |
|
|
|
|
|
|
|
include_directories(${DAEMON_SRC_DIR}) |
|
|
|
|
|
|
|
|
|
|
|
set(LIBI2PD_SRC |
|
|
|
set(LIBI2PD_SRC |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/api.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/Base.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/Blinding.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/BloomFilter.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/BloomFilter.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/ChaCha20.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/Config.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/Config.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/CPU.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/CPU.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/Crypto.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/Crypto.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/CryptoKey.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/CryptoKey.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/Datagram.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/Destination.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/ECIESX25519AEADRatchetSession.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/Ed25519.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/Elligator.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/Family.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/FS.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/Garlic.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/Garlic.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/Gost.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/Gzip.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/Gzip.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/HTTP.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/HTTP.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/I2NPProtocol.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/I2NPProtocol.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/Identity.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/Identity.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/LeaseSet.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/LeaseSet.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/FS.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/Log.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/Log.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/NTCPSession.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/NetDbRequests.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/NetDb.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/NetDb.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/NetDbRequests.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/NTCP2.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/NTCPSession.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/Poly1305.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/Profiling.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/Profiling.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/Reseed.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/Reseed.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/RouterContext.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/RouterContext.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/RouterInfo.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/RouterInfo.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/Signature.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/SSU.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/SSU.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/SSUData.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/SSUData.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/SSUSession.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/SSUSession.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/Streaming.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/Streaming.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/Destination.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/Timestamp.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/TransitTunnel.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/TransitTunnel.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/Tunnel.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/TunnelGateway.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/Transports.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/Transports.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/Tunnel.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/TunnelEndpoint.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/TunnelEndpoint.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/TunnelGateway.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/TunnelPool.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/TunnelPool.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/Base.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/util.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/util.cpp" |
|
|
|
"${LIBI2PD_SRC_DIR}/Datagram.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/Family.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/Signature.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/Timestamp.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/api.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/Gost.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/ChaCha20.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/Poly1305.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/Ed25519.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/NTCP2.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/Blinding.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/Elligator.cpp" |
|
|
|
|
|
|
|
"${LIBI2PD_SRC_DIR}/ECIESX25519AEADRatchetSession.cpp" |
|
|
|
|
|
|
|
) |
|
|
|
) |
|
|
|
|
|
|
|
|
|
|
|
if (WIN32 OR MSYS) |
|
|
|
|
|
|
|
list (APPEND LIBI2PD_SRC "${CMAKE_SOURCE_DIR}/I2PEndian.cpp") |
|
|
|
|
|
|
|
endif () |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
add_library(libi2pd ${LIBI2PD_SRC}) |
|
|
|
add_library(libi2pd ${LIBI2PD_SRC}) |
|
|
|
set_target_properties(libi2pd PROPERTIES PREFIX "") |
|
|
|
set_target_properties(libi2pd PROPERTIES PREFIX "") |
|
|
|
|
|
|
|
|
|
|
@ -125,8 +127,6 @@ if (WITH_LIBRARY) |
|
|
|
COMPONENT Libraries) |
|
|
|
COMPONENT Libraries) |
|
|
|
endif() |
|
|
|
endif() |
|
|
|
|
|
|
|
|
|
|
|
set(DAEMON_SRC_DIR ../daemon) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
set(DAEMON_SRC |
|
|
|
set(DAEMON_SRC |
|
|
|
"${DAEMON_SRC_DIR}/Daemon.cpp" |
|
|
|
"${DAEMON_SRC_DIR}/Daemon.cpp" |
|
|
|
"${DAEMON_SRC_DIR}/HTTPServer.cpp" |
|
|
|
"${DAEMON_SRC_DIR}/HTTPServer.cpp" |
|
|
@ -141,31 +141,14 @@ endif () |
|
|
|
|
|
|
|
|
|
|
|
if(WITH_UPNP) |
|
|
|
if(WITH_UPNP) |
|
|
|
add_definitions(-DUSE_UPNP) |
|
|
|
add_definitions(-DUSE_UPNP) |
|
|
|
if (NOT MSVC AND NOT MSYS) |
|
|
|
|
|
|
|
set(DL_LIB ${CMAKE_DL_LIBS}) |
|
|
|
|
|
|
|
endif () |
|
|
|
|
|
|
|
endif() |
|
|
|
endif() |
|
|
|
|
|
|
|
|
|
|
|
# compiler flags customization (by vendor) |
|
|
|
|
|
|
|
if (MSVC) |
|
|
|
|
|
|
|
add_definitions( -DWIN32_LEAN_AND_MEAN -DNOMINMAX ) |
|
|
|
|
|
|
|
# TODO Check & report to Boost dev, there should be no need for these two |
|
|
|
|
|
|
|
add_definitions( -DBOOST_THREAD_NO_LIB -DBOOST_CHRONO_NO_LIB ) |
|
|
|
|
|
|
|
set( CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} /GL" ) |
|
|
|
|
|
|
|
set( CMAKE_EXE_LINKER_FLAGS_RELEASE "${CMAKE_EXE_LINKER_FLAGS_RELEASE} /INCREMENTAL:NO /LTCG" ) |
|
|
|
|
|
|
|
set( CMAKE_CXX_FLAGS_RELWITHDEBINFO "${CMAKE_CXX_FLAGS_RELEASE} /GL" ) |
|
|
|
|
|
|
|
set( CMAKE_EXE_LINKER_FLAGS_RELWITHDEBINFO "${CMAKE_EXE_LINKER_FLAGS_RELWITHDEBINFO} /INCREMENTAL:NO /LTCG" ) |
|
|
|
|
|
|
|
else() |
|
|
|
|
|
|
|
if (MSYS OR MINGW) |
|
|
|
|
|
|
|
add_definitions( -DWIN32_LEAN_AND_MEAN ) |
|
|
|
|
|
|
|
endif () |
|
|
|
|
|
|
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -Wextra -Winvalid-pch -Wno-unused-parameter") |
|
|
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -Wextra -Winvalid-pch -Wno-unused-parameter") |
|
|
|
set(CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} -pedantic") |
|
|
|
set(CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} -pedantic") |
|
|
|
# TODO: The following is incompatible with static build and enabled hardening for OpenWRT. |
|
|
|
# TODO: The following is incompatible with static build and enabled hardening for OpenWRT. |
|
|
|
# Multiple definitions of __stack_chk_fail(libssp & libc) |
|
|
|
# Multiple definitions of __stack_chk_fail(libssp & libc) |
|
|
|
set(CMAKE_CXX_FLAGS_MINSIZEREL "${CMAKE_CXX_FLAGS_MINSIZEREL} -flto -s -ffunction-sections -fdata-sections") |
|
|
|
set(CMAKE_CXX_FLAGS_MINSIZEREL "${CMAKE_CXX_FLAGS_MINSIZEREL} -flto -s -ffunction-sections -fdata-sections") |
|
|
|
set(CMAKE_EXE_LINKER_FLAGS_MINSIZEREL "-Wl,--gc-sections") # -flto is added from above |
|
|
|
set(CMAKE_EXE_LINKER_FLAGS_MINSIZEREL "-Wl,--gc-sections") # -flto is added from above |
|
|
|
endif () |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# check for c++17 & c++11 support |
|
|
|
# check for c++17 & c++11 support |
|
|
|
include(CheckCXXCompilerFlag) |
|
|
|
include(CheckCXXCompilerFlag) |
|
|
@ -192,16 +175,11 @@ elseif (CMAKE_CXX_COMPILER_ID STREQUAL "Clang") |
|
|
|
set(CMAKE_REQUIRED_FLAGS "${CMAKE_REQUIRED_FLAGS} -stdlib=libstdc++") # required for <atomic> |
|
|
|
set(CMAKE_REQUIRED_FLAGS "${CMAKE_REQUIRED_FLAGS} -stdlib=libstdc++") # required for <atomic> |
|
|
|
list(APPEND CMAKE_REQUIRED_LIBRARIES "stdc++") # required to link with -stdlib=libstdc++ |
|
|
|
list(APPEND CMAKE_REQUIRED_LIBRARIES "stdc++") # required to link with -stdlib=libstdc++ |
|
|
|
endif() |
|
|
|
endif() |
|
|
|
if (NOT (MSVC OR MSYS OR APPLE)) |
|
|
|
if(NOT APPLE) |
|
|
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-const-variable -Wno-overloaded-virtual -Wno-c99-extensions") |
|
|
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-const-variable -Wno-overloaded-virtual -Wno-c99-extensions") |
|
|
|
endif() |
|
|
|
endif() |
|
|
|
endif() |
|
|
|
endif() |
|
|
|
|
|
|
|
|
|
|
|
if (WITH_HARDENING AND MSVC) |
|
|
|
|
|
|
|
# Most security options like dynamic base, buffer & stack checks are ON by default |
|
|
|
|
|
|
|
set (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /guard:cf" ) |
|
|
|
|
|
|
|
endif () |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# compiler flags customization(by system) |
|
|
|
# compiler flags customization(by system) |
|
|
|
if(UNIX) |
|
|
|
if(UNIX) |
|
|
|
list(APPEND DAEMON_SRC "${DAEMON_SRC_DIR}/UnixDaemon.cpp") |
|
|
|
list(APPEND DAEMON_SRC "${DAEMON_SRC_DIR}/UnixDaemon.cpp") |
|
|
@ -209,19 +187,11 @@ if (UNIX) |
|
|
|
# "'sleep_for' is not a member of 'std::this_thread'" in gcc 4.7/4.8 |
|
|
|
# "'sleep_for' is not a member of 'std::this_thread'" in gcc 4.7/4.8 |
|
|
|
add_definitions("-D_GLIBCXX_USE_NANOSLEEP=1") |
|
|
|
add_definitions("-D_GLIBCXX_USE_NANOSLEEP=1") |
|
|
|
endif() |
|
|
|
endif() |
|
|
|
elseif (WIN32 OR MSYS) |
|
|
|
|
|
|
|
list (APPEND DAEMON_SRC "${CMAKE_SOURCE_DIR}/Win32/DaemonWin32.cpp") |
|
|
|
|
|
|
|
if (WITH_GUI) |
|
|
|
|
|
|
|
list (APPEND DAEMON_SRC "${CMAKE_SOURCE_DIR}/Win32/Win32App.cpp") |
|
|
|
|
|
|
|
set_source_files_properties("${CMAKE_SOURCE_DIR}/Win32/DaemonWin32.cpp" |
|
|
|
|
|
|
|
PROPERTIES COMPILE_DEFINITIONS WIN32_APP) |
|
|
|
|
|
|
|
endif () |
|
|
|
|
|
|
|
list (APPEND DAEMON_SRC "${CMAKE_SOURCE_DIR}/Win32/Win32Service.cpp") |
|
|
|
|
|
|
|
list (APPEND DAEMON_SRC "${CMAKE_SOURCE_DIR}/Win32/Resource.rc") |
|
|
|
|
|
|
|
endif() |
|
|
|
endif() |
|
|
|
|
|
|
|
|
|
|
|
if(WITH_AESNI) |
|
|
|
if(WITH_AESNI) |
|
|
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -maes") |
|
|
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -maes") |
|
|
|
|
|
|
|
add_definitions(-DAESNI) |
|
|
|
endif() |
|
|
|
endif() |
|
|
|
|
|
|
|
|
|
|
|
if(WITH_AVX) |
|
|
|
if(WITH_AVX) |
|
|
@ -229,22 +199,16 @@ if (WITH_AVX) |
|
|
|
endif() |
|
|
|
endif() |
|
|
|
|
|
|
|
|
|
|
|
if(WITH_ADDRSANITIZER) |
|
|
|
if(WITH_ADDRSANITIZER) |
|
|
|
if (NOT MSVC) |
|
|
|
|
|
|
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fsanitize=address -fno-omit-frame-pointer") |
|
|
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fsanitize=address -fno-omit-frame-pointer") |
|
|
|
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -fsanitize=address") |
|
|
|
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -fsanitize=address") |
|
|
|
else () |
|
|
|
|
|
|
|
message( SEND_ERROR "MSVC does not support address sanitizer option") |
|
|
|
|
|
|
|
endif() |
|
|
|
|
|
|
|
endif() |
|
|
|
endif() |
|
|
|
|
|
|
|
|
|
|
|
if(WITH_THREADSANITIZER) |
|
|
|
if(WITH_THREADSANITIZER) |
|
|
|
if(WITH_ADDRSANITIZER) |
|
|
|
if(WITH_ADDRSANITIZER) |
|
|
|
message(FATAL_ERROR "thread sanitizer option cannot be combined with address sanitizer") |
|
|
|
message(FATAL_ERROR "thread sanitizer option cannot be combined with address sanitizer") |
|
|
|
elseif (NOT MSVC) |
|
|
|
else() |
|
|
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fsanitize=thread") |
|
|
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fsanitize=thread") |
|
|
|
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -fsanitize=thread") |
|
|
|
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -fsanitize=thread") |
|
|
|
else () |
|
|
|
|
|
|
|
message( SEND_ERROR "MSVC does not support address sanitizer option") |
|
|
|
|
|
|
|
endif() |
|
|
|
endif() |
|
|
|
endif() |
|
|
|
endif() |
|
|
|
|
|
|
|
|
|
|
@ -268,18 +232,6 @@ endif() |
|
|
|
if(WITH_STATIC) |
|
|
|
if(WITH_STATIC) |
|
|
|
set(Boost_USE_STATIC_LIBS ON) |
|
|
|
set(Boost_USE_STATIC_LIBS ON) |
|
|
|
set(Boost_USE_STATIC_RUNTIME ON) |
|
|
|
set(Boost_USE_STATIC_RUNTIME ON) |
|
|
|
if (WIN32 AND NOT MSYS AND NOT MINGW) |
|
|
|
|
|
|
|
# http://www.cmake.org/Wiki/CMake_FAQ#Dynamic_Replace |
|
|
|
|
|
|
|
foreach(flag_var |
|
|
|
|
|
|
|
CMAKE_CXX_FLAGS CMAKE_CXX_FLAGS_DEBUG CMAKE_CXX_FLAGS_RELEASE |
|
|
|
|
|
|
|
CMAKE_CXX_FLAGS_MINSIZEREL CMAKE_CXX_FLAGS_RELWITHDEBINFO) |
|
|
|
|
|
|
|
if(${flag_var} MATCHES "/MD") |
|
|
|
|
|
|
|
string(REGEX REPLACE "/MD" "/MT" ${flag_var} "${${flag_var}}") |
|
|
|
|
|
|
|
endif(${flag_var} MATCHES "/MD") |
|
|
|
|
|
|
|
endforeach(flag_var) |
|
|
|
|
|
|
|
else () |
|
|
|
|
|
|
|
set(CMAKE_FIND_LIBRARY_SUFFIXES .a) |
|
|
|
|
|
|
|
endif () |
|
|
|
|
|
|
|
set(BUILD_SHARED_LIBS OFF) |
|
|
|
set(BUILD_SHARED_LIBS OFF) |
|
|
|
if(${CMAKE_CXX_COMPILER} MATCHES ".*-openwrt-.*") |
|
|
|
if(${CMAKE_CXX_COMPILER} MATCHES ".*-openwrt-.*") |
|
|
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -pthread") |
|
|
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -pthread") |
|
|
@ -287,29 +239,16 @@ if (WITH_STATIC) |
|
|
|
set(CMAKE_THREAD_LIBS_INIT "gcc_eh -Wl,-u,pthread_create,-u,pthread_once,-u,pthread_mutex_lock,-u,pthread_mutex_unlock,-u,pthread_join,-u,pthread_equal,-u,pthread_detach,-u,pthread_cond_wait,-u,pthread_cond_signal,-u,pthread_cond_destroy,-u,pthread_cond_broadcast,-u,pthread_cancel") |
|
|
|
set(CMAKE_THREAD_LIBS_INIT "gcc_eh -Wl,-u,pthread_create,-u,pthread_once,-u,pthread_mutex_lock,-u,pthread_mutex_unlock,-u,pthread_join,-u,pthread_equal,-u,pthread_detach,-u,pthread_cond_wait,-u,pthread_cond_signal,-u,pthread_cond_destroy,-u,pthread_cond_broadcast,-u,pthread_cancel") |
|
|
|
endif() |
|
|
|
endif() |
|
|
|
else() |
|
|
|
else() |
|
|
|
if (NOT WIN32 AND NOT MSYS) |
|
|
|
|
|
|
|
# TODO: Consider separate compilation for LIBI2PD_SRC for library. |
|
|
|
# TODO: Consider separate compilation for LIBI2PD_SRC for library. |
|
|
|
# No need in -fPIC overhead for binary if not interested in library |
|
|
|
# No need in -fPIC overhead for binary if not interested in library |
|
|
|
# HINT: revert c266cff CMakeLists.txt: compilation speed up |
|
|
|
# HINT: revert c266cff CMakeLists.txt: compilation speed up |
|
|
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fPIC") |
|
|
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fPIC") |
|
|
|
endif () |
|
|
|
|
|
|
|
add_definitions(-DBOOST_SYSTEM_DYN_LINK -DBOOST_FILESYSTEM_DYN_LINK -DBOOST_PROGRAM_OPTIONS_DYN_LINK -DBOOST_DATE_TIME_DYN_LINK -DBOOST_REGEX_DYN_LINK) |
|
|
|
add_definitions(-DBOOST_SYSTEM_DYN_LINK -DBOOST_FILESYSTEM_DYN_LINK -DBOOST_PROGRAM_OPTIONS_DYN_LINK -DBOOST_DATE_TIME_DYN_LINK -DBOOST_REGEX_DYN_LINK) |
|
|
|
endif() |
|
|
|
endif() |
|
|
|
|
|
|
|
|
|
|
|
if(WITH_PCH) |
|
|
|
if(WITH_PCH) |
|
|
|
include_directories(BEFORE ${CMAKE_BINARY_DIR}) |
|
|
|
include_directories(BEFORE ${CMAKE_BINARY_DIR}) |
|
|
|
add_library(stdafx STATIC "${LIBI2PD_SRC_DIR}/stdafx.cpp") |
|
|
|
add_library(stdafx STATIC "${LIBI2PD_SRC_DIR}/stdafx.cpp") |
|
|
|
if(MSVC) |
|
|
|
|
|
|
|
target_compile_options(stdafx PRIVATE /Ycstdafx.h /Zm155) |
|
|
|
|
|
|
|
add_custom_command(TARGET stdafx POST_BUILD |
|
|
|
|
|
|
|
COMMAND xcopy /y stdafx.dir\\$<CONFIG>\\*.pdb libi2pd.dir\\$<CONFIG>\\ |
|
|
|
|
|
|
|
COMMAND xcopy /y stdafx.dir\\$<CONFIG>\\*.pdb i2pdclient.dir\\$<CONFIG>\\ |
|
|
|
|
|
|
|
COMMAND xcopy /y stdafx.dir\\$<CONFIG>\\*.pdb i2pd.dir\\$<CONFIG>\\ |
|
|
|
|
|
|
|
WORKING_DIRECTORY ${CMAKE_BINARY_DIR} |
|
|
|
|
|
|
|
) |
|
|
|
|
|
|
|
target_compile_options(libi2pd PRIVATE /FIstdafx.h /Yustdafx.h /Zm155 "/Fp${CMAKE_BINARY_DIR}/stdafx.dir/$<CONFIG>/stdafx.pch") |
|
|
|
|
|
|
|
target_compile_options(libi2pdclient PRIVATE /FIstdafx.h /Yustdafx.h /Zm155 "/Fp${CMAKE_BINARY_DIR}/stdafx.dir/$<CONFIG>/stdafx.pch") |
|
|
|
|
|
|
|
else() |
|
|
|
|
|
|
|
string(TOUPPER ${CMAKE_BUILD_TYPE} BTU) |
|
|
|
string(TOUPPER ${CMAKE_BUILD_TYPE} BTU) |
|
|
|
get_directory_property(DEFS DEFINITIONS) |
|
|
|
get_directory_property(DEFS DEFINITIONS) |
|
|
|
string(REPLACE " " ";" FLAGS "${CMAKE_CXX_FLAGS} ${CMAKE_CXX_FLAGS_${BTU}} ${DEFS}") |
|
|
|
string(REPLACE " " ";" FLAGS "${CMAKE_CXX_FLAGS} ${CMAKE_CXX_FLAGS_${BTU}} ${DEFS}") |
|
|
@ -318,7 +257,6 @@ if (WITH_PCH) |
|
|
|
) |
|
|
|
) |
|
|
|
target_compile_options(libi2pd PRIVATE -include libi2pd/stdafx.h) |
|
|
|
target_compile_options(libi2pd PRIVATE -include libi2pd/stdafx.h) |
|
|
|
target_compile_options(libi2pdclient PRIVATE -include libi2pd/stdafx.h) |
|
|
|
target_compile_options(libi2pdclient PRIVATE -include libi2pd/stdafx.h) |
|
|
|
endif() |
|
|
|
|
|
|
|
target_link_libraries(libi2pd stdafx) |
|
|
|
target_link_libraries(libi2pd stdafx) |
|
|
|
endif() |
|
|
|
endif() |
|
|
|
|
|
|
|
|
|
|
@ -336,58 +274,30 @@ endif() |
|
|
|
|
|
|
|
|
|
|
|
if(WITH_UPNP) |
|
|
|
if(WITH_UPNP) |
|
|
|
find_package(MiniUPnPc REQUIRED) |
|
|
|
find_package(MiniUPnPc REQUIRED) |
|
|
|
|
|
|
|
if(NOT MINIUPNPC_FOUND) |
|
|
|
|
|
|
|
message(SEND_ERROR "Could not find MiniUPnPc. Please download and install it first!") |
|
|
|
|
|
|
|
else() |
|
|
|
include_directories(SYSTEM ${MINIUPNPC_INCLUDE_DIR}) |
|
|
|
include_directories(SYSTEM ${MINIUPNPC_INCLUDE_DIR}) |
|
|
|
endif() |
|
|
|
endif() |
|
|
|
|
|
|
|
endif() |
|
|
|
|
|
|
|
|
|
|
|
find_package(ZLIB) |
|
|
|
find_package(ZLIB) |
|
|
|
if (NOT ZLIB_FOUND ) |
|
|
|
if(ZLIB_FOUND) |
|
|
|
# We are probably on Windows |
|
|
|
|
|
|
|
find_program( PATCH patch C:/Program Files/Git/usr/bin C:/msys64/usr/bin C:/msys32/usr/bin C:/Strawberry/c/bin ) |
|
|
|
|
|
|
|
include( ExternalProject ) |
|
|
|
|
|
|
|
if( CMAKE_SIZEOF_VOID_P EQUAL 8 ) |
|
|
|
|
|
|
|
set( ZLIB_EXTRA -DAMD64=ON ) |
|
|
|
|
|
|
|
else() |
|
|
|
|
|
|
|
set( ZLIB_EXTRA -DASM686=ON "-DCMAKE_ASM_MASM_FLAGS=/W0 /safeseh" ) |
|
|
|
|
|
|
|
endif() |
|
|
|
|
|
|
|
ExternalProject_Add(zlib-project |
|
|
|
|
|
|
|
URL https://zlib.net/zlib-1.2.11.tar.gz |
|
|
|
|
|
|
|
URL_HASH SHA256=c3e5e9fdd5004dcb542feda5ee4f0ff0744628baf8ed2dd5d66f8ca1197cb1a1 |
|
|
|
|
|
|
|
PREFIX ${CMAKE_CURRENT_BINARY_DIR}/zlib |
|
|
|
|
|
|
|
PATCH_COMMAND "${PATCH}" -p0 < ${CMAKE_CURRENT_SOURCE_DIR}/cmake-zlib-static.patch |
|
|
|
|
|
|
|
&& "${PATCH}" -p0 < ${CMAKE_CURRENT_SOURCE_DIR}/cmake-zlib-amd64.patch |
|
|
|
|
|
|
|
CMAKE_ARGS -DCMAKE_INSTALL_PREFIX:PATH=<INSTALL_DIR> |
|
|
|
|
|
|
|
-DWITH_STATIC=${WITH_STATIC} ${ZLIB_EXTRA} |
|
|
|
|
|
|
|
) |
|
|
|
|
|
|
|
if (WITH_PCH) |
|
|
|
|
|
|
|
add_dependencies( stdafx zlib-project ) |
|
|
|
|
|
|
|
else () |
|
|
|
|
|
|
|
add_dependencies( libi2pd zlib-project ) |
|
|
|
|
|
|
|
endif () |
|
|
|
|
|
|
|
# ExternalProject_Get_Property(zlib-project install_dir) |
|
|
|
|
|
|
|
set ( ZLIB_INCLUDE_DIR "${CMAKE_CURRENT_BINARY_DIR}/zlib/include" CACHE FILEPATH "zlib include dir" FORCE) |
|
|
|
|
|
|
|
if (NOT WITH_STATIC) |
|
|
|
|
|
|
|
set ( ZLIB_LIBRARY debug zlibd optimized zlib CACHE STRING "zlib libraries" FORCE) |
|
|
|
|
|
|
|
endif () |
|
|
|
|
|
|
|
link_directories(${CMAKE_CURRENT_BINARY_DIR}/zlib/lib) |
|
|
|
|
|
|
|
else() |
|
|
|
|
|
|
|
link_directories(${ZLIB_ROOT}/lib) |
|
|
|
link_directories(${ZLIB_ROOT}/lib) |
|
|
|
endif() |
|
|
|
endif() |
|
|
|
if (WITH_STATIC AND (MSVC OR MSYS)) |
|
|
|
|
|
|
|
set ( ZLIB_LIBRARY debug zlibstaticd optimized zlibstatic CACHE STRING "zlib libraries" FORCE) |
|
|
|
|
|
|
|
endif () |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# load includes |
|
|
|
# load includes |
|
|
|
include_directories(SYSTEM ${Boost_INCLUDE_DIRS} ${OPENSSL_INCLUDE_DIR} ${ZLIB_INCLUDE_DIR}) |
|
|
|
include_directories(SYSTEM ${Boost_INCLUDE_DIRS} ${OPENSSL_INCLUDE_DIR} ${ZLIB_INCLUDE_DIR}) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# warn if for meshnet |
|
|
|
# warn if for meshnet |
|
|
|
if(WITH_MESHNET) |
|
|
|
if(WITH_MESHNET) |
|
|
|
message(STATUS "Building for testnet") |
|
|
|
message(STATUS "Building for testnet") |
|
|
|
message(WARNING "This build will NOT work on mainline i2p") |
|
|
|
message(WARNING "This build will NOT work on mainline i2p") |
|
|
|
endif() |
|
|
|
endif() |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(NOT MSYS) |
|
|
|
include(CheckAtomic) |
|
|
|
include(CheckAtomic) |
|
|
|
|
|
|
|
endif() |
|
|
|
|
|
|
|
|
|
|
|
# show summary |
|
|
|
# show summary |
|
|
|
message(STATUS "---------------------------------------") |
|
|
|
message(STATUS "---------------------------------------") |
|
|
@ -416,29 +326,21 @@ include(GNUInstallDirs) |
|
|
|
|
|
|
|
|
|
|
|
if(WITH_BINARY) |
|
|
|
if(WITH_BINARY) |
|
|
|
add_executable("${PROJECT_NAME}" ${DAEMON_SRC}) |
|
|
|
add_executable("${PROJECT_NAME}" ${DAEMON_SRC}) |
|
|
|
if (WIN32 AND WITH_GUI) |
|
|
|
|
|
|
|
set_target_properties("${PROJECT_NAME}" PROPERTIES WIN32_EXECUTABLE TRUE ) |
|
|
|
|
|
|
|
endif() |
|
|
|
|
|
|
|
if(NOT MSVC) |
|
|
|
|
|
|
|
if(WITH_STATIC) |
|
|
|
if(WITH_STATIC) |
|
|
|
set_target_properties("${PROJECT_NAME}" PROPERTIES LINK_FLAGS "-static") |
|
|
|
set_target_properties("${PROJECT_NAME}" PROPERTIES LINK_FLAGS "-static") |
|
|
|
endif() |
|
|
|
endif() |
|
|
|
endif() |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(WITH_PCH) |
|
|
|
if(WITH_PCH) |
|
|
|
if (MSVC) |
|
|
|
|
|
|
|
target_compile_options("${PROJECT_NAME}" PRIVATE /FIstdafx.h /Yustdafx.h /Zm155 "/Fp${CMAKE_BINARY_DIR}/stdafx.dir/$<CONFIG>/stdafx.pch") |
|
|
|
|
|
|
|
else() |
|
|
|
|
|
|
|
target_compile_options("${PROJECT_NAME}" PRIVATE -include libi2pd/stdafx.h) |
|
|
|
target_compile_options("${PROJECT_NAME}" PRIVATE -include libi2pd/stdafx.h) |
|
|
|
endif() |
|
|
|
endif() |
|
|
|
endif() |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (WITH_HARDENING AND CMAKE_CXX_COMPILER_ID STREQUAL "GNU" AND NOT MSYS AND NOT MINGW) |
|
|
|
if(WITH_HARDENING AND CMAKE_CXX_COMPILER_ID STREQUAL "GNU") |
|
|
|
set_target_properties("${PROJECT_NAME}" PROPERTIES LINK_FLAGS "-z relro -z now") |
|
|
|
set_target_properties("${PROJECT_NAME}" PROPERTIES LINK_FLAGS "-z relro -z now") |
|
|
|
endif() |
|
|
|
endif() |
|
|
|
|
|
|
|
|
|
|
|
if(WITH_UPNP) |
|
|
|
if(WITH_UPNP) |
|
|
|
target_link_libraries("${PROJECT_NAME}" "${MINIUPNPC_LIBRARY}") |
|
|
|
set(UPNP_LIB ${MINIUPNPC_LIBRARY}) |
|
|
|
endif() |
|
|
|
endif() |
|
|
|
|
|
|
|
|
|
|
|
# FindBoost pulls pthread for thread which is broken for static linking at least on Ubuntu 15.04 |
|
|
|
# FindBoost pulls pthread for thread which is broken for static linking at least on Ubuntu 15.04 |
|
|
@ -447,128 +349,15 @@ if (WITH_BINARY) |
|
|
|
list(REMOVE_AT Boost_LIBRARIES -1) |
|
|
|
list(REMOVE_AT Boost_LIBRARIES -1) |
|
|
|
endif() |
|
|
|
endif() |
|
|
|
|
|
|
|
|
|
|
|
if (MSYS OR MINGW) |
|
|
|
|
|
|
|
set (MINGW_EXTRA -lws2_32 -lmswsock -liphlpapi ) |
|
|
|
|
|
|
|
endif () |
|
|
|
|
|
|
|
if(WITH_STATIC) |
|
|
|
if(WITH_STATIC) |
|
|
|
set(DL_LIB ${CMAKE_DL_LIBS}) |
|
|
|
set(DL_LIB ${CMAKE_DL_LIBS}) |
|
|
|
endif() |
|
|
|
endif() |
|
|
|
|
|
|
|
|
|
|
|
target_link_libraries(libi2pd ${Boost_LIBRARIES} ${ZLIB_LIBRARY}) |
|
|
|
target_link_libraries(libi2pd ${Boost_LIBRARIES} ${ZLIB_LIBRARY}) |
|
|
|
target_link_libraries( "${PROJECT_NAME}" libi2pd libi2pdclient ${DL_LIB} ${Boost_LIBRARIES} ${OPENSSL_LIBRARIES} ${ZLIB_LIBRARY} ${CMAKE_THREAD_LIBS_INIT} ${MINGW_EXTRA} ${DL_LIB} ${CMAKE_REQUIRED_LIBRARIES}) |
|
|
|
target_link_libraries("${PROJECT_NAME}" libi2pd libi2pdclient ${DL_LIB} ${Boost_LIBRARIES} ${OPENSSL_LIBRARIES} ${UPNP_LIB} ${ZLIB_LIBRARY} ${CMAKE_THREAD_LIBS_INIT} ${MINGW_EXTRA} ${DL_LIB} ${CMAKE_REQUIRED_LIBRARIES}) |
|
|
|
|
|
|
|
|
|
|
|
install(TARGETS "${PROJECT_NAME}" RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR} COMPONENT Runtime) |
|
|
|
install(TARGETS "${PROJECT_NAME}" RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR} COMPONENT Runtime) |
|
|
|
set(APPS "\${CMAKE_INSTALL_PREFIX}/bin/${PROJECT_NAME}${CMAKE_EXECUTABLE_SUFFIX}") |
|
|
|
set(APPS "\${CMAKE_INSTALL_PREFIX}/bin/${PROJECT_NAME}${CMAKE_EXECUTABLE_SUFFIX}") |
|
|
|
set(DIRS "${Boost_LIBRARY_DIR};${OPENSSL_INCLUDE_DIR}/../bin;${ZLIB_INCLUDE_DIR}/../bin;/mingw32/bin") |
|
|
|
set(DIRS "${Boost_LIBRARY_DIR};${OPENSSL_INCLUDE_DIR}/../bin;${ZLIB_INCLUDE_DIR}/../bin;/mingw32/bin") |
|
|
|
if (MSVC) |
|
|
|
|
|
|
|
install(FILES $<TARGET_PDB_FILE:${PROJECT_NAME}> DESTINATION ${CMAKE_INSTALL_BINDIR} CONFIGURATIONS DEBUG RELWITHDEBINFO COMPONENT Symbols) |
|
|
|
|
|
|
|
# TODO Somehow this picks lots of unrelevant stuff with MSYS. OS X testing needed. |
|
|
|
|
|
|
|
INSTALL(CODE " |
|
|
|
|
|
|
|
include(BundleUtilities) |
|
|
|
|
|
|
|
fixup_bundle(\"${APPS}\" \"\" \"${DIRS}\") |
|
|
|
|
|
|
|
" COMPONENT Runtime) |
|
|
|
|
|
|
|
endif () |
|
|
|
|
|
|
|
endif () |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
install(FILES ../LICENSE |
|
|
|
|
|
|
|
DESTINATION . |
|
|
|
|
|
|
|
COMPONENT Runtime |
|
|
|
|
|
|
|
) |
|
|
|
|
|
|
|
# Take a copy on Appveyor |
|
|
|
|
|
|
|
install(FILES "C:/projects/openssl-$ENV{OPENSSL}/LICENSE" |
|
|
|
|
|
|
|
DESTINATION . |
|
|
|
|
|
|
|
COMPONENT Runtime |
|
|
|
|
|
|
|
RENAME LICENSE_OPENSSL |
|
|
|
|
|
|
|
OPTIONAL # for local builds only! |
|
|
|
|
|
|
|
) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
file(GLOB_RECURSE I2PD_SOURCES "../libi2pd/*.cpp" "../libi2pd_client/*.cpp" "../daemon/*.cpp" "../build" "../Win32" "../Makefile*") |
|
|
|
|
|
|
|
install(FILES ${I2PD_SOURCES} DESTINATION src/ COMPONENT Source) |
|
|
|
|
|
|
|
# install(DIRECTORY ../ DESTINATION src/ |
|
|
|
|
|
|
|
# # OPTIONAL |
|
|
|
|
|
|
|
# COMPONENT Source FILES_MATCHING |
|
|
|
|
|
|
|
# PATTERN .git EXCLUDE |
|
|
|
|
|
|
|
# PATTERN "*.cpp" |
|
|
|
|
|
|
|
# ) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
file(GLOB I2PD_HEADERS "../libi2pd/*.h" "../libi2pd_client/*.h" "../daemon/*.h") |
|
|
|
|
|
|
|
install(FILES ${I2PD_HEADERS} DESTINATION src/ COMPONENT Headers) |
|
|
|
|
|
|
|
# install(DIRECTORY ../ DESTINATION src/ |
|
|
|
|
|
|
|
# # OPTIONAL |
|
|
|
|
|
|
|
# COMPONENT Headers FILES_MATCHING |
|
|
|
|
|
|
|
# PATTERN .git EXCLUDE |
|
|
|
|
|
|
|
# PATTERN "*.h" |
|
|
|
|
|
|
|
# ) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
set(CPACK_PACKAGE_DESCRIPTION_SUMMARY "Purple I2P, a C++ I2P daemon") |
|
|
|
|
|
|
|
set(CPACK_PACKAGE_VENDOR "Purple I2P") |
|
|
|
|
|
|
|
set(CPACK_PACKAGE_DESCRIPTION_FILE "${CMAKE_CURRENT_SOURCE_DIR}/../README.md") |
|
|
|
|
|
|
|
set(CPACK_RESOURCE_FILE_LICENSE "${CMAKE_CURRENT_SOURCE_DIR}/../LICENSE") |
|
|
|
|
|
|
|
file(READ ../libi2pd/version.h version_h) |
|
|
|
|
|
|
|
string(REGEX REPLACE ".*I2PD_VERSION_MAJOR ([0-9]+).*" "\\1" CPACK_PACKAGE_VERSION_MAJOR "${version_h}") |
|
|
|
|
|
|
|
string(REGEX REPLACE ".*I2PD_VERSION_MINOR ([0-9]+).*" "\\1" CPACK_PACKAGE_VERSION_MINOR "${version_h}") |
|
|
|
|
|
|
|
string(REGEX REPLACE ".*I2PD_VERSION_MICRO ([0-9]+).*" "\\1" CPACK_PACKAGE_VERSION_MICRO "${version_h}") |
|
|
|
|
|
|
|
string(REGEX REPLACE ".*I2PD_VERSION_PATCH ([0-9]+).*" "\\1" CPACK_PACKAGE_VERSION_PATCH "${version_h}") |
|
|
|
|
|
|
|
set(CPACK_PACKAGE_INSTALL_DIRECTORY "Purple I2P")# ${CPACK_PACKAGE_VERSION_MAJOR}.${CPACK_PACKAGE_VERSION_MINOR}") |
|
|
|
|
|
|
|
include(CPackComponent) |
|
|
|
|
|
|
|
cpack_add_component(Runtime |
|
|
|
|
|
|
|
DESCRIPTION "Main files" |
|
|
|
|
|
|
|
REQUIRED INSTALL_TYPES minimal) |
|
|
|
|
|
|
|
cpack_add_component(Symbols |
|
|
|
|
|
|
|
DISPLAY_NAME "Debug symbols" |
|
|
|
|
|
|
|
DESCRIPTION "Debug symbols for use with WinDbg or Visual Studio" |
|
|
|
|
|
|
|
INSTALL_TYPES recommended full |
|
|
|
|
|
|
|
) |
|
|
|
|
|
|
|
cpack_add_component(Libraries |
|
|
|
|
|
|
|
DESCRIPTION "Binary libraries for development" |
|
|
|
|
|
|
|
INSTALL_TYPES full dev3rd |
|
|
|
|
|
|
|
) |
|
|
|
|
|
|
|
cpack_add_component(Source |
|
|
|
|
|
|
|
DISPLAY_NAME "Source code" |
|
|
|
|
|
|
|
DESCRIPTION "I2pd source code" |
|
|
|
|
|
|
|
INSTALL_TYPES full |
|
|
|
|
|
|
|
) |
|
|
|
|
|
|
|
cpack_add_component(Headers |
|
|
|
|
|
|
|
DISPLAY_NAME "Header files" |
|
|
|
|
|
|
|
DESCRIPTION "I2pd header files for development" |
|
|
|
|
|
|
|
INSTALL_TYPES full dev3rd |
|
|
|
|
|
|
|
) |
|
|
|
|
|
|
|
install(FILES ${MINIUPNPC_INCLUDE_DIR}/miniupnpc/miniupnpc.dll |
|
|
|
|
|
|
|
DESTINATION bin |
|
|
|
|
|
|
|
COMPONENT MiniUPnPc |
|
|
|
|
|
|
|
OPTIONAL |
|
|
|
|
|
|
|
) |
|
|
|
|
|
|
|
install(FILES ${MINIUPNPC_INCLUDE_DIR}/miniupnpc/LICENSE |
|
|
|
|
|
|
|
DESTINATION . |
|
|
|
|
|
|
|
COMPONENT MiniUPnPc |
|
|
|
|
|
|
|
RENAME LICENSE_MINIUPNPC |
|
|
|
|
|
|
|
OPTIONAL |
|
|
|
|
|
|
|
) |
|
|
|
|
|
|
|
cpack_add_component(MiniUPnPc |
|
|
|
|
|
|
|
INSTALL_TYPES full recommended |
|
|
|
|
|
|
|
# DOWNLOADED |
|
|
|
|
|
|
|
# ARCHIVE_FILE miniupnpc-win32.zip |
|
|
|
|
|
|
|
) |
|
|
|
|
|
|
|
cpack_add_install_type(recommended DISPLAY_NAME Recommended) |
|
|
|
|
|
|
|
cpack_add_install_type(dev3rd DISPLAY_NAME "Third party development") |
|
|
|
|
|
|
|
cpack_add_install_type(full DISPLAY_NAME Full) |
|
|
|
|
|
|
|
cpack_add_install_type(minimal DISPLAY_NAME Minimal) |
|
|
|
|
|
|
|
if((WIN32 OR MSYS) AND NOT UNIX) |
|
|
|
|
|
|
|
# There is a bug in NSI that does not handle full unix paths properly. Make |
|
|
|
|
|
|
|
# sure there is at least one set of four (4) backlasshes. |
|
|
|
|
|
|
|
set(CPACK_NSIS_DEFINES "RequestExecutionLevel user") |
|
|
|
|
|
|
|
set(CPACK_PACKAGE_ICON "${CMAKE_CURRENT_SOURCE_DIR}/../Win32\\\\mask.bmp") |
|
|
|
|
|
|
|
set(CPACK_NSIS_INSTALLED_ICON_NAME "bin/i2pd.exe") |
|
|
|
|
|
|
|
SET(CPACK_NSIS_DISPLAY_NAME "${CPACK_PACKAGE_DESCRIPTION_SUMMARY}") |
|
|
|
|
|
|
|
set(CPACK_NSIS_HELP_LINK "https:\\\\\\\\github.com\\\\PurpleI2P\\\\i2pd\\\\issues") |
|
|
|
|
|
|
|
set(CPACK_NSIS_URL_INFO_ABOUT "https:\\\\\\\\github.com\\\\PurpleI2P\\\\i2pd") |
|
|
|
|
|
|
|
set(CPACK_NSIS_CREATE_ICONS_EXTRA "CreateShortCut '$SMPROGRAMS\\\\$STARTMENU_FOLDER\\\\Install i2pd as windows service.lnk' '$INSTDIR\\\\bin\\\\i2pd.exe' '--service=install' |
|
|
|
|
|
|
|
CreateShortCut '$SMPROGRAMS\\\\$STARTMENU_FOLDER\\\\Remove i2pd windows service.lnk' '$INSTDIR\\\\bin\\\\i2pd.exe' '--service=remove'") |
|
|
|
|
|
|
|
set(CPACK_NSIS_DELETE_ICONS_EXTRA "Delete '$SMPROGRAMS\\\\$START_MENU\\\\Install i2pd as windows service.lnk' |
|
|
|
|
|
|
|
Delete '$SMPROGRAMS\\\\$START_MENU\\\\Remove i2pd windows service.lnk'") |
|
|
|
|
|
|
|
else() |
|
|
|
|
|
|
|
set(CPACK_STRIP_FILES "bin/i2pd") |
|
|
|
|
|
|
|
set(CPACK_SOURCE_STRIP_FILES "") |
|
|
|
|
|
|
|
endif() |
|
|
|
endif() |
|
|
|
set(CPACK_PACKAGE_EXECUTABLES "i2pd" "C++ I2P daemon") |
|
|
|
|
|
|
|
set(CPACK_SOURCE_GENERATOR "TGZ") |
|
|
|
|
|
|
|
include(CPack) |
|
|
|
|
|
|
|