mirror of https://github.com/oxen-io/lokinet
Refactor CMakeLists into distinct directories
This commit is contained in:
parent
4f3c2a7e80
commit
3b3926a0ea
579
CMakeLists.txt
579
CMakeLists.txt
|
@ -4,6 +4,7 @@ cmake_minimum_required(VERSION 3.6.0)
|
|||
set(PROJECT_NAME lokinet)
|
||||
project(${PROJECT_NAME} C CXX ASM)
|
||||
|
||||
# Core options
|
||||
option(USE_LIBABYSS "enable libabyss" )
|
||||
option(USE_AVX2 "enable avx2 code" )
|
||||
option(USE_NETNS "enable networking namespace support. Linux only" )
|
||||
|
@ -18,6 +19,9 @@ option(TESTNET "testnet build" )
|
|||
option(WITH_SHARED "build shared library")
|
||||
option(WITH_COVERAGE "generate coverage data")
|
||||
|
||||
# Basic definitions
|
||||
get_filename_component(CORE_INCLUDE include ABSOLUTE)
|
||||
|
||||
find_program(CCACHE_PROGRAM ccache)
|
||||
if(CCACHE_PROGRAM)
|
||||
set_property(GLOBAL PROPERTY RULE_LAUNCH_COMPILE "${CCACHE_PROGRAM}")
|
||||
|
@ -54,8 +58,8 @@ set(ABSEIL_DIR vendor/abseil-cpp)
|
|||
include_directories(${ABSEIL_DIR})
|
||||
|
||||
if (NOT WIN32)
|
||||
add_compile_options(-fPIC)
|
||||
add_subdirectory(${ABSEIL_DIR})
|
||||
add_compile_options(-fPIC)
|
||||
add_subdirectory(${ABSEIL_DIR})
|
||||
endif(NOT WIN32)
|
||||
|
||||
# turns off those annoying warnings for
|
||||
|
@ -107,17 +111,13 @@ endif(WIN32)
|
|||
|
||||
if(DEBIAN)
|
||||
add_definitions(-DDEBIAN)
|
||||
else()
|
||||
if(NOT ANDROID)
|
||||
if(NOT NON_PC_TARGET)
|
||||
if (NOT USE_AVX2)
|
||||
set(CRYPTO_FLAGS -march=nocona -mtune=native -mfpmath=sse)
|
||||
else()
|
||||
set(CRYPTO_FLAGS -march=haswell -mtune=native -mfpmath=sse)
|
||||
endif(NOT USE_AVX2)
|
||||
endif(NOT NON_PC_TARGET)
|
||||
endif(NOT ANDROID)
|
||||
endif(DEBIAN)
|
||||
elseif(NOT ANDROID AND NOT NON_PC_TARGET)
|
||||
if (NOT USE_AVX2)
|
||||
set(CRYPTO_FLAGS -march=nocona -mtune=native -mfpmath=sse)
|
||||
else()
|
||||
set(CRYPTO_FLAGS -march=haswell -mtune=native -mfpmath=sse)
|
||||
endif()
|
||||
endif()
|
||||
|
||||
# only needed if using AVX2
|
||||
# TODO: generate a config-time test for this
|
||||
|
@ -223,10 +223,10 @@ endif(JEMALLOC)
|
|||
|
||||
# FS_LIB should resolve to nothing on all other platforms
|
||||
# it is only required on win32 -rick
|
||||
set(LIBS ${LIBS} ${MALLOC_LIB} ${FS_LIB})
|
||||
set(LIBS ${MALLOC_LIB} ${FS_LIB})
|
||||
|
||||
if(ANDROID)
|
||||
set(LIBS ${LIBS} log)
|
||||
list(APPEND LIBS log)
|
||||
add_definitions(-DANDROID)
|
||||
set(ANDROID_PLATFORM_SRC llarp/android/ifaddrs.c)
|
||||
endif(ANDROID)
|
||||
|
@ -238,40 +238,40 @@ set(CRYPTOGRAPHY_LIB ${LIB}-cryptography)
|
|||
set(UTIL_LIB ${LIB}-util)
|
||||
set(PLATFORM_LIB ${LIB}-platform)
|
||||
set(ANDROID_LIB ${LIB}android)
|
||||
set(TT_ROOT vendor/libtuntap-master)
|
||||
get_filename_component(TT_ROOT "vendor/libtuntap-master" ABSOLUTE)
|
||||
add_definitions(-D${CMAKE_SYSTEM_NAME})
|
||||
|
||||
if(UNIX)
|
||||
add_definitions(-DUNIX)
|
||||
add_definitions(-DPOSIX)
|
||||
if(${CMAKE_SYSTEM_NAME} MATCHES "Linux")
|
||||
set(LIBTUNTAP_IMPL ${TT_ROOT}/tuntap-unix-linux.c)
|
||||
set(EV_SRC llarp/ev/ev_epoll.cpp)
|
||||
elseif(${CMAKE_SYSTEM_NAME} MATCHES "Android")
|
||||
set(LIBTUNTAP_IMPL ${TT_ROOT}/tuntap-unix-linux.c)
|
||||
set(EV_SRC llarp/ev/ev_epoll.cpp)
|
||||
elseif (${CMAKE_SYSTEM_NAME} MATCHES "OpenBSD")
|
||||
set(LIBTUNTAP_IMPL ${TT_ROOT}/tuntap-unix-openbsd.c ${TT_ROOT}/tuntap-unix-bsd.c)
|
||||
set(EV_SRC llarp/ev/ev_kqueue.cpp)
|
||||
elseif (${CMAKE_SYSTEM_NAME} MATCHES "NetBSD")
|
||||
set(LIBTUNTAP_IMPL ${TT_ROOT}/tuntap-unix-netbsd.c ${TT_ROOT}/tuntap-unix-bsd.c)
|
||||
set(EV_SRC llarp/ev/ev_kqueue.cpp)
|
||||
elseif (${CMAKE_SYSTEM_NAME} MATCHES "FreeBSD" OR ${CMAKE_SYSTEM_NAME} MATCHES "DragonFly")
|
||||
set(LIBTUNTAP_IMPL ${TT_ROOT}/tuntap-unix-freebsd.c ${TT_ROOT}/tuntap-unix-bsd.c)
|
||||
set(EV_SRC llarp/ev/ev_kqueue.cpp)
|
||||
elseif (${CMAKE_SYSTEM_NAME} MATCHES "Darwin")
|
||||
set(LIBTUNTAP_IMPL ${TT_ROOT}/tuntap-unix-darwin.c ${TT_ROOT}/tuntap-unix-bsd.c)
|
||||
set(EV_SRC llarp/ev/ev_kqueue.cpp)
|
||||
get_filename_component(LIBTUNTAP_IMPL ${TT_ROOT}/tuntap-unix-linux.c ABSOLUTE)
|
||||
get_filename_component(EV_SRC "llarp/ev/ev_epoll.cpp" ABSOLUTE)
|
||||
elseif(${CMAKE_SYSTEM_NAME} MATCHES "Android")
|
||||
get_filename_component(LIBTUNTAP_IMPL ${TT_ROOT}/tuntap-unix-linux.c ABSOLUTE)
|
||||
get_filename_component(EV_SRC "llarp/ev/ev_epoll.cpp" ABSOLUTE)
|
||||
elseif (${CMAKE_SYSTEM_NAME} MATCHES "OpenBSD")
|
||||
set(LIBTUNTAP_IMPL ${TT_ROOT}/tuntap-unix-openbsd.c ${TT_ROOT}/tuntap-unix-bsd.c)
|
||||
get_filename_component(EV_SRC "llarp/ev/ev_kqueue.cpp" ABSOLUTE)
|
||||
elseif (${CMAKE_SYSTEM_NAME} MATCHES "NetBSD")
|
||||
set(LIBTUNTAP_IMPL ${TT_ROOT}/tuntap-unix-netbsd.c ${TT_ROOT}/tuntap-unix-bsd.c)
|
||||
get_filename_component(EV_SRC "llarp/ev/ev_kqueue.cpp" ABSOLUTE)
|
||||
elseif (${CMAKE_SYSTEM_NAME} MATCHES "FreeBSD" OR ${CMAKE_SYSTEM_NAME} MATCHES "DragonFly")
|
||||
set(LIBTUNTAP_IMPL ${TT_ROOT}/tuntap-unix-freebsd.c ${TT_ROOT}/tuntap-unix-bsd.c)
|
||||
get_filename_component(EV_SRC "llarp/ev/ev_kqueue.cpp" ABSOLUTE)
|
||||
elseif (${CMAKE_SYSTEM_NAME} MATCHES "Darwin")
|
||||
set(LIBTUNTAP_IMPL ${TT_ROOT}/tuntap-unix-darwin.c ${TT_ROOT}/tuntap-unix-bsd.c)
|
||||
get_filename_component(EV_SRC "llarp/ev/ev_kqueue.cpp" ABSOLUTE)
|
||||
# TODO: _actually_ port to solaris/illumos (it's fairly complete...except for TUN) -rick
|
||||
elseif (${CMAKE_SYSTEM_NAME} MATCHES "SunOS")
|
||||
set(LIBTUNTAP_IMPL ${TT_ROOT}/tuntap-unix-sunos.c)
|
||||
set(EV_SRC llarp/ev/ev_epoll.cpp)
|
||||
else()
|
||||
message(FATAL_ERROR "Your operating system is not supported yet")
|
||||
endif(${CMAKE_SYSTEM_NAME} MATCHES "Linux")
|
||||
elseif (${CMAKE_SYSTEM_NAME} MATCHES "SunOS")
|
||||
set(LIBTUNTAP_IMPL ${TT_ROOT}/tuntap-unix-sunos.c)
|
||||
get_filename_component(EV_SRC "llarp/ev/ev_epoll.cpp" ABSOLUTE)
|
||||
else()
|
||||
message(FATAL_ERROR "Your operating system is not supported yet")
|
||||
endif()
|
||||
elseif(WIN32)
|
||||
set(LIBTUNTAP_IMPL ${TT_ROOT}/tuntap-windows.c)
|
||||
set(EV_SRC llarp/ev/ev_win32.cpp)
|
||||
get_filename_component(LIBTUNTAP_IMPL ${TT_ROOT}/tuntap-unix-windows.c ABSOLUTE)
|
||||
get_filename_component(EV_SRC "llarp/ev/ev_win32.cpp" ABSOLUTE)
|
||||
add_definitions(-DWIN32_LEAN_AND_MEAN -DWIN32 -DWINVER=0x500 -D_WIN32_WINNT=0x500)
|
||||
else()
|
||||
message(FATAL_ERROR "What operating system _are_ you building on/for?")
|
||||
|
@ -282,10 +282,8 @@ set(LIBTUNTAP_SRC_BASE
|
|||
${TT_ROOT}/tuntap_log.cpp
|
||||
${LIBTUNTAP_IMPL})
|
||||
|
||||
if (UNIX)
|
||||
set(LIBTUNTAP_SRC
|
||||
${TT_ROOT}/tuntap-unix.c
|
||||
${LIBTUNTAP_SRC_BASE})
|
||||
if(UNIX)
|
||||
set(LIBTUNTAP_SRC ${TT_ROOT}/tuntap-unix.c ${LIBTUNTAP_SRC_BASE})
|
||||
else()
|
||||
set(LIBTUNTAP_SRC ${LIBTUNTAP_SRC_BASE})
|
||||
endif(UNIX)
|
||||
|
@ -295,332 +293,12 @@ if(${CMAKE_SYSTEM_NAME} MATCHES "Linux")
|
|||
endif(${CMAKE_SYSTEM_NAME} MATCHES "Linux")
|
||||
|
||||
if(NOT WIN32)
|
||||
set(CXX_COMPAT_SRC
|
||||
vendor/cppbackport-master/lib/fs/rename.cpp
|
||||
vendor/cppbackport-master/lib/fs/filestatus.cpp
|
||||
vendor/cppbackport-master/lib/fs/filetype.cpp
|
||||
vendor/cppbackport-master/lib/fs/cleanpath.cpp
|
||||
vendor/cppbackport-master/lib/fs/perms.cpp
|
||||
vendor/cppbackport-master/lib/fs/equivalent.cpp
|
||||
vendor/cppbackport-master/lib/fs/current_path.cpp
|
||||
vendor/cppbackport-master/lib/fs/basename.cpp
|
||||
vendor/cppbackport-master/lib/fs/tempdir.cpp
|
||||
vendor/cppbackport-master/lib/fs/create_directory.cpp
|
||||
vendor/cppbackport-master/lib/fs/path.cpp
|
||||
vendor/cppbackport-master/lib/fs/remove.cpp
|
||||
vendor/cppbackport-master/lib/fs/diriter.cpp
|
||||
vendor/cppbackport-master/lib/fs/copyfile.cpp
|
||||
vendor/cppbackport-master/lib/fs/absolute.cpp
|
||||
vendor/cppbackport-master/lib/fs/direntry.cpp
|
||||
)
|
||||
include_directories(vendor/cppbackport-master/lib)
|
||||
add_subdirectory(vendor)
|
||||
endif(NOT WIN32)
|
||||
|
||||
set(LIB_UTIL_SRC
|
||||
llarp/constants/defaults.cpp
|
||||
llarp/constants/link_layer.cpp
|
||||
llarp/constants/proto.cpp
|
||||
llarp/constants/version.cpp
|
||||
llarp/util/aligned.cpp
|
||||
llarp/util/bencode.cpp
|
||||
llarp/util/bits.cpp
|
||||
llarp/util/buffer.cpp
|
||||
llarp/util/codel.cpp
|
||||
llarp/util/common.cpp
|
||||
llarp/util/encode.cpp
|
||||
llarp/util/endian.cpp
|
||||
llarp/util/fs.cpp
|
||||
llarp/util/ini.cpp
|
||||
llarp/util/logger.c
|
||||
llarp/util/logger.cpp
|
||||
llarp/util/logic.cpp
|
||||
llarp/util/mem.cpp
|
||||
llarp/util/queue_manager.cpp
|
||||
llarp/util/queue.cpp
|
||||
llarp/util/str.cpp
|
||||
llarp/util/string_view.cpp
|
||||
llarp/util/thread_pool.cpp
|
||||
llarp/util/threading.cpp
|
||||
llarp/util/threadpool.cpp
|
||||
llarp/util/time.cpp
|
||||
llarp/util/timer.cpp
|
||||
llarp/util/types.cpp
|
||||
)
|
||||
|
||||
set(LIB_PLATFORM_SRC
|
||||
# for networking
|
||||
llarp/ev/ev.cpp
|
||||
llarp/net/net.cpp
|
||||
llarp/net/net_addr.cpp
|
||||
llarp/net/net_inaddr.cpp
|
||||
# for android shim
|
||||
${ANDROID_PLATFORM_SRC}
|
||||
# process isolation implementation
|
||||
${ISOLATE_PROC_SRC}
|
||||
# tun
|
||||
${LIBTUNTAP_SRC}
|
||||
${EV_SRC}
|
||||
# c++17 compat code
|
||||
${CXX_COMPAT_SRC}
|
||||
# win32 inline code
|
||||
llarp/win32/win32_inet.c
|
||||
llarp/win32/win32_intrnl.c
|
||||
llarp/win32/win32_upoll.c
|
||||
)
|
||||
|
||||
set(NTRU_AVX_SRC
|
||||
crypto/libntrup/src/avx/randomsmall.c
|
||||
crypto/libntrup/src/avx/weight.c
|
||||
crypto/libntrup/src/avx/swap.c
|
||||
crypto/libntrup/src/avx/rq_round3.c
|
||||
crypto/libntrup/src/avx/rq_recip3.c
|
||||
crypto/libntrup/src/avx/small.c
|
||||
crypto/libntrup/src/avx/randomweightw.c
|
||||
crypto/libntrup/src/avx/dec.c
|
||||
crypto/libntrup/src/avx/r3_recip.c
|
||||
crypto/libntrup/src/avx/keypair.c
|
||||
crypto/libntrup/src/avx/rq_rounded.c
|
||||
crypto/libntrup/src/avx/mult.c
|
||||
crypto/libntrup/src/avx/enc.c
|
||||
crypto/libntrup/src/avx/int32_sort.c
|
||||
crypto/libntrup/src/avx/rq.c
|
||||
crypto/libntrup/src/avx/rq_mod3.c
|
||||
)
|
||||
|
||||
set(NTRU_REF_SRC
|
||||
crypto/libntrup/src/ref/randomsmall.c
|
||||
crypto/libntrup/src/ref/swap.c
|
||||
crypto/libntrup/src/ref/rq_round3.c
|
||||
crypto/libntrup/src/ref/rq_recip3.c
|
||||
crypto/libntrup/src/ref/small.c
|
||||
crypto/libntrup/src/ref/rq_mult.c
|
||||
crypto/libntrup/src/ref/randomweightw.c
|
||||
crypto/libntrup/src/ref/random32.c
|
||||
crypto/libntrup/src/ref/dec.c
|
||||
crypto/libntrup/src/ref/r3_mult.c
|
||||
crypto/libntrup/src/ref/r3_recip.c
|
||||
crypto/libntrup/src/ref/keypair.c
|
||||
crypto/libntrup/src/ref/rq_rounded.c
|
||||
crypto/libntrup/src/ref/enc.c
|
||||
crypto/libntrup/src/ref/int32_sort.c
|
||||
crypto/libntrup/src/ref/rq.c
|
||||
)
|
||||
|
||||
include_directories(crypto/include)
|
||||
|
||||
set(NTRU_SRC
|
||||
${NTRU_AVX_SRC}
|
||||
${NTRU_REF_SRC}
|
||||
crypto/libntrup/src/ntru.cpp
|
||||
)
|
||||
|
||||
set(SHA512_SRC
|
||||
crypto/sha512/sha512.c)
|
||||
|
||||
set(CHACHA_SRC
|
||||
crypto/chacha20/ref/chacha20_ref.c
|
||||
crypto/chacha20/dolbeau/chacha20_dolbeau-ssse3.c
|
||||
crypto/chacha20/dolbeau/chacha20_dolbeau-avx2.c
|
||||
crypto/chacha20/stream_chacha20.c
|
||||
crypto/salsa20/ref/salsa20_ref.c
|
||||
crypto/salsa20/core_salsa_ref.c
|
||||
crypto/salsa20/stream_salsa20.c
|
||||
crypto/salsa20/xmm6/salsa20_xmm6-asm.S
|
||||
crypto/salsa20/xmm6/salsa20_xmm6.c
|
||||
crypto/salsa20/xmm6int/salsa20_xmm6int-avx2.c
|
||||
crypto/salsa20/xmm6int/salsa20_xmm6int-sse2.c
|
||||
crypto/xchacha20/hchacha.c
|
||||
crypto/xchacha20/stream_xchacha20.c)
|
||||
|
||||
set(CSRNG_SRC
|
||||
crypto/csrng/randombytes_salsa20_random.c
|
||||
crypto/csrng/randombytes.c)
|
||||
|
||||
set(CRYPTO_MEM_SRC
|
||||
crypto/secmem/secmem.c)
|
||||
|
||||
set(BLAKE2B_SRC
|
||||
crypto/blake2b/blake2b-compress-avx2.c
|
||||
crypto/blake2b/blake2b-compress-ref.c
|
||||
crypto/blake2b/blake2b-compress-sse41.c
|
||||
crypto/blake2b/blake2b-compress-ssse3.c
|
||||
crypto/blake2b/blake2b-ref.c
|
||||
crypto/blake2b/generichash_blake2b.c)
|
||||
|
||||
set(X25519_SRC
|
||||
crypto/curve25519/crypto_scalarmult.c
|
||||
crypto/curve25519/ref10/x25519_ref10.c
|
||||
crypto/curve25519/ref10/ed25519_ref10.c
|
||||
crypto/curve25519/sandy2x/fe51_invert.c
|
||||
crypto/curve25519/sandy2x/ladder_base.S
|
||||
crypto/curve25519/sandy2x/curve25519_sandy2x.c
|
||||
crypto/curve25519/sandy2x/consts.S
|
||||
crypto/curve25519/sandy2x/fe51_nsquare.S
|
||||
crypto/curve25519/sandy2x/fe51_mul.S
|
||||
crypto/curve25519/sandy2x/fe51_pack.S
|
||||
crypto/curve25519/sandy2x/fe_frombytes_sandy2x.c
|
||||
crypto/curve25519/sandy2x/sandy2x.S
|
||||
crypto/curve25519/sandy2x/ladder.S
|
||||
crypto/curve25519/scalarmult_curve25519.c
|
||||
crypto/ed25519/crypto_box.c
|
||||
crypto/ed25519/crypto_sign.c
|
||||
crypto/ed25519/ref10/open.c
|
||||
crypto/ed25519/ref10/obsolete.c
|
||||
crypto/ed25519/ref10/keypair.c
|
||||
crypto/ed25519/ref10/sign.c
|
||||
crypto/ed25519/sign_ed25519.c)
|
||||
|
||||
set(CRYPTOGRAPHY_SRC
|
||||
crypto/libsodium/init.c
|
||||
crypto/libsodium/runtime.c
|
||||
crypto/verify/crypto_verify.c
|
||||
${CRYPTO_MEM_SRC}
|
||||
${CSRNG_SRC}
|
||||
${BLAKE2B_SRC}
|
||||
${CHACHA_SRC}
|
||||
${ED25519_SRC}
|
||||
${X25519_SRC}
|
||||
${SHA512_SRC}
|
||||
${NTRU_SRC})
|
||||
|
||||
add_library(${CRYPTOGRAPHY_LIB} STATIC ${CRYPTOGRAPHY_SRC})
|
||||
|
||||
set(UTP_SRC
|
||||
libutp/utp_callbacks.cpp
|
||||
libutp/utp_utils.cpp
|
||||
libutp/utp_internal.cpp
|
||||
libutp/utp_api.cpp
|
||||
libutp/utp_packedsockaddr.cpp
|
||||
libutp/utp_hash.cpp
|
||||
)
|
||||
|
||||
if(WIN32)
|
||||
set(UTP_SRC ${UTP_SRC} libutp/libutp_inet_ntop.cpp)
|
||||
endif(WIN32)
|
||||
|
||||
set(DNSLIB_SRC
|
||||
llarp/dns/dotlokilookup.cpp
|
||||
llarp/dns/dns.cpp
|
||||
llarp/dns/iptracker.cpp
|
||||
llarp/dns/message.cpp
|
||||
llarp/dns/name.cpp
|
||||
llarp/dns/query.cpp
|
||||
llarp/dns/question.cpp
|
||||
llarp/dns/rectypes.cpp
|
||||
llarp/dns/rr.cpp
|
||||
llarp/dns/serialize.cpp
|
||||
llarp/dns/server.cpp
|
||||
llarp/dns/string.cpp
|
||||
)
|
||||
|
||||
|
||||
set(LIB_SRC
|
||||
${DNSLIB_SRC}
|
||||
${UTP_SRC}
|
||||
llarp/config.cpp
|
||||
llarp/context.cpp
|
||||
llarp/crypto/constants.cpp
|
||||
llarp/crypto/crypto_libsodium.cpp
|
||||
llarp/crypto/crypto.cpp
|
||||
llarp/crypto/encrypted_frame.cpp
|
||||
llarp/crypto/encrypted.cpp
|
||||
llarp/crypto/types.cpp
|
||||
llarp/dht/bucket.cpp
|
||||
llarp/dht/context.cpp
|
||||
llarp/dht/dht.cpp
|
||||
llarp/dht/explorenetworkjob.cpp
|
||||
llarp/dht/kademlia.cpp
|
||||
llarp/dht/key.cpp
|
||||
llarp/dht/localtaglookup.cpp
|
||||
llarp/dht/localrouterlookup.cpp
|
||||
llarp/dht/localserviceaddresslookup.cpp
|
||||
llarp/dht/message.cpp
|
||||
llarp/dht/messages/findintro.cpp
|
||||
llarp/dht/messages/findrouter.cpp
|
||||
llarp/dht/messages/gotintro.cpp
|
||||
llarp/dht/messages/gotrouter.cpp
|
||||
llarp/dht/messages/pubintro.cpp
|
||||
llarp/dht/node.cpp
|
||||
llarp/dht/publishservicejob.cpp
|
||||
llarp/dht/recursiverouterlookup.cpp
|
||||
llarp/dht/serviceaddresslookup.cpp
|
||||
llarp/dht/taglookup.cpp
|
||||
llarp/dht/tx.cpp
|
||||
llarp/dht/txholder.cpp
|
||||
llarp/dht/txowner.cpp
|
||||
llarp/dns.cpp
|
||||
llarp/dnsc.cpp
|
||||
llarp/dnsd.cpp
|
||||
llarp/exit/close_exit.cpp
|
||||
llarp/exit/context.cpp
|
||||
llarp/exit/endpoint.cpp
|
||||
llarp/exit/grant_exit.cpp
|
||||
llarp/exit/obtain_exit.cpp
|
||||
llarp/exit/policy.cpp
|
||||
llarp/exit/reject_exit.cpp
|
||||
llarp/exit/session.cpp
|
||||
llarp/exit/transfer_traffic.cpp
|
||||
llarp/exit/update_exit.cpp
|
||||
llarp/handlers/exit.cpp
|
||||
llarp/handlers/null.cpp
|
||||
llarp/handlers/tun.cpp
|
||||
llarp/link/curvecp.cpp
|
||||
llarp/link/encoder.cpp
|
||||
llarp/link/iwp.cpp
|
||||
llarp/link/server.cpp
|
||||
llarp/link/session.cpp
|
||||
llarp/link/utp.cpp
|
||||
llarp/messages/dht.cpp
|
||||
llarp/messages/dht_immediate.cpp
|
||||
llarp/messages/discard.cpp
|
||||
llarp/messages/exit.cpp
|
||||
llarp/messages/link_intro.cpp
|
||||
llarp/messages/link_message.cpp
|
||||
llarp/messages/path_confirm.cpp
|
||||
llarp/messages/path_latency.cpp
|
||||
llarp/messages/path_transfer.cpp
|
||||
llarp/messages/relay.cpp
|
||||
llarp/messages/relay_commit.cpp
|
||||
llarp/messages/transfer_traffic.cpp
|
||||
llarp/net/address_info.cpp
|
||||
llarp/net/exit_info.cpp
|
||||
llarp/net/ip.cpp
|
||||
llarp/net/net_int.cpp
|
||||
llarp/nodedb.cpp
|
||||
llarp/path/path.cpp
|
||||
llarp/path/path_types.cpp
|
||||
llarp/path/pathbuilder.cpp
|
||||
llarp/path/pathset.cpp
|
||||
llarp/path/transit_hop.cpp
|
||||
llarp/pow.cpp
|
||||
llarp/profiling.cpp
|
||||
llarp/router/router.cpp
|
||||
llarp/router_contact.cpp
|
||||
llarp/router_id.cpp
|
||||
llarp/routing/dht_message.cpp
|
||||
llarp/routing/handler.cpp
|
||||
llarp/routing/message_parser.cpp
|
||||
llarp/routing/message.cpp
|
||||
llarp/routing/path_confirm.cpp
|
||||
llarp/routing/path_latency.cpp
|
||||
llarp/routing/path_transfer.cpp
|
||||
llarp/rpc/rpc.cpp
|
||||
llarp/service/Identity.cpp
|
||||
llarp/service/Intro.cpp
|
||||
llarp/service/IntroSet.cpp
|
||||
llarp/service/address.cpp
|
||||
llarp/service/config.cpp
|
||||
llarp/service/context.cpp
|
||||
llarp/service/endpoint.cpp
|
||||
llarp/service/handler.cpp
|
||||
llarp/service/info.cpp
|
||||
llarp/service/lookup.cpp
|
||||
llarp/service/protocol.cpp
|
||||
llarp/service/tag.cpp
|
||||
llarp/service/types.cpp
|
||||
llarp/service/vanity.cpp
|
||||
llarp/testnet.c
|
||||
)
|
||||
add_subdirectory(crypto)
|
||||
add_subdirectory(libutp)
|
||||
add_subdirectory(llarp)
|
||||
|
||||
set(RC_SRC
|
||||
daemon/rcutil.cpp
|
||||
|
@ -637,116 +315,23 @@ set(DNS_SRC
|
|||
daemon/dns.cpp
|
||||
)
|
||||
|
||||
set(TEST_SRC
|
||||
# helpers
|
||||
test/main.cpp
|
||||
test/crypto/mock_crypto.cpp
|
||||
test/dht/mock_context.cpp
|
||||
test/test_util.cpp
|
||||
# actual test cases
|
||||
test/crypto/test_llarp_crypto_types.cpp
|
||||
test/crypto/test_llarp_crypto.cpp
|
||||
test/dht/test_llarp_dht_bucket.cpp
|
||||
test/dht/test_llarp_dht_explorenetworkjob.cpp
|
||||
test/dht/test_llarp_dht_kademlia.cpp
|
||||
test/dht/test_llarp_dht_key.cpp
|
||||
test/dht/test_llarp_dht_node.cpp
|
||||
test/dht/test_llarp_dht_serviceaddresslookup.cpp
|
||||
test/dht/test_llarp_dht_taglookup.cpp
|
||||
test/dht/test_llarp_dht_tx.cpp
|
||||
test/dht/test_llarp_dht_txowner.cpp
|
||||
test/dns/test_llarp_dns_dns.cpp
|
||||
test/exit/test_llarp_exit_context.cpp
|
||||
test/link/test_llarp_link.cpp
|
||||
test/net/test_llarp_net_inaddr.cpp
|
||||
test/net/test_llarp_net.cpp
|
||||
test/routing/llarp_routing_transfer_traffic.cpp
|
||||
test/routing/test_llarp_routing_obtainexitmessage.cpp
|
||||
test/service/test_llarp_service_address.cpp
|
||||
test/service/test_llarp_service_identity.cpp
|
||||
test/test_llarp_dns.cpp
|
||||
test/test_llarp_dnsd.cpp
|
||||
test/test_llarp_encrypted_frame.cpp
|
||||
test/test_llarp_router_contact.cpp
|
||||
test/test_llarp_router.cpp
|
||||
test/util/test_llarp_util_aligned.cpp
|
||||
test/util/test_llarp_util_bencode.cpp
|
||||
test/util/test_llarp_util_bits.cpp
|
||||
test/util/test_llarp_util_encode.cpp
|
||||
test/util/test_llarp_util_ini.cpp
|
||||
test/util/test_llarp_util_queue_manager.cpp
|
||||
test/util/test_llarp_util_queue.cpp
|
||||
test/util/test_llarp_util_thread_pool.cpp
|
||||
)
|
||||
|
||||
set(TEST_EXE testAll)
|
||||
set(GTEST_DIR test/gtest)
|
||||
set(CLIENT_EXE llarpc)
|
||||
|
||||
set(CLIENT_SRC
|
||||
client/main.cpp
|
||||
)
|
||||
|
||||
include_directories(include)
|
||||
# TODO: exclude this from includes and expose stuff properly for rcutil
|
||||
include_directories(llarp)
|
||||
#include_directories(include)
|
||||
#include_directories(vendor/cppbackport-master/lib)
|
||||
#include_directories(${sodium_INCLUDE_DIR})
|
||||
|
||||
set(RC_EXE rcutil)
|
||||
set(DNS_EXE dns)
|
||||
set(ALL_SRC ${CLIENT_SRC} ${RC_SRC} ${EXE_SRC} ${DNS_SRC} ${LIB_PLATFORM_SRC} ${LIB_SRC} ${TEST_SRC})
|
||||
|
||||
if(USE_LIBABYSS)
|
||||
add_definitions(-DUSE_ABYSS=1)
|
||||
set(ABYSS libabyss)
|
||||
set(ABYSS_LIB abyss)
|
||||
set(ABYSS_EXE ${ABYSS_LIB}-main)
|
||||
include_directories(${ABYSS}/include)
|
||||
set(ABYSS_SRC
|
||||
${ABYSS}/src/http.cpp
|
||||
${ABYSS}/src/client.cpp
|
||||
${ABYSS}/src/server.cpp
|
||||
${ABYSS}/src/json.cpp)
|
||||
add_library(${ABYSS_LIB} STATIC ${ABYSS_SRC})
|
||||
set(ALL_SRC ${ALL_SRC} ${ABYSS_SRC} ${ABYSS}/main.cpp)
|
||||
if (NOT WIN32)
|
||||
add_executable(${ABYSS_EXE} ${ABYSS}/main.cpp)
|
||||
target_link_libraries(${ABYSS_EXE} ${STATIC_LIB} ${UTIL_LIB} ${PLATFORM_LIB} Threads::Threads)
|
||||
else()
|
||||
add_executable(${ABYSS_EXE} ${ABYSS}/main.cpp llarp/win32/abyss.rc)
|
||||
target_link_libraries(${ABYSS_EXE} ${STATIC_LIB} ${UTIL_LIB} ${PLATFORM_LIB} ws2_32 iphlpapi Threads::Threads)
|
||||
endif(NOT WIN32)
|
||||
|
||||
set(TEST_SRC ${TEST_SRC} test/test_libabyss.cpp)
|
||||
# for freebsd
|
||||
if(${CMAKE_SYSTEM_NAME} MATCHES "FreeBSD")
|
||||
include_directories(/usr/local/include)
|
||||
endif(${CMAKE_SYSTEM_NAME} MATCHES "FreeBSD")
|
||||
endif(USE_LIBABYSS)
|
||||
set(ALL_SRC ${RC_SRC} ${EXE_SRC} ${DNS_SRC} ${LIB_PLATFORM_SRC} ${LIB_SRC})
|
||||
|
||||
foreach(F ${ALL_SRC})
|
||||
set_source_files_properties(${F} PROPERTIES COMPILE_FLAGS -DLOG_TAG=\\\"${F}\\\")
|
||||
set_source_files_properties(${F} PROPERTIES COMPILE_FLAGS -DLOG_TAG=\\\"${F}\\\")
|
||||
endforeach(F)
|
||||
|
||||
if(SHADOW)
|
||||
add_shadow_plugin(shadow-plugin-${SHARED_LIB} ${EXE_SRC} ${LIB_SRC} ${LIB_PLATFORM_SRC} ${CPP_BACKPORT_SRC} ${ABYSS_SRC} ${CRYPTOGRAPHY_SRC})
|
||||
add_shadow_plugin(shadow-plugin-${SHARED_LIB} ${EXE_SRC} ${LIB_SRC} ${UTP_SRC} ${LIB_PLATFORM_SRC} ${CPP_BACKPORT_SRC} ${ABYSS_SRC} ${CRYPTOGRAPHY_SRC})
|
||||
target_link_libraries(shadow-plugin-${SHARED_LIB} ${LIBS})
|
||||
install(TARGETS shadow-plugin-${SHARED_LIB} DESTINATION plugins)
|
||||
else()
|
||||
add_subdirectory(${GTEST_DIR})
|
||||
if(NOT WIN32)
|
||||
add_executable(${TEST_EXE} ${TEST_SRC})
|
||||
add_executable(${EXE} ${EXE_SRC})
|
||||
else()
|
||||
add_executable(${TEST_EXE} ${TEST_SRC} llarp/win32/test.rc)
|
||||
add_executable(${EXE} ${EXE_SRC} llarp/win32/version.rc)
|
||||
endif(NOT WIN32)
|
||||
|
||||
target_include_directories(${TEST_EXE} PRIVATE test)
|
||||
target_include_directories(${TEST_EXE} PRIVATE ${GTEST_DIR}/include ${GTEST_DIR})
|
||||
|
||||
install(TARGETS ${EXE} RUNTIME DESTINATION bin)
|
||||
if(WIN32)
|
||||
install(PROGRAMS ${CMAKE_SOURCE_DIR}/lokinet-bootstrap.exe DESTINATION bin)
|
||||
|
@ -758,24 +343,6 @@ else()
|
|||
install(CODE "execute_process(COMMAND setcap cap_net_admin,cap_net_bind_service=+eip ${CMAKE_INSTALL_PREFIX}/bin/lokinet)")
|
||||
endif(${CMAKE_SYSTEM_NAME} MATCHES "Linux")
|
||||
|
||||
add_library(${STATIC_LIB} STATIC ${LIB_SRC})
|
||||
add_library(${UTIL_LIB} STATIC ${LIB_UTIL_SRC})
|
||||
|
||||
# cut back on fluff
|
||||
if (NOT WIN32)
|
||||
target_link_libraries(${UTIL_LIB} absl::optional)
|
||||
else()
|
||||
target_link_libraries(${UTIL_LIB})
|
||||
endif(NOT WIN32)
|
||||
|
||||
add_library(${PLATFORM_LIB} STATIC ${LIB_PLATFORM_SRC})
|
||||
|
||||
if(USE_LIBABYSS)
|
||||
target_link_libraries(${PLATFORM_LIB} ${UTIL_LIB} Threads::Threads ${ABYSS_LIB})
|
||||
else()
|
||||
target_link_libraries(${PLATFORM_LIB} ${UTIL_LIB} Threads::Threads)
|
||||
endif(USE_LIBABYSS)
|
||||
|
||||
if(${CMAKE_SYSTEM_NAME} MATCHES "Linux")
|
||||
if(NON_PC_TARGET)
|
||||
target_link_libraries(${PLATFORM_LIB} -lrt)
|
||||
|
@ -784,13 +351,10 @@ endif(NOT WIN32)
|
|||
endif(NON_PC_TARGET)
|
||||
endif(${CMAKE_SYSTEM_NAME} MATCHES "Linux")
|
||||
|
||||
target_link_libraries(${STATIC_LIB} ${CRYPTOGRAPHY_LIB} ${LIBS} ${UTIL_LIB} ${PLATFORM_LIB})
|
||||
if (WIN32)
|
||||
target_link_libraries(${EXE} ${STATIC_LINK_LIBS} ${STATIC_LIB} ${UTIL_LIB} ${PLATFORM_LIB} ws2_32 iphlpapi)
|
||||
target_link_libraries(${TEST_EXE} ${STATIC_LINK_LIBS} gmock gtest ${STATIC_LIB} ${UTIL_LIB} ${PLATFORM_LIB} ws2_32 iphlpapi)
|
||||
target_link_libraries(${EXE} ${STATIC_LIB} ws2_32 iphlpapi)
|
||||
else()
|
||||
target_link_libraries(${EXE} ${STATIC_LINK_LIBS} ${STATIC_LIB} ${UTIL_LIB} ${PLATFORM_LIB})
|
||||
target_link_libraries(${TEST_EXE} ${STATIC_LINK_LIBS} gmock gtest absl::variant ${STATIC_LIB} ${UTIL_LIB} ${PLATFORM_LIB})
|
||||
target_link_libraries(${EXE} ${STATIC_LIB} cppbackport libutp)
|
||||
endif(WIN32)
|
||||
|
||||
|
||||
|
@ -804,8 +368,45 @@ endif(NOT WIN32)
|
|||
if (WIN32)
|
||||
target_link_libraries(${SHARED_LIB} ${CRYPTOGRAPHY_LIB} ${LIBS} ${UTIL_LIB} ${PLATFORM_LIB} ws2_32 iphlpapi Threads::Threads)
|
||||
else (NOT WIN32)
|
||||
target_link_libraries(${SHARED_LIB} ${CRYPTOGRAPHY_LIB} ${LIBS} ${UTIL_LIB} ${PLATFORM_LIB} Threads::Threads)
|
||||
target_link_libraries(${SHARED_LIB} ${CRYPTOGRAPHY_LIB} ${LIBS} ${UTIL_LIB} libutp ${PLATFORM_LIB} Threads::Threads)
|
||||
install(TARGETS ${SHARED_LIB} LIBRARY DESTINATION lib)
|
||||
endif(WIN32)
|
||||
endif(WITH_SHARED)
|
||||
endif(SHADOW)
|
||||
|
||||
if(USE_LIBABYSS)
|
||||
add_definitions(-DUSE_ABYSS=1)
|
||||
set(ABYSS libabyss)
|
||||
set(ABYSS_LIB abyss)
|
||||
set(ABYSS_EXE ${ABYSS_LIB}-main)
|
||||
set(ABYSS_SRC
|
||||
${ABYSS}/src/http.cpp
|
||||
${ABYSS}/src/client.cpp
|
||||
${ABYSS}/src/server.cpp
|
||||
${ABYSS}/src/json.cpp)
|
||||
add_library(${ABYSS_LIB} OBJECT ${ABYSS_SRC})
|
||||
target_link_libraries(${ABYSS_LIB} PUBLIC ${PLATFORM_LIB})
|
||||
list(APPEND ALL_SRC ${ABYSS_SRC} ${ABYSS}/main.cpp)
|
||||
|
||||
if (NOT WIN32)
|
||||
add_executable(${ABYSS_EXE} ${ABYSS}/main.cpp)
|
||||
else()
|
||||
add_executable(${ABYSS_EXE} ${ABYSS}/main.cpp llarp/win32/abyss.rc)
|
||||
target_link_libraries(${ABYSS_EXE} ws2_32 iphlpapi)
|
||||
endif(NOT WIN32)
|
||||
|
||||
target_link_libraries(${ABYSS_EXE} PUBLIC ${ABYSS_LIB} ${STATIC_LIB} Threads::Threads)
|
||||
target_include_directories(${ABYSS_EXE} PUBLIC "${CMAKE_CURRENT_SOURCE_DIR}/${ABYSS}/include")
|
||||
target_include_directories(${ABYSS_LIB} PUBLIC "${CMAKE_CURRENT_SOURCE_DIR}/${ABYSS}/include")
|
||||
|
||||
# for freebsd
|
||||
if(${CMAKE_SYSTEM_NAME} MATCHES "FreeBSD")
|
||||
target_include_directories(${ABYSS_LIB} /usr/local/include)
|
||||
endif(${CMAKE_SYSTEM_NAME} MATCHES "FreeBSD")
|
||||
endif(USE_LIBABYSS)
|
||||
|
||||
enable_testing()
|
||||
|
||||
if (NOT SHADOW)
|
||||
add_subdirectory(test)
|
||||
endif()
|
||||
|
|
|
@ -0,0 +1,115 @@
|
|||
set(NTRU_AVX_SRC
|
||||
libntrup/src/avx/randomsmall.c
|
||||
libntrup/src/avx/weight.c
|
||||
libntrup/src/avx/swap.c
|
||||
libntrup/src/avx/rq_round3.c
|
||||
libntrup/src/avx/rq_recip3.c
|
||||
libntrup/src/avx/small.c
|
||||
libntrup/src/avx/randomweightw.c
|
||||
libntrup/src/avx/dec.c
|
||||
libntrup/src/avx/r3_recip.c
|
||||
libntrup/src/avx/keypair.c
|
||||
libntrup/src/avx/rq_rounded.c
|
||||
libntrup/src/avx/mult.c
|
||||
libntrup/src/avx/enc.c
|
||||
libntrup/src/avx/int32_sort.c
|
||||
libntrup/src/avx/rq.c
|
||||
libntrup/src/avx/rq_mod3.c
|
||||
)
|
||||
|
||||
set(NTRU_REF_SRC
|
||||
libntrup/src/ref/randomsmall.c
|
||||
libntrup/src/ref/swap.c
|
||||
libntrup/src/ref/rq_round3.c
|
||||
libntrup/src/ref/rq_recip3.c
|
||||
libntrup/src/ref/small.c
|
||||
libntrup/src/ref/rq_mult.c
|
||||
libntrup/src/ref/randomweightw.c
|
||||
libntrup/src/ref/random32.c
|
||||
libntrup/src/ref/dec.c
|
||||
libntrup/src/ref/r3_mult.c
|
||||
libntrup/src/ref/r3_recip.c
|
||||
libntrup/src/ref/keypair.c
|
||||
libntrup/src/ref/rq_rounded.c
|
||||
libntrup/src/ref/enc.c
|
||||
libntrup/src/ref/int32_sort.c
|
||||
libntrup/src/ref/rq.c
|
||||
)
|
||||
|
||||
set(NTRU_SRC
|
||||
${NTRU_AVX_SRC}
|
||||
${NTRU_REF_SRC}
|
||||
libntrup/src/ntru.cpp
|
||||
)
|
||||
|
||||
set(SHA512_SRC
|
||||
sha512/sha512.c)
|
||||
|
||||
set(CHACHA_SRC
|
||||
chacha20/ref/chacha20_ref.c
|
||||
chacha20/dolbeau/chacha20_dolbeau-ssse3.c
|
||||
chacha20/dolbeau/chacha20_dolbeau-avx2.c
|
||||
chacha20/stream_chacha20.c
|
||||
salsa20/ref/salsa20_ref.c
|
||||
salsa20/core_salsa_ref.c
|
||||
salsa20/stream_salsa20.c
|
||||
salsa20/xmm6/salsa20_xmm6-asm.S
|
||||
salsa20/xmm6/salsa20_xmm6.c
|
||||
salsa20/xmm6int/salsa20_xmm6int-avx2.c
|
||||
salsa20/xmm6int/salsa20_xmm6int-sse2.c
|
||||
xchacha20/hchacha.c
|
||||
xchacha20/stream_xchacha20.c)
|
||||
|
||||
set(CSRNG_SRC
|
||||
csrng/randombytes_salsa20_random.c
|
||||
csrng/randombytes.c)
|
||||
|
||||
set(CRYPTO_MEM_SRC
|
||||
secmem/secmem.c)
|
||||
|
||||
set(BLAKE2B_SRC
|
||||
blake2b/blake2b-compress-avx2.c
|
||||
blake2b/blake2b-compress-ref.c
|
||||
blake2b/blake2b-compress-sse41.c
|
||||
blake2b/blake2b-compress-ssse3.c
|
||||
blake2b/blake2b-ref.c
|
||||
blake2b/generichash_blake2b.c)
|
||||
|
||||
set(X25519_SRC
|
||||
curve25519/crypto_scalarmult.c
|
||||
curve25519/ref10/x25519_ref10.c
|
||||
curve25519/ref10/ed25519_ref10.c
|
||||
curve25519/sandy2x/fe51_invert.c
|
||||
curve25519/sandy2x/ladder_base.S
|
||||
curve25519/sandy2x/curve25519_sandy2x.c
|
||||
curve25519/sandy2x/consts.S
|
||||
curve25519/sandy2x/fe51_nsquare.S
|
||||
curve25519/sandy2x/fe51_mul.S
|
||||
curve25519/sandy2x/fe51_pack.S
|
||||
curve25519/sandy2x/fe_frombytes_sandy2x.c
|
||||
curve25519/sandy2x/sandy2x.S
|
||||
curve25519/sandy2x/ladder.S
|
||||
curve25519/scalarmult_curve25519.c
|
||||
ed25519/crypto_box.c
|
||||
ed25519/crypto_sign.c
|
||||
ed25519/ref10/open.c
|
||||
ed25519/ref10/obsolete.c
|
||||
ed25519/ref10/keypair.c
|
||||
ed25519/ref10/sign.c
|
||||
ed25519/sign_ed25519.c)
|
||||
|
||||
set(CRYPTOGRAPHY_SRC
|
||||
libsodium/init.c
|
||||
libsodium/runtime.c
|
||||
verify/crypto_verify.c
|
||||
${CRYPTO_MEM_SRC}
|
||||
${CSRNG_SRC}
|
||||
${BLAKE2B_SRC}
|
||||
${CHACHA_SRC}
|
||||
${ED25519_SRC}
|
||||
${X25519_SRC}
|
||||
${SHA512_SRC}
|
||||
${NTRU_SRC})
|
||||
|
||||
add_library(${CRYPTOGRAPHY_LIB} STATIC ${CRYPTOGRAPHY_SRC})
|
||||
target_include_directories (${CRYPTOGRAPHY_LIB} PUBLIC "${CMAKE_CURRENT_SOURCE_DIR}/include")
|
|
@ -0,0 +1,15 @@
|
|||
set(UTP_SRC
|
||||
utp_callbacks.cpp
|
||||
utp_utils.cpp
|
||||
utp_internal.cpp
|
||||
utp_api.cpp
|
||||
utp_packedsockaddr.cpp
|
||||
utp_hash.cpp
|
||||
)
|
||||
|
||||
if(WIN32)
|
||||
list(APPEND UTP_SRC libutp_inet_ntop.cpp)
|
||||
endif(WIN32)
|
||||
|
||||
add_library(libutp OBJECT ${UTP_SRC})
|
||||
target_include_directories(libutp PUBLIC ${CMAKE_CURRENT_SOURCE_DIR} ${CORE_INCLUDE})
|
|
@ -0,0 +1,190 @@
|
|||
set(LIB_UTIL_SRC
|
||||
constants/defaults.cpp
|
||||
constants/link_layer.cpp
|
||||
constants/proto.cpp
|
||||
constants/version.cpp
|
||||
util/aligned.cpp
|
||||
util/bencode.cpp
|
||||
util/bits.cpp
|
||||
util/buffer.cpp
|
||||
util/codel.cpp
|
||||
util/common.cpp
|
||||
util/encode.cpp
|
||||
util/endian.cpp
|
||||
util/fs.cpp
|
||||
util/ini.cpp
|
||||
util/logger.c
|
||||
util/logger.cpp
|
||||
util/logic.cpp
|
||||
util/mem.cpp
|
||||
util/queue_manager.cpp
|
||||
util/queue.cpp
|
||||
util/str.cpp
|
||||
util/string_view.cpp
|
||||
util/thread_pool.cpp
|
||||
util/threading.cpp
|
||||
util/threadpool.cpp
|
||||
util/time.cpp
|
||||
util/timer.cpp
|
||||
util/types.cpp
|
||||
)
|
||||
|
||||
add_library(${UTIL_LIB} STATIC ${LIB_UTIL_SRC})
|
||||
target_include_directories(${UTIL_LIB} PUBLIC ${CMAKE_CURRENT_SOURCE_DIR})
|
||||
target_link_libraries(${UTIL_LIB} cppbackport)
|
||||
|
||||
# cut back on fluff
|
||||
if (NOT WIN32)
|
||||
target_link_libraries(${UTIL_LIB} absl::optional)
|
||||
endif(NOT WIN32)
|
||||
|
||||
set(LIB_PLATFORM_SRC
|
||||
# for networking
|
||||
ev/ev.cpp
|
||||
net/net.cpp
|
||||
net/net_addr.cpp
|
||||
net/net_inaddr.cpp
|
||||
# for android shim
|
||||
${ANDROID_PLATFORM_SRC}
|
||||
# process isolation implementation
|
||||
${ISOLATE_PROC_SRC}
|
||||
# tun
|
||||
${LIBTUNTAP_SRC}
|
||||
${EV_SRC}
|
||||
# win32 inline code
|
||||
win32/win32_inet.c
|
||||
win32/win32_intrnl.c
|
||||
win32/win32_upoll.c
|
||||
)
|
||||
|
||||
add_library(${PLATFORM_LIB} STATIC ${LIB_PLATFORM_SRC})
|
||||
target_link_libraries(${PLATFORM_LIB} PUBLIC ${CRYPTOGRAPHY_LIB} ${UTIL_LIB} libutp cppbackport Threads::Threads)
|
||||
|
||||
if(USE_LIBABYSS)
|
||||
target_link_libraries(${PLATFORM_LIB} ${ABYSS_LIB})
|
||||
endif()
|
||||
|
||||
set(DNSLIB_SRC
|
||||
dns/dotlokilookup.cpp
|
||||
dns/dns.cpp
|
||||
dns/iptracker.cpp
|
||||
dns/message.cpp
|
||||
dns/name.cpp
|
||||
dns/query.cpp
|
||||
dns/question.cpp
|
||||
dns/rectypes.cpp
|
||||
dns/rr.cpp
|
||||
dns/serialize.cpp
|
||||
dns/server.cpp
|
||||
dns/string.cpp
|
||||
)
|
||||
|
||||
set(LIB_SRC
|
||||
${DNSLIB_SRC}
|
||||
config.cpp
|
||||
context.cpp
|
||||
crypto/constants.cpp
|
||||
crypto/crypto_libsodium.cpp
|
||||
crypto/crypto.cpp
|
||||
crypto/encrypted_frame.cpp
|
||||
crypto/encrypted.cpp
|
||||
crypto/types.cpp
|
||||
dht/bucket.cpp
|
||||
dht/context.cpp
|
||||
dht/dht.cpp
|
||||
dht/explorenetworkjob.cpp
|
||||
dht/kademlia.cpp
|
||||
dht/key.cpp
|
||||
dht/localtaglookup.cpp
|
||||
dht/localrouterlookup.cpp
|
||||
dht/localserviceaddresslookup.cpp
|
||||
dht/message.cpp
|
||||
dht/messages/findintro.cpp
|
||||
dht/messages/findrouter.cpp
|
||||
dht/messages/gotintro.cpp
|
||||
dht/messages/gotrouter.cpp
|
||||
dht/messages/pubintro.cpp
|
||||
dht/node.cpp
|
||||
dht/publishservicejob.cpp
|
||||
dht/recursiverouterlookup.cpp
|
||||
dht/serviceaddresslookup.cpp
|
||||
dht/taglookup.cpp
|
||||
dht/tx.cpp
|
||||
dht/txholder.cpp
|
||||
dht/txowner.cpp
|
||||
dns.cpp
|
||||
dnsc.cpp
|
||||
dnsd.cpp
|
||||
exit/close_exit.cpp
|
||||
exit/context.cpp
|
||||
exit/endpoint.cpp
|
||||
exit/grant_exit.cpp
|
||||
exit/obtain_exit.cpp
|
||||
exit/policy.cpp
|
||||
exit/reject_exit.cpp
|
||||
exit/session.cpp
|
||||
exit/transfer_traffic.cpp
|
||||
exit/update_exit.cpp
|
||||
handlers/exit.cpp
|
||||
handlers/null.cpp
|
||||
handlers/tun.cpp
|
||||
link/curvecp.cpp
|
||||
link/encoder.cpp
|
||||
link/iwp.cpp
|
||||
link/server.cpp
|
||||
link/session.cpp
|
||||
link/utp.cpp
|
||||
messages/dht.cpp
|
||||
messages/dht_immediate.cpp
|
||||
messages/discard.cpp
|
||||
messages/exit.cpp
|
||||
messages/link_intro.cpp
|
||||
messages/link_message.cpp
|
||||
messages/path_confirm.cpp
|
||||
messages/path_latency.cpp
|
||||
messages/path_transfer.cpp
|
||||
messages/relay.cpp
|
||||
messages/relay_commit.cpp
|
||||
messages/transfer_traffic.cpp
|
||||
net/address_info.cpp
|
||||
net/exit_info.cpp
|
||||
net/ip.cpp
|
||||
net/net_int.cpp
|
||||
nodedb.cpp
|
||||
path/path.cpp
|
||||
path/path_types.cpp
|
||||
path/pathbuilder.cpp
|
||||
path/pathset.cpp
|
||||
path/transit_hop.cpp
|
||||
pow.cpp
|
||||
profiling.cpp
|
||||
router/router.cpp
|
||||
router_contact.cpp
|
||||
router_id.cpp
|
||||
routing/dht_message.cpp
|
||||
routing/handler.cpp
|
||||
routing/message_parser.cpp
|
||||
routing/message.cpp
|
||||
routing/path_confirm.cpp
|
||||
routing/path_latency.cpp
|
||||
routing/path_transfer.cpp
|
||||
rpc/rpc.cpp
|
||||
service/Identity.cpp
|
||||
service/Intro.cpp
|
||||
service/IntroSet.cpp
|
||||
service/address.cpp
|
||||
service/config.cpp
|
||||
service/context.cpp
|
||||
service/endpoint.cpp
|
||||
service/handler.cpp
|
||||
service/info.cpp
|
||||
service/lookup.cpp
|
||||
service/protocol.cpp
|
||||
service/tag.cpp
|
||||
service/types.cpp
|
||||
service/vanity.cpp
|
||||
testnet.c
|
||||
)
|
||||
|
||||
add_library(${STATIC_LIB} STATIC ${LIB_SRC})
|
||||
target_link_libraries(${STATIC_LIB} PUBLIC ${PLATFORM_LIB} ${UTIL_LIB} ${CRYPTOGRAPHY_LIB} cppbackport libutp ${LIBS})
|
|
@ -0,0 +1,102 @@
|
|||
set(TEST_EXE testAll)
|
||||
set(GTEST_DIR gtest)
|
||||
add_subdirectory(${GTEST_DIR})
|
||||
|
||||
set(TEST_SRC
|
||||
# helpers
|
||||
main.cpp
|
||||
crypto/mock_crypto.cpp
|
||||
dht/mock_context.cpp
|
||||
test_util.cpp
|
||||
# actual test cases
|
||||
crypto/test_llarp_crypto_types.cpp
|
||||
crypto/test_llarp_crypto.cpp
|
||||
dht/test_llarp_dht_bucket.cpp
|
||||
dht/test_llarp_dht_explorenetworkjob.cpp
|
||||
dht/test_llarp_dht_kademlia.cpp
|
||||
dht/test_llarp_dht_key.cpp
|
||||
dht/test_llarp_dht_node.cpp
|
||||
dht/test_llarp_dht_serviceaddresslookup.cpp
|
||||
dht/test_llarp_dht_taglookup.cpp
|
||||
dht/test_llarp_dht_tx.cpp
|
||||
dht/test_llarp_dht_txowner.cpp
|
||||
dns/test_llarp_dns_dns.cpp
|
||||
exit/test_llarp_exit_context.cpp
|
||||
link/test_llarp_link.cpp
|
||||
net/test_llarp_net_inaddr.cpp
|
||||
net/test_llarp_net.cpp
|
||||
routing/llarp_routing_transfer_traffic.cpp
|
||||
routing/test_llarp_routing_obtainexitmessage.cpp
|
||||
service/test_llarp_service_address.cpp
|
||||
service/test_llarp_service_identity.cpp
|
||||
test_llarp_dns.cpp
|
||||
test_llarp_dnsd.cpp
|
||||
test_llarp_encrypted_frame.cpp
|
||||
test_llarp_router_contact.cpp
|
||||
test_llarp_router.cpp
|
||||
util/test_llarp_util_aligned.cpp
|
||||
util/test_llarp_util_bencode.cpp
|
||||
util/test_llarp_util_bits.cpp
|
||||
util/test_llarp_util_encode.cpp
|
||||
util/test_llarp_util_ini.cpp
|
||||
util/test_llarp_util_queue_manager.cpp
|
||||
util/test_llarp_util_queue.cpp
|
||||
util/test_llarp_util_thread_pool.cpp
|
||||
)
|
||||
|
||||
add_executable(${TEST_EXE}
|
||||
# helpers
|
||||
main.cpp
|
||||
crypto/mock_crypto.cpp
|
||||
dht/mock_context.cpp
|
||||
test_util.cpp
|
||||
# actual test cases
|
||||
crypto/test_llarp_crypto_types.cpp
|
||||
crypto/test_llarp_crypto.cpp
|
||||
dht/test_llarp_dht_bucket.cpp
|
||||
dht/test_llarp_dht_explorenetworkjob.cpp
|
||||
dht/test_llarp_dht_kademlia.cpp
|
||||
dht/test_llarp_dht_key.cpp
|
||||
dht/test_llarp_dht_node.cpp
|
||||
dht/test_llarp_dht_serviceaddresslookup.cpp
|
||||
dht/test_llarp_dht_taglookup.cpp
|
||||
dht/test_llarp_dht_tx.cpp
|
||||
dht/test_llarp_dht_txowner.cpp
|
||||
dns/test_llarp_dns_dns.cpp
|
||||
exit/test_llarp_exit_context.cpp
|
||||
link/test_llarp_link.cpp
|
||||
net/test_llarp_net_inaddr.cpp
|
||||
net/test_llarp_net.cpp
|
||||
routing/llarp_routing_transfer_traffic.cpp
|
||||
routing/test_llarp_routing_obtainexitmessage.cpp
|
||||
service/test_llarp_service_address.cpp
|
||||
service/test_llarp_service_identity.cpp
|
||||
test_llarp_dns.cpp
|
||||
test_llarp_dnsd.cpp
|
||||
test_llarp_encrypted_frame.cpp
|
||||
test_llarp_router_contact.cpp
|
||||
test_llarp_router.cpp
|
||||
util/test_llarp_util_aligned.cpp
|
||||
util/test_llarp_util_bencode.cpp
|
||||
util/test_llarp_util_bits.cpp
|
||||
util/test_llarp_util_encode.cpp
|
||||
util/test_llarp_util_ini.cpp
|
||||
util/test_llarp_util_queue_manager.cpp
|
||||
util/test_llarp_util_queue.cpp
|
||||
util/test_llarp_util_thread_pool.cpp)
|
||||
|
||||
target_link_libraries(${TEST_EXE} PUBLIC gmock gtest ${STATIC_LIB})
|
||||
target_include_directories(${TEST_EXE} PRIVATE ${CMAKE_CURRENT_SOURCE_DIR})
|
||||
|
||||
if(NOT WIN32)
|
||||
target_link_libraries(${TEST_EXE} PUBLIC absl::variant)
|
||||
else()
|
||||
target_sources(${TEST_EXE} PUBLIC "${CMAKE_CURRENT_SOURCE_DIR}/win32/test.rc")
|
||||
target_link_libraries(${TEST_EXE} PUBLIC ws2_32 iphlpapi)
|
||||
endif(NOT WIN32)
|
||||
|
||||
|
||||
if(USE_LIBABYSS)
|
||||
target_sources(${TEST_EXE} PUBLIC "${CMAKE_CURRENT_SOURCE_DIR}/test_libabyss.cpp")
|
||||
target_link_libraries(${TEST_EXE} PUBLIC ${ABYSS_LIB})
|
||||
endif()
|
|
@ -0,0 +1,21 @@
|
|||
set(CXX_COMPAT_SRC
|
||||
cppbackport-master/lib/fs/rename.cpp
|
||||
cppbackport-master/lib/fs/filestatus.cpp
|
||||
cppbackport-master/lib/fs/filetype.cpp
|
||||
cppbackport-master/lib/fs/cleanpath.cpp
|
||||
cppbackport-master/lib/fs/perms.cpp
|
||||
cppbackport-master/lib/fs/equivalent.cpp
|
||||
cppbackport-master/lib/fs/current_path.cpp
|
||||
cppbackport-master/lib/fs/basename.cpp
|
||||
cppbackport-master/lib/fs/tempdir.cpp
|
||||
cppbackport-master/lib/fs/create_directory.cpp
|
||||
cppbackport-master/lib/fs/path.cpp
|
||||
cppbackport-master/lib/fs/remove.cpp
|
||||
cppbackport-master/lib/fs/diriter.cpp
|
||||
cppbackport-master/lib/fs/copyfile.cpp
|
||||
cppbackport-master/lib/fs/absolute.cpp
|
||||
cppbackport-master/lib/fs/direntry.cpp
|
||||
)
|
||||
|
||||
add_library(cppbackport OBJECT ${CXX_COMPAT_SRC})
|
||||
target_include_directories(cppbackport PUBLIC cppbackport-master/lib)
|
Loading…
Reference in New Issue