commit:     20ea2072e04e1804fbe0b2c351b22167149ed272
Author:     Georgy Yakovlev <gyakovlev <AT> gentoo <DOT> org>
AuthorDate: Sun Dec  9 08:00:26 2018 +0000
Commit:     Georgy Yakovlev <gyakovlev <AT> gentoo <DOT> org>
CommitDate: Sun Dec  9 08:04:01 2018 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=20ea2072

sys-devel/distcc: revbump, fix distcc-config py2<-> py3 errors

error:
Creating symlinks...
Creating /usr/lib/distcc/bin/gcc symlink...
Creating /usr/lib/distcc/bin/cc symlink...
Creating /usr/lib/distcc/bin/c++ symlink...
Creating /usr/lib/distcc/bin/g++ symlink...
Traceback (most recent call last):
  File "/usr/bin/distcc-config", line 154, in <module>
    installlinks()
  File "/usr/bin/distcc-config", line 93, in installlinks
    lines = p.stdout.read().rstrip().split('\n')
TypeError: a bytes-like object is required, not 'str'

throw in extra .decode() to stdout.read()

Package-Manager: Portage-2.3.52, Repoman-2.3.12
Signed-off-by: Georgy Yakovlev <gyakovlev <AT> gentoo.org>

 sys-devel/distcc/distcc-3.3.2-r2.ebuild | 196 ++++++++++++++++++++++++++++++++
 sys-devel/distcc/files/distcc-config    | 180 +++++++++++++++++++++++++++++
 2 files changed, 376 insertions(+)

diff --git a/sys-devel/distcc/distcc-3.3.2-r2.ebuild 
b/sys-devel/distcc/distcc-3.3.2-r2.ebuild
new file mode 100644
index 00000000000..22f3c738ebd
--- /dev/null
+++ b/sys-devel/distcc/distcc-3.3.2-r2.ebuild
@@ -0,0 +1,196 @@
+# Copyright 1999-2018 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=6
+
+PYTHON_COMPAT=( python3_{5,6} )
+
+inherit autotools flag-o-matic python-single-r1 systemd \
+       toolchain-funcs user xdg-utils prefix
+
+DESCRIPTION="Distribute compilation of C code across several machines on a 
network"
+HOMEPAGE="http://distcc.org/";
+SRC_URI="https://github.com/${PN}/${PN}/releases/download/v${PV}/${P}.tar.gz";
+
+LICENSE="GPL-2+"
+SLOT="0"
+KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~mips ~ppc ~ppc64 ~sparc ~x86"
+IUSE="gnome gssapi gtk hardened ipv6 selinux xinetd zeroconf"
+
+RESTRICT="test"
+
+CDEPEND="${PYTHON_DEPS}
+       dev-libs/popt
+       gnome? (
+               >=gnome-base/libgnome-2
+               >=gnome-base/libgnomeui-2
+               x11-libs/gtk+:2
+               x11-libs/pango
+       )
+       gssapi? ( net-libs/libgssglue )
+       gtk? ( x11-libs/gtk+:2 )
+       zeroconf? ( >=net-dns/avahi-0.6[dbus] )
+"
+DEPEND="${CDEPEND}
+       sys-libs/binutils-libs
+       virtual/pkgconfig"
+RDEPEND="${CDEPEND}
+       !net-misc/pump
+       dev-util/shadowman
+       >=sys-devel/gcc-config-1.4.1
+       selinux? ( sec-policy/selinux-distcc )
+       xinetd? ( sys-apps/xinetd )"
+
+REQUIRED_USE="${PYTHON_REQUIRED_USE}"
+
+S="${WORKDIR}/distcc"
+
+pkg_setup() {
+       enewuser distcc 240 -1 -1 daemon
+       python-single-r1_pkg_setup
+}
+
+src_prepare() {
+       eapply "${FILESDIR}/${PN}-3.0-xinetd.patch"
+       # bug #255188
+       eapply "${FILESDIR}/${PN}-3.3.2-freedesktop.patch"
+       # SOCKSv5 support needed for Portage, bug #537616
+       eapply "${FILESDIR}/${PN}-3.2_rc1-socks5.patch"
+       eapply_user
+
+       # Bugs #120001, #167844 and probably more. See patch for description.
+       use hardened && eapply "${FILESDIR}/distcc-hardened.patch"
+
+       sed -i \
+               -e "/PATH/s:\$distcc_location:${EPREFIX}/usr/lib/distcc/bin:" \
+               -e "s:@PYTHON@:${EPYTHON}:" \
+               pump.in || die "sed failed"
+
+       sed \
+               -e "s:@EPREFIX@:${EPREFIX:-/}:" \
+               -e "s:@libdir@:/usr/lib:" \
+               "${FILESDIR}/distcc-config" > "${T}/distcc-config" || die
+
+       hprefixify update-distcc-symlinks.py src/{serve,daemon}.c
+       python_fix_shebang update-distcc-symlinks.py "${T}/distcc-config"
+       eautoreconf
+}
+
+src_configure() {
+       local myconf=(
+               --disable-Werror
+               $(use_enable ipv6 rfc2553)
+               $(use_with gtk)
+               $(use_with gnome)
+               $(use_with gssapi auth)
+               $(use_with zeroconf avahi)
+       )
+
+       econf "${myconf[@]}"
+}
+
+src_install() {
+       # override GZIP_BIN to stop it from compressing manpages
+       emake DESTDIR="${D}" GZIP_BIN=false install
+       python_optimize
+
+       newinitd "${FILESDIR}/distccd.initd" distccd
+       systemd_dounit "${FILESDIR}/distccd.service"
+       systemd_install_serviced "${FILESDIR}/distccd.service.conf"
+
+       cp "${FILESDIR}/distccd.confd" "${T}/distccd" || die
+       if use zeroconf; then
+               cat >> "${T}/distccd" <<-EOF || die
+
+               # Enable zeroconf support in distccd
+               DISTCCD_OPTS="\${DISTCCD_OPTS} --zeroconf"
+               EOF
+
+               sed -i '/ExecStart/ s|$| --zeroconf|' 
"${D}$(systemd_get_systemunitdir)"/distccd.service || die
+       fi
+       doconfd "${T}/distccd"
+
+       newenvd - 02distcc <<-EOF || die
+       # This file is managed by distcc-config; use it to change these 
settings.
+       # DISTCC_LOG and DISTCC_DIR should not be set.
+       DISTCC_VERBOSE="${DISTCC_VERBOSE:-0}"
+       DISTCC_FALLBACK="${DISTCC_FALLBACK:-1}"
+       DISTCC_SAVE_TEMPS="${DISTCC_SAVE_TEMPS:-0}"
+       DISTCC_TCP_CORK="${DISTCC_TCP_CORK}"
+       DISTCC_SSH="${DISTCC_SSH}"
+       UNCACHED_ERR_FD="${UNCACHED_ERR_FD}"
+       DISTCC_ENABLE_DISCREPANCY_EMAIL="${DISTCC_ENABLE_DISCREPANCY_EMAIL}"
+       DCC_EMAILLOG_WHOM_TO_BLAME="${DCC_EMAILLOG_WHOM_TO_BLAME}"
+       EOF
+
+       keepdir /usr/lib/distcc
+
+       dobin "${T}/distcc-config"
+
+       if use gnome || use gtk; then
+               einfo "Renaming /usr/bin/distccmon-gnome to 
/usr/bin/distccmon-gui"
+               einfo "This is to have a little sensability in naming schemes 
between distccmon programs"
+               mv "${ED}/usr/bin/distccmon-gnome" 
"${ED}/usr/bin/distccmon-gui" || die
+               dosym distccmon-gui /usr/bin/distccmon-gnome
+       fi
+
+       if use xinetd; then
+               insinto /etc/xinetd.d
+               newins "doc/example/xinetd" distcc
+       fi
+
+       insinto /usr/share/shadowman/tools
+       newins - distcc <<<"${EPREFIX}/usr/lib/distcc/bin"
+       newins - distccd <<<"${EPREFIX}/usr/lib/distcc"
+
+       rm -r "${ED}/etc/default" || die
+       rm "${ED}/etc/distcc/clients.allow" || die
+       rm "${ED}/etc/distcc/commands.allow.sh" || die
+}
+
+pkg_postinst() {
+       # remove the old paths when switching from libXX to lib
+       if [[ $(get_libdir) != lib && ${SYMLINK_LIB} != yes && \
+                       -d ${EROOT%/}/usr/$(get_libdir)/distcc ]]; then
+               rm -r -f "${EROOT%/}/usr/$(get_libdir)/distcc" || die
+       fi
+
+       if [[ ${ROOT} == / ]]; then
+               eselect compiler-shadow update distcc
+               eselect compiler-shadow update distccd
+       fi
+
+       use gnome && xdg_desktop_database_update
+
+       elog
+       elog "Tips on using distcc with Gentoo can be found at"
+       elog "https://wiki.gentoo.org/wiki/Distcc";
+       elog
+       elog "distcc-pump is known to cause breakage with multiple packages."
+       elog "Do NOT enable it globally."
+       elog
+       elog "To use the distccmon programs with Gentoo you should use this 
command:"
+       elog "# DISTCC_DIR=\"${DISTCC_DIR:-${BUILD_PREFIX}/.distcc}\" 
distccmon-text 5"
+
+       if use gnome || use gtk; then
+               elog "Or:"
+               elog "# DISTCC_DIR=\"${DISTCC_DIR:-${BUILD_PREFIX}/.distcc}\" 
distccmon-gnome"
+       fi
+
+       elog
+       elog "***SECURITY NOTICE***"
+       elog "Since distcc-3.3, whitelist is used for what distccd could 
execute. The whilelist"
+       elog "has been generated by compiler-shadow distccd.  To revert to the 
old behavior, "
+       elog "you need to pass --make-me-a-botnet to distccd in 
/etc/conf.d/distccd."
+       elog "Cf. https://github.com/distcc/distcc/pull/243.";
+}
+
+pkg_prerm() {
+       if [[ -z ${REPLACED_BY_VERSION} && ${ROOT} == / ]]; then
+               eselect compiler-shadow remove distcc
+       fi
+}
+
+pkg_postrm() {
+       use gnome && xdg_desktop_database_update
+}

diff --git a/sys-devel/distcc/files/distcc-config 
b/sys-devel/distcc/files/distcc-config
new file mode 100644
index 00000000000..974620d107f
--- /dev/null
+++ b/sys-devel/distcc/files/distcc-config
@@ -0,0 +1,180 @@
+#!/usr/bin/env python
+# Copyright 1999-2018 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+import os, re, signal, subprocess, sys
+
+options=[
+       '--get-hosts',
+       '--set-hosts',
+       '--get-verbose',
+       '--set-verbose',
+       '--get-log',
+       '--set-log',
+       '--update-masquerade',
+       '--update-masquerade-with-crossdev',
+       '--help',
+       '--get-env',
+       '--set-env'
+]
+
+tmpcmdline=sys.argv[1:]
+cmdline=[]
+
+eprefix = '@EPREFIX@'
+bindir = os.path.join(eprefix, 'usr', 'bin')
+sbindir = os.path.join(eprefix, 'usr', 'sbin')
+libdir = os.path.join(eprefix, '@libdir@')
+sysconfdir = os.path.join(eprefix, 'etc')
+
+gcc_config = os.path.join(bindir, 'gcc-config')
+env_update = os.path.join(sbindir, 'env-update')
+envfile = os.path.join(sysconfdir, 'env.d', '02distcc')
+default_distcc_dir = os.path.join(sysconfdir, 'distcc')
+hostfile = os.path.join(default_distcc_dir, 'hosts')
+distcc_path = os.path.join(bindir, 'distcc')
+dccc_dir = os.path.join(libdir, 'distcc', 'bin')
+
+def exithandler(foo,bar):
+       os.kill(0,signal.SIGKILL)
+       sys.exit(1)
+
+signal.signal(signal.SIGINT,exithandler)
+
+def isroot(ret=0):
+       if os.getuid() != 0:
+               if ret == 0:
+                       print('!!! %s %s must be run as root' % 
(sys.argv[:1][0],tmpcmdline[0]))
+                       sys.exit(1)
+               else:
+                       retval = 0
+       else:
+               retval = 1
+       return retval
+
+def writeenv(var,value):
+       isroot()
+       distcc_env    = []
+       distcc_env    = open(envfile, 'r').readlines()
+       distcc_env_new = open(envfile, 'w')
+       for i in range(len(distcc_env)):
+               if re.compile(var+'="(.*)"').match(distcc_env[i]):
+                       distcc_env[i] = var+'="'+value+'"\n'
+               distcc_env_new.write(distcc_env[i])
+       #print('Set %s to: %s ' % (var,value))
+       subprocess.Popen(env_update, shell=True)
+       print('If you want to use these new settings in an existing shell,')
+       print('you need to "source /etc/profile" to get the changes.')
+
+def readenv(var):
+       distcc_env = open(envfile, 'r').read()
+       match = re.compile(var+'="(.*)"').search(distcc_env)
+       if match:
+               print(var+'='+match.group(1))
+       else:
+               print(var,'not set.')
+
+def installlink(chost='', version=''):
+       for file in ['gcc', 'cc', 'c++', 'g++']:
+               if not chost == '':
+                       file = '%s-%s' % (chost,file)
+               if not version == '':
+                       file = '%s-%s' % (file,version)
+               path = os.path.join(dccc_dir,file)
+               if os.path.exists(os.path.join(bindir,file)):
+                       if not os.path.exists(path):
+                               print('Creating %s symlink...' % (path))
+                               os.symlink(distcc_path,path)
+                       #else:
+                       #       print('Already exists. Skipping...')
+
+def installlinks():
+       p = subprocess.Popen([gcc_config+" -C -l"], shell=True, 
stdout=subprocess.PIPE)
+       lines = p.stdout.read().decode().rstrip().split('\n')
+       for line in lines:
+               columns = line.split()
+               if len(columns) >= 2:
+                       matches = re.match("(.*)-(.*)", columns[1])
+                       chost = matches.group(1)
+                       version = matches.group(2)
+                       installlink(chost)
+                       installlink(chost, version)
+
+def uninstalllinks():
+       for root, dirs, files in os.walk(dccc_dir):
+               for file in files:
+                       os.remove(os.path.join(root, file))
+
+def createdistccdir(dir):
+       if not os.path.exists(dir):
+               os.mkdir(dir)
+               os.chmod(dir, 0o755)
+
+for x in tmpcmdline:
+       if not x:
+               continue
+       if x[0:2]=="--":
+               if not x in options:
+                       print("!!! Error: %s is an invalid option." % (x))
+                       sys.exit(1)
+       else:
+               cmdline = x
+
+if '--get-hosts' in tmpcmdline:
+       HOSTS_ENV  = os.environ.get('DISTCC_HOSTS')
+       HOSTS_HOME = os.path.join(os.environ.get('HOME'), '.distcc', 'hosts')
+       if HOSTS_ENV:
+               print(HOSTS_ENV)
+       elif os.path.isfile(HOSTS_HOME) and os.path.getsize(HOSTS_HOME) != 0:
+               print(HOSTS_HOME)
+       elif os.path.exists(hostfile):
+               print(open(hostfile, 'r').read().rstrip())
+       else:
+               print('No configuration file found. Setup your hosts with 
--set-hosts.')
+elif '--set-hosts' in tmpcmdline:
+       if isroot(1):
+               PATH = default_distcc_dir
+       else:
+               PATH = os.path.join(os.environ.get('HOME'), '.distcc')
+       createdistccdir(PATH)
+       open(os.path.join(PATH, 'hosts'), 'w').write(cmdline + '\n')
+elif '--get-verbose' in tmpcmdline:
+       readenv('DISTCC_VERBOSE')
+elif '--set-verbose' in tmpcmdline:
+       writeenv('DISTCC_VERBOSE',tmpcmdline[1])
+elif '--get-log' in tmpcmdline:
+       readenv('DISTCC_LOG')
+elif '--set-log' in tmpcmdline:
+       writeenv('DISTCC_LOG',tmpcmdline[1])
+elif '--update-masquerade' in tmpcmdline:
+       isroot()
+       uninstalllinks()
+       print('Creating symlinks...')
+       installlink()
+       installlinks()
+elif '--update-masquerade-with-crossdev' in tmpcmdline:
+       isroot()
+       uninstalllinks()
+       print('Creating symlinks...')
+       installlinks()
+elif '--get-env' in tmpcmdline:
+       if len(tmpcmdline) == 1:
+               print(open(envfile, 'r').read().rstrip())
+       elif len(tmpcmdline) == 2:
+               readenv(tmpcmdline[1])
+       else:
+               print('!!! Error: Specify only one variable.')
+elif '--set-env' in tmpcmdline:
+       if len(tmpcmdline) > 2 and len(tmpcmdline) <= 3:
+               isroot()
+               writeenv(tmpcmdline[1],tmpcmdline[2])
+       else:
+               print('!!! Error: Awaiting two parameters.')
+else:
+       cmd = sys.argv[:1][0]
+       print('Usage: %s --set-hosts DISTCC_HOSTS | --get-hosts' % (cmd))
+       print('       %s --set-verbose { 0 | 1 }  | --get-verbose' % (cmd))
+       print('       %s --set-log FILE           | --get-log' % (cmd))
+       print('       %s --set-env VARIABLE VALUE | --get-env [VARIABLE]' % 
(cmd))
+       print('       %s --update-masquerade' % (cmd))
+       print('       %s --update-masquerade-with-crossdev' % (cmd))

Reply via email to