aboutsummaryrefslogtreecommitdiff
path: root/vcpkg/ports/liblsquic
diff options
context:
space:
mode:
Diffstat (limited to 'vcpkg/ports/liblsquic')
-rw-r--r--vcpkg/ports/liblsquic/disable-asan.patch23
-rw-r--r--vcpkg/ports/liblsquic/fix-found-boringssl.patch53
-rw-r--r--vcpkg/ports/liblsquic/portfile.cmake77
-rw-r--r--vcpkg/ports/liblsquic/vcpkg.json25
4 files changed, 178 insertions, 0 deletions
diff --git a/vcpkg/ports/liblsquic/disable-asan.patch b/vcpkg/ports/liblsquic/disable-asan.patch
new file mode 100644
index 0000000..2b05d0e
--- /dev/null
+++ b/vcpkg/ports/liblsquic/disable-asan.patch
@@ -0,0 +1,23 @@
+diff --git a/CMakeLists.txt b/CMakeLists.txt
+index 65c4776..5d4086a 100644
+--- a/CMakeLists.txt
++++ b/CMakeLists.txt
+@@ -60,12 +60,12 @@ ENDIF()
+
+ IF(CMAKE_BUILD_TYPE STREQUAL "Debug")
+ SET(MY_CMAKE_FLAGS "${MY_CMAKE_FLAGS} -O0 -g3")
+- IF(CMAKE_C_COMPILER MATCHES "clang" AND
+- NOT "$ENV{TRAVIS}" MATCHES "^true$" AND
+- NOT "$ENV{EXTRA_CFLAGS}" MATCHES "-fsanitize")
+- SET(MY_CMAKE_FLAGS "${MY_CMAKE_FLAGS} -fsanitize=address")
+- SET(LIBS ${LIBS} -fsanitize=address)
+- ENDIF()
++ # IF(CMAKE_C_COMPILER MATCHES "clang" AND
++ # NOT "$ENV{TRAVIS}" MATCHES "^true$" AND
++ # NOT "$ENV{EXTRA_CFLAGS}" MATCHES "-fsanitize")
++ # SET(MY_CMAKE_FLAGS "${MY_CMAKE_FLAGS} -fsanitize=address")
++ # SET(LIBS ${LIBS} -fsanitize=address)
++ # ENDIF()
+ # Uncomment to enable cleartext protocol mode (no crypto):
+ #SET (MY_CMAKE_FLAGS "${MY_CMAKE_FLAGS} -DLSQUIC_ENABLE_HANDSHAKE_DISABLE=1")
+ ELSE()
diff --git a/vcpkg/ports/liblsquic/fix-found-boringssl.patch b/vcpkg/ports/liblsquic/fix-found-boringssl.patch
new file mode 100644
index 0000000..a3a632c
--- /dev/null
+++ b/vcpkg/ports/liblsquic/fix-found-boringssl.patch
@@ -0,0 +1,53 @@
+diff --git a/CMakeLists.txt b/CMakeLists.txt
+index 5d4086a..e085a83 100644
+--- a/CMakeLists.txt
++++ b/CMakeLists.txt
+@@ -120,10 +120,12 @@ IF(CMAKE_BUILD_TYPE STREQUAL "Debug")
+ SET(MY_CMAKE_FLAGS "${MY_CMAKE_FLAGS} -Od")
+ #SET (MY_CMAKE_FLAGS "${MY_CMAKE_FLAGS} -DFIU_ENABLE=1")
+ #SET(LIBS ${LIBS} fiu)
++ SET(LIB_NAME ssld cryptod)
+ ELSE()
+ SET(MY_CMAKE_FLAGS "${MY_CMAKE_FLAGS} -Ox")
+ # Comment out the following line to compile out debug messages:
+ #SET(MY_CMAKE_FLAGS "${MY_CMAKE_FLAGS} -DLSQUIC_LOWEST_LOG_LEVEL=LSQ_LOG_INFO")
++ SET(LIB_NAME ssl crypto)
+ ENDIF()
+
+ ENDIF() #MSVC
+@@ -191,7 +193,7 @@ IF (NOT DEFINED BORINGSSL_LIB AND DEFINED BORINGSSL_DIR)
+ ELSE()
+
+
+- FOREACH(LIB_NAME ssl crypto)
++ FOREACH(LIB ${LIB_NAME})
+ # If BORINGSSL_LIB is defined, try find each lib. Otherwise, user should define BORINGSSL_LIB_ssl,
+ # BORINGSSL_LIB_crypto and so on explicitly. For example, including boringssl and lsquic both via
+ # add_subdirectory:
+@@ -201,20 +203,20 @@ ELSE()
+ # add_subdirectory(third_party/lsquic)
+ IF (DEFINED BORINGSSL_LIB)
+ IF (CMAKE_SYSTEM_NAME STREQUAL Windows)
+- FIND_LIBRARY(BORINGSSL_LIB_${LIB_NAME}
+- NAMES ${LIB_NAME}
++ FIND_LIBRARY(BORINGSSL_LIB_${LIB}
++ NAMES ${LIB}
+ PATHS ${BORINGSSL_LIB}
+ PATH_SUFFIXES Debug Release MinSizeRel RelWithDebInfo
+ NO_DEFAULT_PATH)
+ ELSE()
+- FIND_LIBRARY(BORINGSSL_LIB_${LIB_NAME}
+- NAMES lib${LIB_NAME}${LIB_SUFFIX}
++ FIND_LIBRARY(BORINGSSL_LIB_${LIB}
++ NAMES lib${LI}${LIB_SUFFIX}
+ PATHS ${BORINGSSL_LIB}
+- PATH_SUFFIXES ${LIB_NAME}
++ PATH_SUFFIXES ${LIB}
+ NO_DEFAULT_PATH)
+ ENDIF()
+ ENDIF()
+- IF(BORINGSSL_LIB_${LIB_NAME})
++ IF(BORINGSSL_LIB_${LIB})
+ MESSAGE(STATUS "Found ${LIB_NAME} library: ${BORINGSSL_LIB_${LIB_NAME}}")
+ ELSE()
+ MESSAGE(FATAL_ERROR "BORINGSSL_LIB_${LIB_NAME} library not found")
diff --git a/vcpkg/ports/liblsquic/portfile.cmake b/vcpkg/ports/liblsquic/portfile.cmake
new file mode 100644
index 0000000..f2568e9
--- /dev/null
+++ b/vcpkg/ports/liblsquic/portfile.cmake
@@ -0,0 +1,77 @@
+if(VCPKG_TARGET_IS_WINDOWS)
+ # The lib uses CMAKE_WINDOWS_EXPORT_ALL_SYMBOLS, at least until
+ # https://github.com/litespeedtech/lsquic/pull/371 or similar is merged
+ vcpkg_check_linkage(ONLY_STATIC_LIBRARY)
+endif()
+
+vcpkg_from_github(OUT_SOURCE_PATH SOURCE_PATH
+ REPO litespeedtech/lsquic
+ REF v${VERSION}
+ SHA512 40d742779bfa2dc6fdaf0ee8e9349498d373dcffcc6dd27867c18d87309a288ea6811d693043b5d98364d816b818b49445214497475844201241193c0f37b349
+ HEAD_REF master
+ PATCHES
+ disable-asan.patch
+ fix-found-boringssl.patch
+)
+
+# Submodules
+vcpkg_from_github(OUT_SOURCE_PATH LSQPACK_SOURCE_PATH
+ REPO litespeedtech/ls-qpack
+ REF v2.5.3
+ HEAD_REF master
+ SHA512 f90502c763abc84532f33d1b8f952aea7869e4e0c5f6bd344532ddd51c4a180958de4086d88b9ec96673a059c806eec9e70007651d4d4e1a73395919dee47ce0
+)
+if(NOT EXISTS "${SOURCE_PATH}/src/ls-hpack/CMakeLists.txt")
+ file(REMOVE_RECURSE "${SOURCE_PATH}/src/liblsquic/ls-qpack")
+ file(RENAME "${LSQPACK_SOURCE_PATH}" "${SOURCE_PATH}/src/liblsquic/ls-qpack")
+endif()
+
+vcpkg_from_github(OUT_SOURCE_PATH LSHPACK_SOURCE_PATH
+ REPO litespeedtech/ls-hpack
+ REF v2.3.2
+ HEAD_REF master
+ SHA512 45d6c8296e8eee511e6a083f89460d5333fc9a49bc078dac55fdec6c46db199de9f150379f02e054571f954a5e3c79af3864dbc53dc57d10a8d2ed26a92d4278
+)
+if(NOT EXISTS "${SOURCE_PATH}/src/lshpack/CMakeLists.txt")
+ file(REMOVE_RECURSE "${SOURCE_PATH}/src/lshpack")
+ file(RENAME "${LSHPACK_SOURCE_PATH}" "${SOURCE_PATH}/src/lshpack")
+endif()
+
+# Configuration
+vcpkg_find_acquire_program(PERL)
+
+string(COMPARE EQUAL "${VCPKG_LIBRARY_LINKAGE}" "dynamic" LSQUIC_SHARED_LIB)
+
+vcpkg_cmake_configure(
+ SOURCE_PATH "${SOURCE_PATH}"
+ OPTIONS
+ "-DPERL=${PERL}"
+ "-DPERL_EXECUTABLE=${PERL}"
+ "-DLSQUIC_SHARED_LIB=${LSQUIC_SHARED_LIB}"
+ "-DBORINGSSL_INCLUDE=${CURRENT_INSTALLED_DIR}/include"
+ -DLSQUIC_BIN=OFF
+ -DLSQUIC_TESTS=OFF
+ OPTIONS_RELEASE
+ "-DBORINGSSL_LIB=${CURRENT_INSTALLED_DIR}/lib"
+ OPTIONS_DEBUG
+ "-DBORINGSSL_LIB=${CURRENT_INSTALLED_DIR}/debug/lib"
+ -DLSQUIC_DEVEL=ON
+)
+
+vcpkg_cmake_install()
+if(VCPKG_TARGET_IS_WINDOWS)
+ # Upstream removed installation of this header after merging changes
+ file(INSTALL "${SOURCE_PATH}/wincompat/vc_compat.h" DESTINATION "${CURRENT_INSTALLED_DIR}/include/lsquic")
+endif()
+
+vcpkg_cmake_config_fixup(PACKAGE_NAME lsquic)
+
+# Concatenate license files and install
+vcpkg_install_copyright(FILE_LIST
+ "${SOURCE_PATH}/LICENSE"
+ "${SOURCE_PATH}/LICENSE.chrome"
+)
+
+# Remove duplicated include directory
+file(REMOVE_RECURSE "${CURRENT_PACKAGES_DIR}/debug/include")
+
diff --git a/vcpkg/ports/liblsquic/vcpkg.json b/vcpkg/ports/liblsquic/vcpkg.json
new file mode 100644
index 0000000..ec90032
--- /dev/null
+++ b/vcpkg/ports/liblsquic/vcpkg.json
@@ -0,0 +1,25 @@
+{
+ "name": "liblsquic",
+ "version": "3.3.2",
+ "port-version": 1,
+ "description": "An implementation of the QUIC and HTTP/3 protocols.",
+ "homepage": "https://github.com/litespeedtech/lsquic",
+ "license": "MIT AND BSD-3-Clause",
+ "supports": "!x86",
+ "dependencies": [
+ "boringssl",
+ {
+ "name": "getopt",
+ "platform": "windows"
+ },
+ {
+ "name": "vcpkg-cmake",
+ "host": true
+ },
+ {
+ "name": "vcpkg-cmake-config",
+ "host": true
+ },
+ "zlib"
+ ]
+}