commit:     647b7cae8f31d5c16c0eb90a81c08576a442dd2f
Author:     Yixun Lan <dlan <AT> gentoo <DOT> org>
AuthorDate: Thu Jan 28 06:32:53 2021 +0000
Commit:     Yixun Lan <dlan <AT> gentoo <DOT> org>
CommitDate: Thu Jan 28 06:45:27 2021 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=647b7cae

net-fs/autofs: version bump 5.1.7

Package-Manager: Portage-3.0.13, Repoman-3.0.2
Signed-off-by: Yixun Lan <dlan <AT> gentoo.org>

 net-fs/autofs/Manifest                       |   1 +
 net-fs/autofs/autofs-5.1.7.ebuild            | 124 +++++++++++++++++++++++++++
 net-fs/autofs/files/autofs-5.1.7-glibc.patch |  97 +++++++++++++++++++++
 3 files changed, 222 insertions(+)

diff --git a/net-fs/autofs/Manifest b/net-fs/autofs/Manifest
index 6f533814338..2dd24948a6b 100644
--- a/net-fs/autofs/Manifest
+++ b/net-fs/autofs/Manifest
@@ -1 +1,2 @@
 DIST autofs-5.1.6.tar.xz 315316 BLAKE2B 
0c5e2351462505c6de0b12e510f0c08a625a0235e1ff8eeaff825946c4530c258449d26aaf6a3794aa82a97e8860711226168f434dd31bfb8a4e70287beb3ca4
 SHA512 
dc8b2bd86c140905dd1bc461bfc469f92363d9c2687fe422e1e751cc7ad64c0733b011c80bf4840e510e5909176cd1a066968b9a5ba835b62c4cf27537863cf2
+DIST autofs-5.1.7.tar.xz 327752 BLAKE2B 
bff290048fb2849dd4c7099718f6824eac7e4f700909342f82b79a3baa752c4efe7f45be3492578fa15df6d959751be5d7fae5aafe129b52425c0d9ab19eaccc
 SHA512 
cf994d0e68d5f6a5647235000743811a791150ece0a90ed9e1cb9bb131259f52769371c6a06d968b7191b10e709c9c90de611cc3ee310fbbea87f60034b3d4e1

diff --git a/net-fs/autofs/autofs-5.1.7.ebuild 
b/net-fs/autofs/autofs-5.1.7.ebuild
new file mode 100644
index 00000000000..5dfef5feafa
--- /dev/null
+++ b/net-fs/autofs/autofs-5.1.7.ebuild
@@ -0,0 +1,124 @@
+# Copyright 1999-2021 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=7
+
+inherit linux-info systemd toolchain-funcs
+
+DESCRIPTION="Kernel based automounter"
+HOMEPAGE="https://web.archive.org/web/*/http://www.linux-consulting.com/Amd_AutoFS/autofs.html";
+SRC_URI="https://www.kernel.org/pub/linux/daemons/${PN}/v5/${P}.tar.xz";
+
+LICENSE="GPL-2"
+SLOT="0"
+KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~mips ~ppc ~ppc64 ~sparc ~x86"
+IUSE="-dmalloc ldap +libtirpc mount-locking sasl systemd"
+
+# currently, sasl code assumes the presence of kerberosV
+RDEPEND=">=sys-apps/util-linux-2.20
+       dmalloc? ( dev-libs/dmalloc[threads] )
+       ldap? ( >=net-nds/openldap-2.0
+               sasl? (
+                       dev-libs/cyrus-sasl
+                       dev-libs/libxml2
+                       virtual/krb5
+               )
+       )
+       systemd? ( sys-apps/systemd )
+       libtirpc? ( net-libs/libtirpc )
+       !libtirpc? ( elibc_glibc? ( sys-libs/glibc[rpc(-)] ) )
+"
+DEPEND="${RDEPEND}
+       libtirpc? ( net-libs/rpcsvc-proto )
+"
+BDEPEND="
+       sys-devel/flex
+       virtual/yacc
+"
+
+PATCHES=(
+       "${FILESDIR}/${P}-glibc.patch"
+       "${FILESDIR}/${PN}-5.1.6-pid.patch"
+)
+
+pkg_setup() {
+       linux-info_pkg_setup
+
+       local CONFIG_CHECK
+
+       if kernel_is -ge 4 18; then
+               CONFIG_CHECK="~AUTOFS_FS"
+       else
+               CONFIG_CHECK="~AUTOFS4_FS"
+       fi
+
+       check_extra_config
+}
+
+src_prepare() {
+       sed -i  -e "s:/usr/bin/kill:/bin/kill:" samples/autofs.service.in || 
die # bug #479492
+       sed -i  -e "/^EnvironmentFile/d"        samples/autofs.service.in || 
die # bug #592334
+
+       # Install samples including autofs.service
+       sed -i -e "/^SUBDIRS/s/$/ samples/g" Makefile.rules || die
+
+       default
+}
+
+src_configure() {
+       # bug #483716
+       tc-export AR
+       # --with-confdir is for bug #361481
+       # --with-mapdir is for bug #385113
+       local myeconfargs=(
+               --with-confdir=/etc/conf.d
+               --with-mapdir=/etc/autofs
+               $(use_with dmalloc)
+               $(use_with ldap openldap)
+               $(use_with libtirpc)
+               $(use_with sasl)
+               $(use_enable mount-locking)
+               $(use_with systemd systemd $(systemd_get_systemunitdir)) # bug 
#479492
+               --without-hesiod
+               --disable-ext-env
+               --enable-sloppy-mount # bug #453778
+               --enable-force-shutdown
+               --enable-ignore-busy
+               RANLIB="$(type -P $(tc-getRANLIB))" # bug #483716
+       )
+       econf "${myeconfargs[@]}"
+}
+
+src_compile() {
+       export DONTSTRIP=1
+       default
+}
+
+src_install() {
+       default
+       rmdir "${D}"/run
+
+       if kernel_is -lt 2 6 30; then
+               # kernel patches
+               docinto patches
+               dodoc patches/${PN}4-2.6.??{,.?{,?}}-v5-update-????????.patch
+       fi
+       newinitd "${FILESDIR}"/autofs5.initd autofs
+       insinto etc/autofs
+       newins "${FILESDIR}"/autofs5-auto.master auto.master
+}
+
+pkg_postinst() {
+       if kernel_is -lt 2 6 30; then
+               elog "This version of ${PN} requires a kernel with autofs4 
supporting"
+               elog "protocol version 5.00. Patches for kernels older than 
2.6.30 have"
+               elog "been installed into"
+               elog "${EROOT}/usr/share/doc/${P}/patches."
+               elog "For further instructions how to patch the kernel, please 
refer to"
+               elog "${EROOT}/usr/share/doc/${P}/INSTALL."
+               elog
+       fi
+       elog "If you plan on using autofs for automounting remote NFS mounts,"
+       elog "please check that both portmap (or rpcbind) and rpc.statd/lockd"
+       elog "are running."
+}

diff --git a/net-fs/autofs/files/autofs-5.1.7-glibc.patch 
b/net-fs/autofs/files/autofs-5.1.7-glibc.patch
new file mode 100644
index 00000000000..2a0f415fbee
--- /dev/null
+++ b/net-fs/autofs/files/autofs-5.1.7-glibc.patch
@@ -0,0 +1,97 @@
+diff --git a/daemon/lookup.c b/daemon/lookup.c
+index 2fea0c0..3b3aa3e 100644
+--- a/daemon/lookup.c
++++ b/daemon/lookup.c
+@@ -397,7 +397,7 @@ static int read_file_source_instance(struct autofs_point 
*ap, struct map_source
+               return NSS_STATUS_NOTFOUND;
+       }
+ 
+-      if (st.st_mode & __S_IEXEC)
++      if (st.st_mode & S_IEXEC)
+               type = src_prog;
+       else
+               type = src_file;
+@@ -930,7 +930,7 @@ static int lookup_name_file_source_instance(struct 
autofs_point *ap, struct map_
+               return NSS_STATUS_NOTFOUND;
+       }
+ 
+-      if (st.st_mode & __S_IEXEC)
++      if (st.st_mode & S_IEXEC)
+               type = src_prog;
+       else
+               type = src_file;
+@@ -1077,7 +1077,7 @@ static struct map_source *lookup_get_map_source(struct 
master_mapent *entry)
+       if (!S_ISREG(st.st_mode))
+               return NULL;
+ 
+-      if (st.st_mode & __S_IEXEC)
++      if (st.st_mode & S_IEXEC)
+               type = "program";
+       else
+               type = "file";
+diff --git a/include/automount.h b/include/automount.h
+index 1ae4078..c2e8dba 100644
+--- a/include/automount.h
++++ b/include/automount.h
+@@ -13,6 +13,7 @@
+ #include <limits.h>
+ #include <time.h>
+ #include <syslog.h>
++#include <sys/procfs.h>
+ #include <sys/types.h>
+ #include <pthread.h>
+ #include <sched.h>
+@@ -42,6 +43,16 @@
+ #include <dmalloc.h>
+ #endif
+ 
++#ifndef __SWORD_TYPE
++#if __WORDSIZE == 32
++# define __SWORD_TYPE         int
++#elif __WORDSIZE == 64
++# define __SWORD_TYPE         long int
++#else
++#error
++#endif
++#endif
++
+ #define ENABLE_CORES  1
+ 
+ /* We MUST have the paths to mount(8) and umount(8) */
+diff --git a/include/nsswitch.h b/include/nsswitch.h
+index d3e4027..8376113 100644
+--- a/include/nsswitch.h
++++ b/include/nsswitch.h
+@@ -24,6 +24,10 @@
+ #include <netdb.h>
+ #include "list.h"
+ 
++#ifndef _PATH_NSSWITCH_CONF
++#define _PATH_NSSWITCH_CONF "/dev/null"
++#endif
++
+ #define NSSWITCH_FILE _PATH_NSSWITCH_CONF
+ 
+ enum nsswitch_status {
+diff --git a/modules/lookup_multi.c b/modules/lookup_multi.c
+index fadd2ea..cf109de 100644
+--- a/modules/lookup_multi.c
++++ b/modules/lookup_multi.c
+@@ -247,7 +247,7 @@ static struct lookup_mod *nss_open_lookup(const char 
*format, int argc, const ch
+                               continue;
+                       }
+ 
+-                      if (st.st_mode & __S_IEXEC)
++                      if (st.st_mode & S_IEXEC)
+                               type = src_prog;
+                       else
+                               type = src_file;
+@@ -452,7 +452,7 @@ int lookup_reinit(const char *my_mapfmt,
+                                       continue;
+                               }
+ 
+-                              if (st.st_mode & __S_IEXEC)
++                              if (st.st_mode & S_IEXEC)
+                                       type = src_prog;
+                               else
+                                       type = src_file;

Reply via email to