diff options
-rw-r--r-- | testing/hfsprogs/APKBUILD | 68 | ||||
-rw-r--r-- | testing/hfsprogs/fix-stdarg.patch | 122 | ||||
-rw-r--r-- | testing/hfsprogs/musl-compat.patch | 136 |
3 files changed, 326 insertions, 0 deletions
diff --git a/testing/hfsprogs/APKBUILD b/testing/hfsprogs/APKBUILD new file mode 100644 index 0000000000..ec9140bad7 --- /dev/null +++ b/testing/hfsprogs/APKBUILD @@ -0,0 +1,68 @@ +# Contributor: Jakub Jirutka <jakub@jirutka.cz> +# Maintainer: Jakub Jirutka <jakub@jirutka.cz> +pkgname=hfsprogs +_pkgname=diskdev_cmds +pkgver=540.1_p3 +_pkgver=${pkgver/_p/.linux} +pkgrel=0 +pkgdesc="Tools to create/check Apple HFS+ filesystems" +# We use modified version provided by Fedora's dev, not directly from Apple. +url="https://src.fedoraproject.org/rpms/hfsplus-tools" +arch="all" +license="APSL-2.0" +makedepends="clang libbsd-dev libressl-dev linux-headers util-linux-dev" +provides="$_pkgname=$pkgver-r$pkgrel" +subpackages="$pkgname-doc" +# Tarball made by Matthew Garrett (mjg59). +# https://src.fedoraproject.org/rpms/hfsplus-tools/blob/f27/f/hfsplus-tools.spec +source="http://cavan.codon.org.uk/~mjg59/$_pkgname/$_pkgname-$_pkgver.tar.gz + http://www.opensource.org/licenses/apsl-2.0.txt + fix-stdarg.patch + musl-compat.patch" +builddir="$srcdir/$_pkgname-$_pkgver" + +prepare() { + default_prepare + cd "$builddir" + + sed -i 's/[F|f]sck_hfs/fsck.hfsplus/g' fsck_hfs.tproj/fsck_hfs.8 + sed -i 's/[N|n]ewfs_hfs/mkfs.hfsplus/g' newfs_hfs.tproj/newfs_hfs.8 + + # Remove errant execute bits. + find . -type f -name '*.[ch]' -exec chmod -c -x {} + +} + +build() { + cd "$builddir" + + make +} + +check() { + cd "$builddir" + + ./fsck_hfs.tproj/fsck_hfs 2>&1 | grep 'usage: fsck_hfs' + ./newfs_hfs.tproj/newfs_hfs 2>&1 | grep 'usage: newfs_hfs' +} + +package() { + cd "$builddir" + + install -D -m 755 fsck_hfs.tproj/fsck_hfs "$pkgdir"/usr/sbin/fsck.hfs + install -D -m 755 newfs_hfs.tproj/newfs_hfs "$pkgdir"/usr/sbin/mkfs.hfsplus + ln -s fsck.hfs "$pkgdir"/usr/sbin/fsck.hfsplus + + install -D -m 644 fsck_hfs.tproj/fsck_hfs.8 \ + "$pkgdir"/usr/share/man/man8/fsck.hfsplus.8 + install -D -m 644 newfs_hfs.tproj/newfs_hfs.8 \ + "$pkgdir"/usr/share/man/man8/mkfs.hfsplus.8 + ln -s fsck.hfs.8 "$pkgdir"/usr/share/man/man8/fsck.hfs.8 + + install -D -m 644 "$srcdir"/apsl-2.0.txt \ + "$pkgdir"/usr/share/licenses/$pkgname/APSL-2.0.txt +} + +sha512sums="3d88fcdec4bfd32a75b6dc75899748d8585371b641be86cfdfe54ade738a0612662dd008c1506c7e216325303217d0b5f188a9c4fdccfb48b2ce50333f212d9e diskdev_cmds-540.1.linux3.tar.gz +6217c0ae844c4f8c7ba08abf255d8bd594d487f13bc6b52c7ec19fc48fa8f8d1d1afe7a0d939220e3a2d9756aa3235d51492d5c155ac7d68971ef79e837cd0f9 apsl-2.0.txt +cff25de690f5ecc418380e5cbda3615d38ef9583ace60be9b7696c50e46bc35a29855b216ddb4daae79ff5b40f66ffbc03f613ab0ae1935ee9df6e69caed2e0b fix-stdarg.patch +34c73b0b57c8e8fa64abf34a9396b6dc218b1a1f06fec98fd52e77c81421cff249f4a65d5f26e692b1cb5e2424a871ecbf5b35eab5d3509506f6710406ff7577 musl-compat.patch" diff --git a/testing/hfsprogs/fix-stdarg.patch b/testing/hfsprogs/fix-stdarg.patch new file mode 100644 index 0000000000..ecd8fe84a4 --- /dev/null +++ b/testing/hfsprogs/fix-stdarg.patch @@ -0,0 +1,122 @@ +Patch-Source: https://src.fedoraproject.org/rpms/hfsplus-tools/blob/f27/f/hfsplus-tools-learn-to-stdarg.patch + +diff -up diskdev_cmds-540.1.linux3/fsck_hfs.tproj/utilities.c.jx diskdev_cmds-540.1.linux3/fsck_hfs.tproj/utilities.c +--- diskdev_cmds-540.1.linux3/fsck_hfs.tproj/utilities.c.jx 2012-02-01 12:17:19.000000000 -0500 ++++ diskdev_cmds-540.1.linux3/fsck_hfs.tproj/utilities.c 2014-06-18 13:44:45.125620007 -0400 +@@ -296,11 +296,8 @@ static volatile int keep_going = 1; + #undef printf + + // prototype +-void print_to_mem(int type, const char *fmt, const char *str, va_list ap); +- +-#define DO_VPRINT 1 // types for print_to_mem +-#define DO_STR 2 +- ++void vprint_to_mem(const char *fmt, va_list ap); ++void print_to_mem(const char *fmt, ...); + + static void * + fsck_printing_thread(void *arg) +@@ -547,8 +544,8 @@ setup_logging(void) + cur_in_mem = in_mem_log; + + t = time(NULL); +- print_to_mem(DO_STR, "\n%s: ", cdevname ? cdevname : "UNKNOWN-DEV", NULL); +- print_to_mem(DO_STR, "fsck_hfs run at %s", ctime(&t), NULL); ++ print_to_mem("\n%s: ", cdevname ? cdevname : "UNKNOWN-DEV"); ++ print_to_mem("fsck_hfs run at %s", ctime(&t)); + + if (live_fsck && log_file) { + pthread_cond_init(&mem_buf_cond, NULL); +@@ -576,26 +573,20 @@ setup_logging(void) + + + void +-print_to_mem(int type, const char *fmt, const char *str, va_list ap) ++vprint_to_mem(const char *fmt, va_list ap) + { + int ret; + size_t size_remaining; + va_list ap_copy; + +- if (type == DO_VPRINT) { +- va_copy(ap_copy, ap); +- } ++ va_copy(ap_copy, ap); + + if (live_fsck) { + pthread_mutex_lock(&mem_buf_lock); + } + + size_remaining = in_mem_size - (ptrdiff_t)(cur_in_mem - in_mem_log); +- if (type == DO_VPRINT) { +- ret = vsnprintf(cur_in_mem, size_remaining, fmt, ap); +- } else { +- ret = snprintf(cur_in_mem, size_remaining, fmt, str); +- } ++ ret = vsnprintf(cur_in_mem, size_remaining, fmt, ap); + if (ret > size_remaining) { + char *new_log; + size_t amt; +@@ -619,11 +610,7 @@ print_to_mem(int type, const char *fmt, + cur_in_mem = new_log + (cur_in_mem - in_mem_log); + in_mem_log = new_log; + size_remaining = in_mem_size - (ptrdiff_t)(cur_in_mem - new_log); +- if (type == DO_VPRINT) { +- ret = vsnprintf(cur_in_mem, size_remaining, fmt, ap_copy); +- } else { +- ret = snprintf(cur_in_mem, size_remaining, fmt, str); +- } ++ ret = vsnprintf(cur_in_mem, size_remaining, fmt, ap_copy); + if (ret <= size_remaining) { + cur_in_mem += ret; + } +@@ -636,11 +623,18 @@ print_to_mem(int type, const char *fmt, + pthread_mutex_unlock(&mem_buf_lock); + } + done: +- if (type == DO_VPRINT) { +- va_end(ap_copy); +- } ++ va_end(ap_copy); + } + ++void ++print_to_mem(const char *fmt, ...) ++{ ++ va_list ap; ++ ++ va_start(ap, fmt); ++ vprint_to_mem(fmt, ap); ++ va_end(ap); ++} + + static int need_prefix=1; + +@@ -662,7 +656,7 @@ static int need_prefix=1; + LOG_PREFIX \ + vfprintf(log_file, fmt, ap); \ + } else { \ +- print_to_mem(DO_VPRINT, fmt, NULL, ap); \ ++ vprint_to_mem(fmt, ap); \ + } + + #define FLOG(fmt, str) \ +@@ -670,7 +664,7 @@ static int need_prefix=1; + LOG_PREFIX; \ + fprintf(log_file, fmt, str); \ + } else { \ +- print_to_mem(DO_STR, fmt, str, NULL); \ ++ print_to_mem(fmt, str); \ + } + + +@@ -800,7 +794,7 @@ vplog(const char *fmt, va_list ap) + LOG_PREFIX; + vfprintf(log_file, fmt, ap); + } else { +- print_to_mem(DO_VPRINT, fmt, NULL, ap); ++ vprint_to_mem(fmt, ap); + } + } + diff --git a/testing/hfsprogs/musl-compat.patch b/testing/hfsprogs/musl-compat.patch new file mode 100644 index 0000000000..345bd24d69 --- /dev/null +++ b/testing/hfsprogs/musl-compat.patch @@ -0,0 +1,136 @@ +--- diskdev_cmds-540.1.linux3.orig/fsck_hfs.tproj/dfalib/Scavenger.h ++++ diskdev_cmds-540.1.linux3/fsck_hfs.tproj/dfalib/Scavenger.h +@@ -48,7 +48,6 @@ + #endif + #include <sys/errno.h> + #include <sys/param.h> +-#include <sys/sysctl.h> + #include <sys/mount.h> + #include <hfs/hfs_mount.h> + +--- diskdev_cmds-540.1.linux3.orig/fsck_hfs.tproj/fsck_hfs.c ++++ diskdev_cmds-540.1.linux3/fsck_hfs.tproj/fsck_hfs.c +@@ -30,7 +30,6 @@ + #include <sys/ioctl.h> + #if !LINUX + #include <sys/disk.h> +-#include <sys/sysctl.h> + #include <setjmp.h> + #endif + #include <hfs/hfs_mount.h> +--- diskdev_cmds-540.1.linux3.orig/newfs_hfs.tproj/makehfs.c ++++ diskdev_cmds-540.1.linux3/newfs_hfs.tproj/makehfs.c +@@ -38,7 +38,6 @@ + #endif + #include <sys/errno.h> + #include <sys/stat.h> +-#include <sys/sysctl.h> + #if !LINUX + #include <sys/vmmeter.h> + #endif +--- a/fsck_hfs.tproj/utilities.c ++++ b/fsck_hfs.tproj/utilities.c +@@ -70,7 +70,6 @@ + #include <string.h> + #include <unistd.h> + #include <stdlib.h> +-#include <sys/sysctl.h> + + #include "fsck_hfs.h" + +--- diskdev_cmds-540.1.linux3.orig/fsck_hfs.tproj/dfalib/Scavenger.h ++++ diskdev_cmds-540.1.linux3/fsck_hfs.tproj/dfalib/Scavenger.h +@@ -46,7 +46,7 @@ + #include <sys/kauth.h> + #include <sys/syslimits.h> + #endif +-#include <sys/errno.h> ++#include <errno.h> + #include <sys/param.h> + #include <sys/mount.h> + #include <hfs/hfs_mount.h> +--- diskdev_cmds-540.1.linux3.orig/fsck_hfs.tproj/utilities.c ++++ diskdev_cmds-540.1.linux3/fsck_hfs.tproj/utilities.c +@@ -55,7 +55,7 @@ + #include <stddef.h> + #include <sys/types.h> + #include <sys/stat.h> +-#include <sys/errno.h> ++#include <errno.h> + #if LINUX + #include <limits.h> + #include <signal.h> +--- diskdev_cmds-540.1.linux3.orig/newfs_hfs.tproj/makehfs.c ++++ diskdev_cmds-540.1.linux3/newfs_hfs.tproj/makehfs.c +@@ -36,7 +36,7 @@ + #include <time.h> + #include "missing.h" + #endif +-#include <sys/errno.h> ++#include <errno.h> + #include <sys/stat.h> + #if !LINUX + #include <sys/vmmeter.h> +--- a/fsck_hfs.tproj/cache.h ++++ b/fsck_hfs.tproj/cache.h +@@ -29,6 +29,7 @@ + #ifndef _CACHE_H_ + #define _CACHE_H_ + #include <stdint.h> ++#include <sys/types.h> + + /* Different values for initializing cache */ + enum { +--- a/newfs_hfs.tproj/makehfs.c ++++ b/newfs_hfs.tproj/makehfs.c +@@ -41,6 +41,7 @@ + #if !LINUX + #include <sys/vmmeter.h> + #endif ++#include <sys/cdefs.h> + + #include <err.h> + #include <errno.h> +--- a/newfs_hfs.tproj/newfs_hfs.c ++++ b/newfs_hfs.tproj/newfs_hfs.c +@@ -42,6 +42,7 @@ + #if LINUX + #include <time.h> + #endif ++#include <sys/cdefs.h> + + #if !LINUX + #include <IOKit/storage/IOMediaBSDClient.h> +--- a/fsck_hfs.tproj/fsck_hfs.h ++++ b/fsck_hfs.tproj/fsck_hfs.h +@@ -22,6 +22,7 @@ + */ + + #include "cache.h" ++#include <sys/cdefs.h> + + + const extern char *cdevname; /* name of device being checked */ +--- a/fsck_hfs.tproj/utilities.c ++++ b/fsck_hfs.tproj/utilities.c +@@ -785,7 +785,7 @@ + + if (!live_fsck) { + /* copy va_list as it will be used again later */ +- __va_copy(ap_stdout, ap); ++ va_copy(ap_stdout, ap); + vfprintf(stdout, fmt, ap_stdout); + } + +--- a/fsck_hfs.tproj/fsck_messages.c ++++ b/fsck_hfs.tproj/fsck_messages.c +@@ -85,7 +85,7 @@ + + if (c == NULL) + return; +- __va_copy(ap2, ap); // Just in case we need it ++ va_copy(ap2, ap); // Just in case we need it + length = vsnprintf(buf, BUFSIZ, fmt, ap); + if (length > BUFSIZ) { + // We need to allocate space for it + |