# Copyright 1999-2014 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 # $Id$ EAPI=3 inherit eutils pam toolchain-funcs versionator DESCRIPTION="Concurrent Versions System - source code revision control tools" HOMEPAGE="http://www.nongnu.org/cvs/" DOC_PV="$(get_version_component_range 1-3)" FEAT_URIBASE="mirror://gnu/non-gnu/cvs/source/feature/${PV}/" DOC_URIBASE="mirror://gnu/non-gnu/cvs/source/feature/${DOC_PV}/" SNAP_URIBASE="mirror://gnu/non-gnu/cvs/source/nightly-snapshots/feature/" SRC_URI=" ${FEAT_URIBASE}/${P}.tar.bz2 ${SNAP_URIBASE}/${P}.tar.bz2 doc? ( ${DOC_URIBASE}/cederqvist-${DOC_PV}.html.tar.bz2 ${DOC_URIBASE}/cederqvist-${DOC_PV}.pdf ${DOC_URIBASE}/cederqvist-${DOC_PV}.ps )" LICENSE="GPL-2 LGPL-2" SLOT="0" KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~m68k ~mips ~ppc ~ppc64 ~s390 ~sh ~sparc ~x86 ~ppc-aix ~sparc-fbsd ~x86-fbsd ~amd64-linux ~x86-linux ~ppc-macos ~x64-macos ~x86-macos ~m68k-mint ~sparc-solaris ~sparc64-solaris ~x64-solaris ~x86-solaris" IUSE="crypt doc kerberos nls pam server" RDEPEND=">=sys-libs/zlib-1.1.4 kerberos? ( virtual/krb5 ) pam? ( virtual/pam )" DEPEND="${RDEPEND}" src_unpack() { unpack ${P}.tar.bz2 use doc && unpack cederqvist-${DOC_PV}.html.tar.bz2 } src_prepare() { epatch "${FILESDIR}"/${PN}-1.12.12-cvsbug-tmpfix.patch epatch "${FILESDIR}"/${PN}-1.12.12-install-sh.patch epatch "${FILESDIR}"/${PN}-1.12.13.1-block-requests.patch epatch "${FILESDIR}"/${PN}-1.12.13.1-hash-nameclash.patch # for AIX epatch "${FILESDIR}"/${PN}-1.12.13.1-gl-mempcpy.patch # for AIX epatch "${FILESDIR}"/${PN}-1.12.12-fix-massive-leak.patch epatch "${FILESDIR}"/${PN}-1.12.13.1-use-include_next.patch epatch "${FILESDIR}"/${PN}-1.12.13.1-fix-gnulib-SEGV-vasnprintf.patch # Applied by upstream: #epatch "${FILESDIR}"/${PN}-1.12.13-openat.patch #epatch "${FILESDIR}"/${PN}-1.12.13-zlib.patch # this testcase was not updated #sed -i.orig -e '/unrecognized keyword.*BogusOption/s,98,73,g' \ # ${S}/src/sanity.sh # this one fails when the testpath path contains '.' sed -i.orig \ -e '/newfile config3/s,a-z,a-z.,g' \ "${S}"/src/sanity.sh elog "If you want any CVS server functionality, you MUST emerge with USE=server!" } src_configure() { local myconf # the tests need the server and proxy if use test; then use server || \ ewarn "The server and proxy code are enabled as they are required for tests." myconf="--enable-server --enable-proxy" fi if tc-is-cross-compiler ; then # Sane defaults when cross-compiling (as these tests want to # try and execute code). export cvs_cv_func_printf_ptr="yes" fi econf \ --with-external-zlib \ --with-tmpdir=/tmp \ $(use_enable crypt encryption) \ $(use_with kerberos gssapi) \ $(use_enable nls) \ $(use_enable pam) \ $(use_enable server) \ $(use_enable server proxy) \ ${myconf} } src_install() { emake install DESTDIR="${D}" || die if use server; then insinto /etc/xinetd.d newins "${FILESDIR}"/cvspserver.xinetd.d cvspserver || die "newins failed" fi dodoc BUGS ChangeLog* DEVEL* FAQ HACKING \ MINOR* NEWS PROJECTS README* TESTS TODO # Not installed into emacs site-lisp because it clobbers the normal C # indentations. dodoc cvs-format.el || die "dodoc failed" use server && newdoc "${FILESDIR}"/${PN}-1.12.12-cvs-custom.c cvs-custom.c if use doc; then dodoc "${DISTDIR}"/cederqvist-${DOC_PV}.pdf dodoc "${DISTDIR}"/cederqvist-${DOC_PV}.ps dohtml -r "${WORKDIR}"/cederqvist-${DOC_PV}.html/ dosym cvs.html /usr/share/doc/${PF}/html/index.html fi newpamd "${FILESDIR}"/cvs.pam-include-1.12.12 cvs } _run_one_test() { mode="$1" ; shift einfo "Starting ${mode} test" cd "${S}"/src export TESTDIR="${T}/tests-${mode}" rm -rf "$TESTDIR" # Clean up from any previous test passes mkdir -p "$TESTDIR" emake -j1 ${mode}check || die "Some ${mode} test failed." mv -f check.log check.log-${mode} einfo "${mode} test completed successfully, log is check.log-${mode}" } src_test() { einfo "If you want to see realtime status, or check out a failure," einfo "please look at ${S}/src/check.log*" if [ "$TEST_REMOTE_AND_PROXY" == "1" ]; then einfo "local, remote, and proxy tests enabled." else einfo "Only testing local mode. Please see ebuild for other modes." fi # we only do the local tests by default _run_one_test local # if you want to test the remote and proxy modes, things get a little bit # complicated. You need to set up a SSH config file at ~portage/.ssh/config # that allows the portage user to login without any authentication, and also # set up the ~portage/.ssh/known_hosts file for your machine. # We do not do this by default, as it is unsafe from a security point of # view, and requires root level ssh changes. # Note that this also requires having a real shell for the portage user, so make # sure that su -c 'ssh portage@mybox' portage works first! # (It uses the local ip, not loopback) if [ "$TEST_REMOTE_AND_PROXY" == "1" ]; then _run_one_test remote _run_one_test proxy fi }