From 38c0e57b47fb699c1e7d87d31db5905f22ffb71b Mon Sep 17 00:00:00 2001 From: Natanael Copa Date: Wed, 27 Jan 2010 20:14:58 +0000 Subject: main/e2fsprogs: provide com_err_r() for heimdal compat --- main/e2fsprogs/0001-implement-com_right_r.patch | 59 +++++++++++++++++++++++++ main/e2fsprogs/APKBUILD | 26 ++++++----- 2 files changed, 75 insertions(+), 10 deletions(-) create mode 100644 main/e2fsprogs/0001-implement-com_right_r.patch (limited to 'main') diff --git a/main/e2fsprogs/0001-implement-com_right_r.patch b/main/e2fsprogs/0001-implement-com_right_r.patch new file mode 100644 index 0000000000..dc285d9acd --- /dev/null +++ b/main/e2fsprogs/0001-implement-com_right_r.patch @@ -0,0 +1,59 @@ +From 527d258d605e5a1dd841bccc6091c0b894a10411 Mon Sep 17 00:00:00 2001 +From: Natanael Copa +Date: Wed, 27 Jan 2010 16:02:08 +0000 +Subject: [PATCH] implement com_right_r() + +For heimdal compat +--- + lib/et/com_err.h | 2 ++ + lib/et/com_right.c | 14 ++++++++++++++ + 2 files changed, 16 insertions(+), 0 deletions(-) + +diff --git a/lib/et/com_err.h b/lib/et/com_err.h +index de0146e..eb2106f 100644 +--- a/lib/et/com_err.h ++++ b/lib/et/com_err.h +@@ -16,6 +16,7 @@ + #define COM_ERR_ATTR(x) + #endif + ++#include + #include + + typedef long errcode_t; +@@ -49,6 +50,7 @@ extern void add_to_error_table(struct et_list *new_table); + + /* Provided for Heimdall compatibility */ + extern const char *com_right(struct et_list *list, long code); ++extern const char *com_right_r(struct et_list *list, long code, char *str, size_t len); + extern void initialize_error_table_r(struct et_list **list, + const char **messages, + int num_errors, +diff --git a/lib/et/com_right.c b/lib/et/com_right.c +index 173fd1a..dbc1e41 100644 +--- a/lib/et/com_right.c ++++ b/lib/et/com_right.c +@@ -55,6 +55,20 @@ com_right(struct et_list *list, long code) + return NULL; + } + ++const char * ++com_right_r(struct et_list *list, long code, char *str, size_t len) ++{ ++ struct et_list *p; ++ for (p = list; p; p = p->next) { ++ if (code >= p->table->base && code < p->table->base + p->table->n_msgs) { ++ strlcpy(str, p->table->msgs[code - p->table->base], len); ++ return str; ++ } ++ } ++ return NULL; ++} ++ ++ + struct foobar { + struct et_list etl; + struct error_table tab; +-- +1.6.6.1 + diff --git a/main/e2fsprogs/APKBUILD b/main/e2fsprogs/APKBUILD index c4906382b9..050e7727e8 100644 --- a/main/e2fsprogs/APKBUILD +++ b/main/e2fsprogs/APKBUILD @@ -1,7 +1,7 @@ # Maintainer: Natanael Copa pkgname=e2fsprogs pkgver=1.41.9 -pkgrel=1 +pkgrel=2 pkgdesc="Standard Ext2/3/4 filesystem utilities" url="http://e2fsprogs.sourceforge.net" license="GPL LGPL MIT" @@ -9,12 +9,19 @@ depends= install="$pkgname.post-upgrade" makedepends="util-linux-ng-dev pkgconfig" subpackages="$pkgname-dev $pkgname-doc libcom_err" -source="http://downloads.sourceforge.net/sourceforge/e2fsprogs/e2fsprogs-$pkgver.tar.gz" +source="http://downloads.sourceforge.net/sourceforge/e2fsprogs/e2fsprogs-$pkgver.tar.gz + 0001-implement-com_right_r.patch" depends_dev="util-linux-ng-dev" +_builddir="$srcdir"/$pkgname-$pkgver +prepare() { + cd "$_builddir" + patch -p1 -i "$srcdir"/0001-implement-com_right_r.patch +} + build () { - cd ${srcdir}/${pkgname}-${pkgver} + cd "$_builddir" ./configure \ --mandir=/usr/share/man \ --enable-elf-shlibs \ @@ -26,6 +33,10 @@ build () { --disable-nls make || return 1 +} + +package() { + cd "$_builddir" make LDCONFIG=: DESTDIR=${pkgdir} install install-libs || return 1 } @@ -35,10 +46,5 @@ libcom_err() { mv "$pkgdir"/usr/lib/libcom_err* "$subpkgdir"/lib/ } -dev() { - default_dev - install -d "$subpkgdir"/lib - mv "$subpkgdir"/usr/lib/libcom_err* "$subpkgdir"/lib/ -} - -md5sums="52f60a9e19a02f142f5546f1b5681927 e2fsprogs-1.41.9.tar.gz" +md5sums="52f60a9e19a02f142f5546f1b5681927 e2fsprogs-1.41.9.tar.gz +600bedf9a85cd197c39715b0be5cc5f7 0001-implement-com_right_r.patch" -- cgit v1.2.3