aboutsummaryrefslogtreecommitdiffstats
path: root/testing/fts
diff options
context:
space:
mode:
authorNatanael Copa <ncopa@alpinelinux.org>2014-09-11 14:14:08 +0000
committerNatanael Copa <ncopa@alpinelinux.org>2014-09-11 14:16:26 +0000
commitb2ca2d696b1f7225c10b6d5c1bf636f3125e7451 (patch)
treec9f098fe91b5c9db0972dd88ec2382580ff62eea /testing/fts
parentc51482993c8410af07f96da6d9dc1dc01248c755 (diff)
downloadaports-b2ca2d696b1f7225c10b6d5c1bf636f3125e7451.tar.bz2
aports-b2ca2d696b1f7225c10b6d5c1bf636f3125e7451.tar.xz
Revert "main/fts: *plonk*" and move to testing
Diffstat (limited to 'testing/fts')
-rw-r--r--testing/fts/APKBUILD56
-rw-r--r--testing/fts/fts-header-correctness.patch20
-rw-r--r--testing/fts/fts-uclibc.patch45
-rw-r--r--testing/fts/stdint.patch10
4 files changed, 131 insertions, 0 deletions
diff --git a/testing/fts/APKBUILD b/testing/fts/APKBUILD
new file mode 100644
index 0000000000..e6f2850ec7
--- /dev/null
+++ b/testing/fts/APKBUILD
@@ -0,0 +1,56 @@
+# Contributor: William Pitcock <nenolod@dereferenced.org>
+# Maintainer: William Pitcock <nenolod@dereferenced.org>
+pkgname=fts
+pkgver=0
+pkgrel=3
+pkgdesc="keith bostic's POSIX file tree stream operations library"
+url="http://bostic.com/"
+arch="all"
+license="BSD"
+depends=
+depends_dev=
+makedepends="$depends_dev wget"
+install=""
+subpackages="$pkgname-dev $pkgname-doc"
+replaces_doc="man-pages"
+source="saveas-https://sites.google.com/a/bostic.com/keithbostic/files/fts.tar.gz?attredirects=0/fts.tar.gz
+ fts-uclibc.patch
+ fts-header-correctness.patch
+ stdint.patch"
+
+_builddir="${srcdir}/${pkgname}"
+prepare() {
+ local i
+ cd "$_builddir"
+ chmod +w *.c
+ for i in $source; do
+ case $i in
+ *.patch) msg $i; patch -p1 -i "$srcdir"/$i || return 1;;
+ esac
+ done
+}
+
+build() {
+ cd "$_builddir"
+ gcc -I. -fPIC -shared -o libfts.so -Wl,-soname,libfts.so.${pkgver} fts.c
+}
+
+package() {
+ cd "$_builddir"
+
+ install -d "$pkgdir"/usr/lib
+
+ install -m 755 libfts.so "$pkgdir"/usr/lib/libfts.so.${pkgver}
+ ln -sf libfts.so.${pkgver} "$pkgdir"/usr/lib/libfts.so
+
+ install -d "$pkgdir"/usr/include
+ install -m 644 fts.h "$pkgdir"/usr/include/fts.h
+
+ install -d "$pkgdir"/usr/share/man/man3
+ install -m 644 fts.3 "$pkgdir"/usr/share/man/man3/fts.3
+}
+
+md5sums="120c14715485ec6ced14f494d059d20a fts.tar.gz
+588fead4044bf535ff97298651aaab8f fts-uclibc.patch
+b197744ece4ef9a5fa52692acf9b6666 fts-header-correctness.patch
+a8a5a8e81e1c67738aef00f3f13a718b stdint.patch"
diff --git a/testing/fts/fts-header-correctness.patch b/testing/fts/fts-header-correctness.patch
new file mode 100644
index 0000000000..59061bfc95
--- /dev/null
+++ b/testing/fts/fts-header-correctness.patch
@@ -0,0 +1,20 @@
+--- fts.orig/fts.h
++++ fts/fts.h
+@@ -38,6 +38,17 @@
+ #ifndef _FTS_H_
+ #define _FTS_H_
+
++#include <sys/types.h>
++#include <sys/param.h>
++#include <sys/stat.h>
++
++#include <dirent.h>
++#include <errno.h>
++#include <fcntl.h>
++#include <stdlib.h>
++#include <string.h>
++#include <unistd.h>
++
+ typedef struct {
+ struct _ftsent *fts_cur; /* current node */
+ struct _ftsent *fts_child; /* linked list of children */
diff --git a/testing/fts/fts-uclibc.patch b/testing/fts/fts-uclibc.patch
new file mode 100644
index 0000000000..3593530396
--- /dev/null
+++ b/testing/fts/fts-uclibc.patch
@@ -0,0 +1,45 @@
+--- fts.orig/fts.c
++++ fts/fts.c
+@@ -31,6 +31,10 @@
+ * SUCH DAMAGE.
+ */
+
++#define alignof(TYPE) ((int) &((struct { char dummy1; TYPE dummy2; } *) 0)->dummy2)
++#define ALIGNBYTES (alignof(long double) - 1)
++#define ALIGN(p) (((uintptr_t)(p) + ALIGNBYTES) & ~ALIGNBYTES)
++
+ #if defined(LIBC_SCCS) && !defined(lint)
+ static char sccsid[] = "@(#)fts.c 8.6 (Berkeley) 8/14/94";
+ #endif /* LIBC_SCCS and not lint */
+@@ -652,10 +656,10 @@
+ if (!ISSET(FTS_SEEDOT) && ISDOT(dp->d_name))
+ continue;
+
+- if ((p = fts_alloc(sp, dp->d_name, (int)dp->d_namlen)) == NULL)
++ if ((p = fts_alloc(sp, dp->d_name, (int)dp->d_reclen)) == NULL)
+ goto mem1;
+- if (dp->d_namlen > maxlen) {
+- if (fts_palloc(sp, (size_t)dp->d_namlen)) {
++ if (dp->d_reclen > maxlen) {
++ if (fts_palloc(sp, (size_t)dp->d_reclen)) {
+ /*
+ * No more memory for path or structures. Save
+ * errno, free up the current structure and the
+@@ -675,7 +679,7 @@
+ maxlen = sp->fts_pathlen - sp->fts_cur->fts_pathlen - 1;
+ }
+
+- p->fts_pathlen = len + dp->d_namlen + 1;
++ p->fts_pathlen = len + dp->d_reclen + 1;
+ p->fts_parent = sp->fts_cur;
+ p->fts_level = level;
+
+@@ -784,7 +788,7 @@
+ /* If user needs stat info, stat buffer already allocated. */
+ sbp = ISSET(FTS_NOSTAT) ? &sb : p->fts_statp;
+
+-#ifdef DT_WHT
++#ifdef S_IFWHT
+ /*
+ * Whited-out files don't really exist. However, there's stat(2) file
+ * mask for them, so we set it so that programs (i.e., find) don't have
diff --git a/testing/fts/stdint.patch b/testing/fts/stdint.patch
new file mode 100644
index 0000000000..1ad7157e58
--- /dev/null
+++ b/testing/fts/stdint.patch
@@ -0,0 +1,10 @@
+--- ./fts.c.orig
++++ ./fts.c
+@@ -46,6 +46,7 @@
+ #include <errno.h>
+ #include <fcntl.h>
+ #include <fts.h>
++#include <stdint.h>
+ #include <stdlib.h>
+ #include <string.h>
+ #include <unistd.h>