blob: c8510ed983e74ddebbe2c7c82278f01b0f45ab06 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
# Copyright 1999-2021 Gentoo Authors
# Distributed under the terms of the GNU General Public License v2
EAPI=7
inherit toolchain-funcs
DESCRIPTION="DNS serial number incrementer and reverse zone builder"
SRC_URI="http://uranus.it.swin.edu.au/~jn/linux/${P}.tar.gz"
HOMEPAGE="https://wiki.gentoo.org/wiki/No_homepage"
LICENSE="GPL-2"
SLOT="0"
KEYWORDS="amd64 ppc x86"
RDEPEND="sys-apps/ed" # dnstouch calls ed to do the dirty work
src_prepare() {
default
eapply "${FILESDIR}"/${P}-binary-locations.patch
eapply "${FILESDIR}"/${P}-fix-pointer-comparison-with-0.patch
# match our bind config
sed -e 's|0.0.127.in-addr.arpa|127.in-addr.arpa|g' -i ndu.conf || die
# document the support for the chrooted BIND setup
cat >> ndu.conf <<-EOF || die
// if you use a chrooted setup, then you need to uncomment these lines:
//process "/chroot/dns/named.conf"
//chroot "/chroot/dns"
EOF
cd src || die
# use the correct compiler
sed -e 's|gcc|$(CXX)|g' -i Makefile || die
# set correct config pathes
sed -e 's|#define CONFIG_PATH "/etc/"|#define CONFIG_PATH "/etc/bind/"|g' \
-i ndu.cpp || die
sed -e 's|"/etc/ndu.conf"|"/etc/bind/ndu.conf"|g' -i dnstouch.cpp || die
# hack up something to work around bug #73858
sed -e 's|execlp("ed", "ed", filename, 0);|execlp("ed", "ed", "-s", filename, 0);|g' \
-i dnstouch.cpp || die
# use the correct editor
sed -e 's|VISUAL|EDITOR|g' -i dnsedit || die
}
src_compile() {
emake -C src CFLAGS="${CFLAGS}" CXX="$(tc-getCXX)"
}
src_install() {
dobin src/{dnsedit,ndu,dnstouch}
insinto /etc/bind
doins ndu.conf
dodoc README INSTALL
}
pkg_postinst() {
elog "The ndu binary expects to read your configuration"
elog "from /etc/bind/named.conf, however the other binaries"
elog "are useful with BIND locally installed."
}
|