summaryrefslogtreecommitdiff
path: root/Ports
diff options
context:
space:
mode:
authorManuel Palenzuela <manuelpalenzuelamerino@gmail.com>2021-04-05 11:49:52 +0200
committerAndreas Kling <kling@serenityos.org>2021-04-05 20:04:15 +0200
commita1815b0f87476df9b26398f3c6eb167d415942bd (patch)
tree82087b0419a11d291fe5d6b43bee14a7e70bc04e /Ports
parentabc7b31079960a35f03a331f98746557d0967d72 (diff)
downloadserenity-a1815b0f87476df9b26398f3c6eb167d415942bd.zip
Ports: Added the libzip library
Diffstat (limited to 'Ports')
-rw-r--r--Ports/AvailablePorts.md1
-rwxr-xr-xPorts/libzip/package.sh16
-rw-r--r--Ports/libzip/patches/disable_unnecessary_options.patch52
3 files changed, 69 insertions, 0 deletions
diff --git a/Ports/AvailablePorts.md b/Ports/AvailablePorts.md
index ab8a611251..ce976ef944 100644
--- a/Ports/AvailablePorts.md
+++ b/Ports/AvailablePorts.md
@@ -47,6 +47,7 @@ Please make sure to keep this list up to date when adding and updating ports. :^
| [`libpuffy`](libpuffy/) | libpuffy | 1.0 | https://github.com/ibara/libpuffy |
| [`libtiff`](libtiff/) | libtiff | 4.2.0 | http://www.libtiff.org/ |
| [`libvorbis`](libvorbis/) | libvorbis | 1.3.7 | https://github.com/xiph/vorbis |
+| [`libzip`](libzip/) | libzip | 1.7.3 | https://libzip.org/ |
| [`links`](links/) | Links web browser | 2.22 | http://links.twibright.com/ |
| [`lua`](lua/) | Lua | 5.3.5 | https://www.lua.org/ |
| [`m4`](m4/) | GNU M4 | 1.4.9 | https://www.gnu.org/software/m4/ |
diff --git a/Ports/libzip/package.sh b/Ports/libzip/package.sh
new file mode 100755
index 0000000000..217ccf847f
--- /dev/null
+++ b/Ports/libzip/package.sh
@@ -0,0 +1,16 @@
+#!/usr/bin/env -S bash ../.port_include.sh
+port=libzip
+useconfigure=true
+version=1.7.3
+depends="zlib"
+workdir=libzip-${version}
+configopts="-DCMAKE_TOOLCHAIN_FILE=$SERENITY_ROOT/Toolchain/CMakeToolchain.txt"
+files="https://libzip.org/download/libzip-${version}.tar.gz libzip-${version}.tar.gz"
+
+configure() {
+ run cmake $configopts
+}
+
+install() {
+ run make DESTDIR=$SERENITY_BUILD_DIR/Root install
+}
diff --git a/Ports/libzip/patches/disable_unnecessary_options.patch b/Ports/libzip/patches/disable_unnecessary_options.patch
new file mode 100644
index 0000000000..64d2c8e9e8
--- /dev/null
+++ b/Ports/libzip/patches/disable_unnecessary_options.patch
@@ -0,0 +1,52 @@
+diff --git a/CMakeLists.txt b/CMakeLists.txt
+index 017f7cf0..125900e2 100644
+--- a/CMakeLists.txt
++++ b/CMakeLists.txt
+@@ -9,19 +9,23 @@ project(libzip
+ VERSION 1.7.3
+ LANGUAGES C)
+
+-option(ENABLE_COMMONCRYPTO "Enable use of CommonCrypto" ON)
+-option(ENABLE_GNUTLS "Enable use of GnuTLS" ON)
+-option(ENABLE_MBEDTLS "Enable use of mbed TLS" ON)
+-option(ENABLE_OPENSSL "Enable use of OpenSSL" ON)
+-option(ENABLE_WINDOWS_CRYPTO "Enable use of Windows cryptography libraries" ON)
++set(ZLIB_LIBRARY ${SERENITY_BUILD_DIR}/Root/usr/local/lib/libz.a)
++set(ZLIB_INCLUDE_DIR ${SERENITY_BUILD_DIR}/Root/usr/local/include/zlib.h)
++add_compile_definitions(HAVE_STRINGS_H)
+
+-option(ENABLE_BZIP2 "Enable use of BZip2" ON)
+-option(ENABLE_LZMA "Enable use of LZMA" ON)
++option(ENABLE_COMMONCRYPTO "Enable use of CommonCrypto" OFF)
++option(ENABLE_GNUTLS "Enable use of GnuTLS" OFF)
++option(ENABLE_MBEDTLS "Enable use of mbed TLS" OFF)
++option(ENABLE_OPENSSL "Enable use of OpenSSL" OFF)
++option(ENABLE_WINDOWS_CRYPTO "Enable use of Windows cryptography libraries" OFF)
+
+-option(BUILD_TOOLS "Build tools in the src directory (zipcmp, zipmerge, ziptool)" ON)
+-option(BUILD_REGRESS "Build regression tests" ON)
+-option(BUILD_EXAMPLES "Build examples" ON)
+-option(BUILD_DOC "Build documentation" ON)
++option(ENABLE_BZIP2 "Enable use of BZip2" OFF)
++option(ENABLE_LZMA "Enable use of LZMA" OFF)
++
++option(BUILD_TOOLS "Build tools in the src directory (zipcmp, zipmerge, ziptool)" OFF)
++option(BUILD_REGRESS "Build regression tests" OFF)
++option(BUILD_EXAMPLES "Build examples" OFF)
++option(BUILD_DOC "Build documentation" OFF)
+
+ include(CheckFunctionExists)
+ include(CheckIncludeFiles)
+@@ -62,10 +66,10 @@ else()
+ set(WINDOWS_CRYPTO_FOUND FALSE)
+ endif()
+
+-option(BUILD_SHARED_LIBS "Build shared libraries" ON)
++option(BUILD_SHARED_LIBS "Build shared libraries" OFF)
+ option(LIBZIP_DO_INSTALL "Install libzip and the related files" ON)
+
+-option(SHARED_LIB_VERSIONNING "Add SO version in .so build" ON)
++option(SHARED_LIB_VERSIONNING "Add SO version in .so build" OFF)
+
+ find_program(MDOCTOOL NAMES mandoc groff)
+ if (MDOCTOOL)