X-Git-Url: https://git.novaco.in/?a=blobdiff_plain;f=src%2FCMakeLists.txt;h=eccdd59a8937b9f154861e5f52b4531f7890009a;hb=refs%2Fheads%2Fmaster;hp=d4bedc887449fd087b6154e6262ccd3f4d758947;hpb=4428c0454c0ab107f1fe303c4669d6eded255141;p=novacoin.git diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index d4bedc8..eccdd59 100644 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -1,10 +1,10 @@ -cmake_minimum_required(VERSION 3.4.1) +cmake_minimum_required(VERSION 3.5) ## ## mkdir build && cd build ## ## cmake -DBerkeleyDB_ROOT:STRING=/opt/homebrew/Cellar/berkeley-db@4/4.8.30 .. -## cmake -DBerkeleyDB_INC:STRING=/usr/include -DBerkeleyDB_LIBS:STRING=/usr/lib/aarch64-linux-gnu -DUSE_LEVELDB=1 .. +## cmake .. ## project(novacoind VERSION 0.5.9 LANGUAGES C CXX) @@ -21,19 +21,36 @@ endif() find_program(CCACHE_FOUND ccache) if(CCACHE_FOUND) - set_property(GLOBAL PROPERTY RULE_LAUNCH_COMPILE ccache) set(CMAKE_C_COMPILER_LAUNCHER ccache) set(CMAKE_CXX_COMPILER_LAUNCHER ccache) endif(CCACHE_FOUND) -set (CMAKE_C_FLAGS "-flto -O3 -fPIC -Wno-deprecated -fstack-protector-all -Wstack-protector -D_FORTIFY_SOURCE=2") -set (CMAKE_CXX_FLAGS "${CMAKE_C_FLAGS} -fexceptions -frtti") +if (NOT MSVC) +if (NOT WIN32) +set(FPIC "-fPIC") +endif() +set (CMAKE_C_FLAGS "-flto=auto -O3 ${FPIC} -Wno-deprecated -Wno-deprecated-declarations -fstack-protector-all") +set (CMAKE_CXX_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-parameter -fexceptions -frtti") +else() +set(CMAKE_C_FLAGS "/O2") +set(CMAKE_CXX_FLAGS "/O2 /GR /EHsc") +endif() + set(CMAKE_CXX_EXTENSIONS OFF) set(Boost_USE_STATIC_LIBS ON) +if(WIN32) +set(Boost_USE_STATIC_RUNTIME ON) +endif() find_package(Boost REQUIRED COMPONENTS atomic chrono filesystem program_options system thread) + set(OPENSSL_USE_STATIC_LIBS ON) +find_package(OpenSSL) +if (NOT OpenSSL_FOUND) +set(OPENSSL_USE_STATIC_LIBS OFF) find_package(OpenSSL REQUIRED) +endif() + add_subdirectory(additional/IXWebSocket) # Set default root path for berkeley db @@ -53,14 +70,32 @@ endif() # Set default library path for berkeley db if (NOT BerkeleyDB_LIBS) set(BerkeleyDB_LIBS ${BerkeleyDB_ROOT}/lib) +if(CMAKE_SYSTEM_NAME STREQUAL "Linux") +# Workaround for linux distributions + execute_process ( + COMMAND bash -c "test -d ${BerkeleyDB_LIBS}/${CMAKE_SYSTEM_PROCESSOR}-linux-gnu && echo -n 'present' || echo -n 'absent'" + OUTPUT_VARIABLE dirPresent + ) + if(dirPresent STREQUAL "present") + set(BerkeleyDB_LIBS ${BerkeleyDB_LIBS}/${CMAKE_SYSTEM_PROCESSOR}-linux-gnu) + endif() +endif(CMAKE_SYSTEM_NAME STREQUAL "Linux") +endif() + +# Set default library name for berkeley db +if (NOT BerkeleyDB_LIB_name) +set(BerkeleyDB_LIB_name libdb_cxx) endif() set(generic_sources ${CMAKE_CURRENT_SOURCE_DIR}/addrman.cpp ${CMAKE_CURRENT_SOURCE_DIR}/alert.cpp + ${CMAKE_CURRENT_SOURCE_DIR}/allocators.cpp ${CMAKE_CURRENT_SOURCE_DIR}/base58.cpp + ${CMAKE_CURRENT_SOURCE_DIR}/bignum.cpp ${CMAKE_CURRENT_SOURCE_DIR}/bitcoinrpc.cpp ${CMAKE_CURRENT_SOURCE_DIR}/checkpoints.cpp + ${CMAKE_CURRENT_SOURCE_DIR}/coincontrol.cpp ${CMAKE_CURRENT_SOURCE_DIR}/crypter.cpp ${CMAKE_CURRENT_SOURCE_DIR}/db.cpp ${CMAKE_CURRENT_SOURCE_DIR}/init.cpp @@ -78,6 +113,7 @@ set(generic_sources ${CMAKE_CURRENT_SOURCE_DIR}/noui.cpp ${CMAKE_CURRENT_SOURCE_DIR}/ntp.cpp ${CMAKE_CURRENT_SOURCE_DIR}/protocol.cpp + ${CMAKE_CURRENT_SOURCE_DIR}/random.cpp ${CMAKE_CURRENT_SOURCE_DIR}/rpcblockchain.cpp ${CMAKE_CURRENT_SOURCE_DIR}/rpcdump.cpp ${CMAKE_CURRENT_SOURCE_DIR}/rpcmining.cpp @@ -85,8 +121,11 @@ set(generic_sources ${CMAKE_CURRENT_SOURCE_DIR}/rpcrawtransaction.cpp ${CMAKE_CURRENT_SOURCE_DIR}/rpcwallet.cpp ${CMAKE_CURRENT_SOURCE_DIR}/script.cpp + ${CMAKE_CURRENT_SOURCE_DIR}/streams.cpp ${CMAKE_CURRENT_SOURCE_DIR}/stun.cpp ${CMAKE_CURRENT_SOURCE_DIR}/sync.cpp + ${CMAKE_CURRENT_SOURCE_DIR}/timedata.cpp + ${CMAKE_CURRENT_SOURCE_DIR}/uint256.cpp ${CMAKE_CURRENT_SOURCE_DIR}/util.cpp ${CMAKE_CURRENT_SOURCE_DIR}/version.cpp ${CMAKE_CURRENT_SOURCE_DIR}/wallet.cpp @@ -96,9 +135,14 @@ set(generic_sources list(APPEND ALL_SOURCES ${generic_sources}) list(APPEND ALL_LIBRARIES ${Boost_LIBRARIES} ixwebsocket OpenSSL::Crypto) -# Windows-specific libraries if (WIN32) - list(APPEND ALL_LIBRARIES ws2_32 mswsock) + # Windows-specific libraries + list(APPEND ALL_LIBRARIES kernel32 user32 gdi32 comdlg32 winspool winmm shell32 comctl32 ole32 oleaut32 uuid rpcrt4 advapi32 ws2_32 mswsock shlwapi pthread) + list(APPEND ALL_DEFINITIONS WIN32) + + # Resources + configure_file(${CMAKE_CURRENT_SOURCE_DIR}/bitcoin.rc bitcoin.rc) + list(APPEND ALL_SOURCES ${CMAKE_BINARY_DIR}/bitcoin.rc) endif() # Some systems need rt library @@ -107,43 +151,27 @@ if (NOT WIN32 AND NOT APPLE) endif() # Try various libdb library file extensions -if (EXISTS ${BerkeleyDB_LIBS}/libdb_cxx.a) - list(APPEND ALL_LIBRARIES ${BerkeleyDB_LIBS}/libdb_cxx.a) -elseif(EXISTS ${BerkeleyDB_LIBS}/libdb_cxx.so) - list(APPEND ALL_LIBRARIES ${BerkeleyDB_LIBS}/libdb_cxx.so) -elseif(EXISTS ${BerkeleyDB_LIBS}/libdb_cxx.dylib) - list(APPEND ALL_LIBRARIES ${BerkeleyDB_LIBS}/libdb_cxx.dylib) -elseif(EXISTS ${BerkeleyDB_LIBS}/libdb_cxx.dll) - list(APPEND ALL_LIBRARIES ${BerkeleyDB_LIBS}/libdb_cxx.dll) -else() - set(BerkeleyDB_LIBS ${BerkeleyDB_ROOT}/lib/x86_64-linux-gnu) - if (EXISTS ${BerkeleyDB_LIBS}/libdb_cxx.a) - list(APPEND ALL_LIBRARIES ${BerkeleyDB_LIBS}/libdb_cxx.a) - elseif(EXISTS ${BerkeleyDB_LIBS}/libdb_cxx.so) - list(APPEND ALL_LIBRARIES ${BerkeleyDB_LIBS}/libdb_cxx.so) - elseif(EXISTS ${BerkeleyDB_LIBS}/libdb_cxx.dylib) - list(APPEND ALL_LIBRARIES ${BerkeleyDB_LIBS}/libdb_cxx.dylib) - elseif(EXISTS ${BerkeleyDB_LIBS}/libdb_cxx.dll) - list(APPEND ALL_LIBRARIES ${BerkeleyDB_LIBS}/libdb_cxx.dll) - else() - message(FATAL_ERROR "Unable to find libdb_cxx library in ${BerkeleyDB_LIBS} directory. Try to specify either library path via BerkeleyDB_LIBS or berkeley db root path via BerkeleyDB_ROOT variable.") - endif() +foreach(ext a so dylib lib) +if (EXISTS ${BerkeleyDB_LIBS}/${BerkeleyDB_LIB_name}.${ext}) + list(APPEND ALL_LIBRARIES ${BerkeleyDB_LIBS}/${BerkeleyDB_LIB_name}.${ext}) + set (BDB_FOUND True) + break() endif() +endforeach() -if(USE_LEVELDB) - # Disable useless targets - option(LEVELDB_BUILD_TESTS "Build LevelDB's unit tests" OFF) - option(LEVELDB_BUILD_BENCHMARKS "Build LevelDB's benchmarks" OFF) - option(LEVELDB_INSTALL "Install LevelDB's header and library" OFF) - - add_subdirectory(additional/leveldb) - list(APPEND ALL_SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/txdb-leveldb.cpp) - list(APPEND ALL_LIBRARIES leveldb) - list(APPEND ALL_DEFINITIONS USE_LEVELDB) -else() - list(APPEND ALL_SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/txdb-bdb.cpp) +if (NOT BDB_FOUND) + message(FATAL_ERROR "Unable to find ${BerkeleyDB_LIB_name} library in ${BerkeleyDB_LIBS} directory. Try to specify either library path via BerkeleyDB_LIBS or berkeley db root path via BerkeleyDB_ROOT variable. You can also use BerkeleyDB_LIB_name variable to provide alternative file name search for.") endif() +# Disable useless targets +option(LEVELDB_BUILD_TESTS "Build LevelDB's unit tests" OFF) +option(LEVELDB_BUILD_BENCHMARKS "Build LevelDB's benchmarks" OFF) +option(LEVELDB_INSTALL "Install LevelDB's header and library" OFF) + +add_subdirectory(additional/leveldb) +list(APPEND ALL_SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/txdb-leveldb.cpp) +list(APPEND ALL_LIBRARIES leveldb) + if (NOT USE_GENERIC_SCRYPT) list( APPEND ALL_SOURCES ${generic_sources} ${CMAKE_CURRENT_SOURCE_DIR}/crypto/scrypt/intrin/scrypt-intrin.cpp ) list(APPEND ALL_DEFINITIONS USE_INTRIN) @@ -156,9 +184,58 @@ execute_process ( COMMAND sh -c "${CMAKE_CURRENT_SOURCE_DIR}/../share/genbuild.sh ${CMAKE_CURRENT_SOURCE_DIR}/build.h" OUTPUT_VARIABLE outVar ) -list(APPEND ALL_DEFINITIONS HAVE_BUILD_INFO) +list(APPEND ALL_DEFINITIONS HAVE_BUILD_INFO USE_IPV6 BOOST_SPIRIT_THREADSAFE) add_executable(novacoind ${ALL_SOURCES}) + +target_precompile_headers(novacoind + PRIVATE + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +) + +if (NOT MSVC) +list(APPEND ALL_DEFINITIONS _FORTIFY_SOURCE=2) +set(ALL_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -fstack-protector-all") +if (WIN32) +list(APPEND ALL_LIBRARIES mingw32 ssp) +set(ALL_LINKER_FLAGS "${ALL_LINKER_FLAGS} -static-libgcc -static") +endif() +set(CMAKE_EXE_LINKER_FLAGS ${ALL_LINKER_FLAGS} CACHE INTERNAL "") +endif() + target_include_directories(novacoind PRIVATE ${CMAKE_CURRENT_SOURCE_DIR} ${CMAKE_CURRENT_SOURCE_DIR}/json ${BerkeleyDB_INC} ${CMAKE_CURRENT_SOURCE_DIR}/additional/leveldb/helpers ${Boost_INCLUDE_DIRS}) target_link_libraries(novacoind ${ALL_LIBRARIES})