commit:     4dbd255403e96f29de759dfd64e0dc45d0bb8a95
Author:     Anthony G. Basile <blueness <AT> gentoo <DOT> org>
AuthorDate: Tue Jul 25 19:47:21 2017 +0000
Commit:     Anthony G. Basile <blueness <AT> gentoo <DOT> org>
CommitDate: Tue Jul 25 19:47:38 2017 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4dbd2554

net-firewall/xtables-addons: version bump to 2.13

Package-Manager: Portage-2.3.6, Repoman-2.3.1

 net-firewall/xtables-addons/Manifest               |   1 +
 .../xtables-addons/xtables-addons-2.13.ebuild      | 187 +++++++++++++++++++++
 2 files changed, 188 insertions(+)

diff --git a/net-firewall/xtables-addons/Manifest 
b/net-firewall/xtables-addons/Manifest
index ed3e487c158..5593aba2655 100644
--- a/net-firewall/xtables-addons/Manifest
+++ b/net-firewall/xtables-addons/Manifest
@@ -1,3 +1,4 @@
 DIST xtables-addons-1.47.1.tar.xz 323312 SHA256 
06535dbefaa7725870750048842b4b53f5a4f8d8b16d5ce61bb4cc28e0b99326 SHA512 
4920c9fae1a5b026f48562590b9221d497127197806f52f2eeba269faf8203b3da2e2ab6ff01f273ecac457d19399c42b4d163c18fa405bfe15b54f46478227d
 WHIRLPOOL 
6654fb33c96eb052b94047445682a26f141532c2db5404ec62c29d40741a34ac9138ba1a5de494d7f1b8706a5de425b1188f79fa6195a824d2642ba506f6bdc1
 DIST xtables-addons-2.12.tar.xz 309724 SHA256 
c4865aa1c64c5ff173ff7b5d69425466c71f0f9b5eb5299c52c68bdcd46fa63b SHA512 
2d93dcb98969d0fb149746b2282eafbf566d0f97c74839d194c7b6cb77d50ec71469d6bbb2565dd855fe8ed6783be2fd705f21f9f7e2842aae9205174a79a6bd
 WHIRLPOOL 
3e25eb102b6a7e6eb85ddac8176f470acc02bfad6830cfa96d7f585a6c3d42c8821fc3c29f41322b5d0ee9273fbc1b11ca29d128b24fa9470f1d7cd965fef899
+DIST xtables-addons-2.13.tar.xz 322116 SHA256 
d141879d438424764e953b97fbb16edafdf8ef6baa57f6e36e07b894a7775dfc SHA512 
51cfa963d6f2f931b0361746e0b48f5ecf43a14e9e8d5297ef55faf0e9f8d1deb4641e88e3fea2afdbb3e39dd06d414de6057fb4a21e5184d4ea3d21b8028497
 WHIRLPOOL 
46463d4497d3b581868ea2a60216bfd198a8f540313c557abda3cb3033be9a853403d8d336f75ed6998d831435950efbacb462406f5d55848b76f12921f39e5f
 DIST xtables-addons-2.8.tar.xz 320864 SHA256 
08af8c85ff00ee76469741bb9eb97454903680213dc3e0602266bcbb08788490 SHA512 
337a0f9f8e1236a14977b1f60f82e9f6ea4b3d1134fb4ff29cdb7edfca54501639760e8f855ac803e259660a9a5afd7366770543e2f077346cb5dda8ef80462e
 WHIRLPOOL 
b09d0d05143ce052372827487e85b7e4c9674809007624371edb4a28155e7e6b605fa2518ba494f1a11cc7e3419675a69cea966a5d79fcfeaf9e273996e059ed

diff --git a/net-firewall/xtables-addons/xtables-addons-2.13.ebuild 
b/net-firewall/xtables-addons/xtables-addons-2.13.ebuild
new file mode 100644
index 00000000000..c81d47572de
--- /dev/null
+++ b/net-firewall/xtables-addons/xtables-addons-2.13.ebuild
@@ -0,0 +1,187 @@
+# Copyright 1999-2017 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI="6"
+
+inherit eutils linux-info linux-mod multilib
+
+DESCRIPTION="iptables extensions not yet accepted in the main kernel"
+HOMEPAGE="http://xtables-addons.sourceforge.net/";
+SRC_URI="mirror://sourceforge/xtables-addons/${P}.tar.xz"
+
+LICENSE="GPL-2"
+SLOT="0"
+KEYWORDS="~amd64 ~x86"
+IUSE="modules"
+
+MODULES="quota2 psd pknock lscan length2 ipv4options ipp2p iface gradm geoip 
fuzzy condition tarpit sysrq logmark ipmark echo dnetmap dhcpmac delude chaos 
account"
+
+for mod in ${MODULES}; do
+       IUSE="${IUSE} xtables_addons_${mod}"
+done
+
+DEPEND=">=net-firewall/iptables-1.4.5"
+
+RDEPEND="${DEPEND}
+       xtables_addons_geoip? (
+               app-arch/unzip
+               dev-perl/Text-CSV_XS
+               virtual/perl-Getopt-Long
+       )
+"
+
+DEPEND="${DEPEND}
+       virtual/linux-sources"
+
+SKIP_MODULES=""
+
+XA_check4internal_module() {
+       local mod=${1}
+       local version=${3}
+       local kconfigname=${3}
+
+       if use xtables_addons_${mod} && kernel_is -gt ${version}; then
+               ewarn "${kconfigname} should be provided by the kernel. 
Skipping its build..."
+               if ! linux_chkconfig_present ${kconfigname}; then
+                       ewarn "Please enable ${kconfigname} target in your 
kernel
+                       configuration or disable checksum module in ${PN}."
+               fi
+               # SKIP_MODULES in case we need to disable building of everything
+               # like having this USE disabled
+               SKIP_MODULES+=" ${mod}"
+       fi
+}
+
+pkg_setup()    {
+       if use modules; then
+               get_version
+               check_modules_supported
+               CONFIG_CHECK="NF_CONNTRACK NF_CONNTRACK_MARK ~CONNECTOR 
UNUSED_SYMBOLS"
+               ERROR_CONNECTOR="Please, enable CONFIG_CONNECTOR if you wish to 
receive userspace notifications from pknock through netlink/connector"
+               linux-mod_pkg_setup
+
+               if ! linux_chkconfig_present IPV6; then
+                       SKIP_IPV6_MODULES="ip6table_rawpost"
+                       ewarn "No IPV6 support in kernel. Disabling: 
${SKIP_IPV6_MODULES}"
+               fi
+               kernel_is -lt 3 7 && die "${P} requires kernel version >= 3.7, 
if you have older kernel please use 1.x version instead"
+       fi
+}
+
+# Helper for maintainer: cheks if all possible MODULES are listed.
+XA_qa_check() {
+       local all_modules
+       all_modules=$(sed -n '/^build_/{s/build_\(.*\)=.*/\L\1/;G;s/\n/ /;s/ 
$//;h}; ${x;p}' "${S}/mconfig")
+       if [[ ${all_modules} != ${MODULES} ]]; then
+               ewarn "QA: Modules in mconfig differ from \$MODULES in ebuild."
+               ewarn "Please, update MODULES in ebuild."
+               ewarn "'${all_modules}'"
+       fi
+}
+
+# Is there any use flag set?
+XA_has_something_to_build() {
+       local mod
+       for mod in ${MODULES}; do
+               use xtables_addons_${mod} && return
+       done
+
+       eerror "All modules are disabled. What do you want me to build?"
+       eerror "Please, set XTABLES_ADDONS to any combination of"
+       eerror "${MODULES}"
+       die "All modules are disabled."
+}
+
+# Parse Kbuid files and generates list of sources
+XA_get_module_name() {
+       [[ $# != 1 ]] && die "XA_get_sources_for_mod: needs exactly one 
argument."
+       local mod objdir build_mod sources_list
+       mod=${1}
+       objdir=${S}/extensions
+       # Take modules name from mconfig
+       build_mod=$(sed -n "s/\(build_${mod}\)=.*/\1/Ip" "${S}/mconfig")
+       # strip .o, = and everything before = and print
+       sources_list=$(sed -n "/^obj-[$][{]${build_mod}[}]/\
+               {s:obj-[^+]\+ [+]=[[:space:]]*::;s:[.]o::g;p}" \
+                               "${objdir}/Kbuild")
+
+       if [[ -d ${S}/extensions/${sources_list} ]]; then
+               objdir=${S}/extensions/${sources_list}
+               sources_list=$(sed -n "/^obj-m/\
+                       {s:obj-[^+]\+ [+]=[[:space:]]*::;s:[.]o::g;p}" \
+                               "${objdir}/Kbuild")
+       fi
+       for mod_src in ${sources_list}; do
+               has ${mod_src} ${SKIP_IPV6_MODULES} || \
+                       echo " 
${mod_src}(xtables_addons:${S}/extensions:${objdir})"
+       done
+}
+
+# Die on modules known to fail on certain kernel version.
+XA_known_failure() {
+       local module_name=$1
+       local KV_max=$2
+
+       if use xtables_addons_${module_name} && kernel_is ge ${KV_max//./ }; 
then
+               eerror
+               eerror "XTABLES_ADDONS=${module_name} fails to build on linux 
${KV_max} or above."
+               eerror "Either remove XTABLES_ADDONS=${module_name} or use an 
earlier version of the kernel."
+               eerror
+               die
+       fi
+}
+
+src_prepare() {
+       XA_qa_check
+       XA_has_something_to_build
+
+       # Bug #553630#c2.  echo fails on linux-4 and above.
+       # This appears to be fixed, at least as of linux-4.2
+       # XA_known_failure "echo" 4
+
+       local mod module_name
+       if use modules; then
+               MODULE_NAMES="compat_xtables(xtables_addons:${S}/extensions:)"
+       fi
+       for mod in ${MODULES}; do
+               if ! has ${mod} ${SKIP_MODULES} && use xtables_addons_${mod}; 
then
+                       sed "s/\(build_${mod}=\).*/\1m/I" -i mconfig || die
+                       if use modules; then
+                               for module_name in $(XA_get_module_name 
${mod}); do
+                                       MODULE_NAMES+=" ${module_name}"
+                               done
+                       fi
+               else
+                       sed "s/\(build_${mod}=\).*/\1n/I" -i mconfig || die
+               fi
+       done
+       einfo "${MODULE_NAMES}" # for debugging
+
+       sed -e 's/depmod -a/true/' -i Makefile.in || die
+       sed -e '/^all-local:/{s: modules::}' \
+               -e '/^install-exec-local:/{s: modules_install::}' \
+                       -i extensions/Makefile.in || die
+
+       use xtables_addons_geoip || sed  -e '/^SUBDIRS/{s/geoip//}' -i 
Makefile.in
+
+       eapply_user
+}
+
+src_configure() {
+       set_arch_to_kernel # .. or it'll look for /arch/amd64/Makefile
+       econf --prefix="${EPREFIX}/" \
+               --libexecdir="${EPREFIX}/$(get_libdir)/" \
+               --with-kbuild="${KV_DIR}"
+}
+
+src_compile() {
+       emake CFLAGS="${CFLAGS}" CC="$(tc-getCC)" V=1
+       use modules && BUILD_PARAMS="V=1" BUILD_TARGETS="modules" 
linux-mod_src_compile
+}
+
+src_install() {
+       emake DESTDIR="${D}" install
+       use modules && linux-mod_src_install
+       dodoc -r README doc/*
+       find "${ED}" -type f -name '*.la' -exec rm -rf '{}' '+'
+}

Reply via email to