aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRobert Schumacher <roschuma@microsoft.com>2016-11-26 01:54:56 -0800
committerRobert Schumacher <roschuma@microsoft.com>2016-11-26 01:54:56 -0800
commitc076567336cfd1f5e1ee8141cb74cf655f5394e1 (patch)
treed6c29cbc983aff0388d69c3a5533da95214b738b
parent7e4a57fbfd60ad0eb9cfce7d4db0160bdf6e9cc4 (diff)
parent431f5e12a3626ac522fb468e44b7b3549f2d2fe1 (diff)
downloadvcpkg-c076567336cfd1f5e1ee8141cb74cf655f5394e1.tar.gz
vcpkg-c076567336cfd1f5e1ee8141cb74cf655f5394e1.zip
Merge branch 'add-zstd-port' of https://github.com/saulthu/vcpkg into saulthu-add-zstd-port
-rw-r--r--ports/zstd/CONTROL3
-rw-r--r--ports/zstd/portfile.cmake64
2 files changed, 67 insertions, 0 deletions
diff --git a/ports/zstd/CONTROL b/ports/zstd/CONTROL
new file mode 100644
index 000000000..f92f610a4
--- /dev/null
+++ b/ports/zstd/CONTROL
@@ -0,0 +1,3 @@
+Source: zstd
+Version: 1.1.1
+Description: Zstandard - Fast real-time compression algorithm http://www.zstd.net
diff --git a/ports/zstd/portfile.cmake b/ports/zstd/portfile.cmake
new file mode 100644
index 000000000..7384e5461
--- /dev/null
+++ b/ports/zstd/portfile.cmake
@@ -0,0 +1,64 @@
+include(vcpkg_common_functions)
+set(SOURCE_PATH ${CURRENT_BUILDTREES_DIR}/src/zstd-1.1.1)
+vcpkg_download_distfile(ARCHIVE
+ URLS "https://github.com/facebook/zstd/archive/v1.1.1.zip"
+ FILENAME "zstd-1.1.1.zip"
+ SHA512 c96a97519202a759c62f661c7bbaeaa0d48e4e78588a8232ad23fd78fe7c3440f1f07d996dcf07daa652569e1c5e39cb7b93103b9ec7845db05b161ec29a8dde
+)
+vcpkg_extract_source_archive(${ARCHIVE})
+
+# Name dynamic libs to be non-versioned and simpler "zstd".
+# Avoid name conflict with static, so postfix static to "zstd-static"
+# This seems to be less painful than renaming a DLL file after creation.
+set(lib_cmake_filename ${SOURCE_PATH}/build/cmake/lib/CMakeLists.txt)
+if (NOT EXISTS ${lib_cmake_filename}.orig)
+ file(INSTALL ${SOURCE_PATH}/build/cmake/lib/CMakeLists.txt
+ DESTINATION ${SOURCE_PATH}/build/cmake/lib
+ RENAME CMakeLists.txt.orig)
+endif()
+file(READ "${lib_cmake_filename}" lib_cmake_content)
+string(REPLACE
+ "SET(SHARED_LIBRARY_OUTPUT_NAME \${LIBRARY_BASE_NAME}.\${LIBVER_MAJOR}.\${LIBVER_MINOR}.\${LIBVER_RELEASE})"
+ "SET(SHARED_LIBRARY_OUTPUT_NAME zstd)"
+ lib_cmake_content
+ "${lib_cmake_content}"
+)
+string(REPLACE
+ "SET(STATIC_LIBRARY_OUTPUT_NAME \${LIBRARY_BASE_NAME})"
+ "SET(STATIC_LIBRARY_OUTPUT_NAME zstd-static)"
+ lib_cmake_content
+ "${lib_cmake_content}"
+)
+file(WRITE "${lib_cmake_filename}" "${lib_cmake_content}")
+
+vcpkg_configure_cmake(
+ SOURCE_PATH ${SOURCE_PATH}/build/cmake
+ OPTIONS -DZSTD_LEGACY_SUPPORT=1
+)
+vcpkg_build_cmake()
+
+# Manual install
+message(STATUS "Installing")
+
+file(COPY ${SOURCE_PATH}/lib/zstd.h DESTINATION ${CURRENT_PACKAGES_DIR}/include)
+file(COPY ${SOURCE_PATH}/lib/common/zbuff.h DESTINATION ${CURRENT_PACKAGES_DIR}/include)
+file(COPY ${SOURCE_PATH}/lib/dictBuilder/zdict.h DESTINATION ${CURRENT_PACKAGES_DIR}/include)
+
+set(RELDIR ${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-rel/lib/Release)
+set(DEBDIR ${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-dbg/lib/Debug)
+if (VCPKG_LIBRARY_LINKAGE STREQUAL dynamic)
+ file(INSTALL ${RELDIR}/ DESTINATION ${CURRENT_PACKAGES_DIR}/lib FILES_MATCHING PATTERN "zstd_*.lib")
+ file(INSTALL ${RELDIR}/ DESTINATION ${CURRENT_PACKAGES_DIR}/bin FILES_MATCHING PATTERN "zstd_*.dll")
+ file(INSTALL ${DEBDIR}/ DESTINATION ${CURRENT_PACKAGES_DIR}/debug/lib FILES_MATCHING PATTERN "zstd_*.lib")
+ file(INSTALL ${DEBDIR}/ DESTINATION ${CURRENT_PACKAGES_DIR}/debug/bin FILES_MATCHING PATTERN "zstd_*.dll")
+ vcpkg_copy_pdbs()
+else()
+ file(INSTALL ${RELDIR}/ DESTINATION ${CURRENT_PACKAGES_DIR}/lib FILES_MATCHING PATTERN "zstd-static_*.lib")
+ file(INSTALL ${DEBDIR}/ DESTINATION ${CURRENT_PACKAGES_DIR}/debug/lib FILES_MATCHING PATTERN "zstd-static_*.lib")
+endif()
+
+# Handle copyright
+file(COPY ${SOURCE_PATH}/LICENSE DESTINATION ${CURRENT_PACKAGES_DIR}/share/zstd)
+file(RENAME ${CURRENT_PACKAGES_DIR}/share/zstd/LICENSE ${CURRENT_PACKAGES_DIR}/share/zstd/copyright)
+
+message(STATUS "Installing done")