diff options
author | Dirkjan Ochtman <djc@gentoo.org> | 2014-05-08 08:19:02 +0000 |
---|---|---|
committer | Dirkjan Ochtman <djc@gentoo.org> | 2014-05-08 08:19:02 +0000 |
commit | dc6da84d40842c97b396ae410a8f21ad1e4c466f (patch) | |
tree | 4663fc44aa9b5fd06c3307f2658422245efac975 | |
parent | Migrate to git-r3 eclass (diff) | |
download | gentoo-2-dc6da84d40842c97b396ae410a8f21ad1e4c466f.tar.gz gentoo-2-dc6da84d40842c97b396ae410a8f21ad1e4c466f.tar.bz2 gentoo-2-dc6da84d40842c97b396ae410a8f21ad1e4c466f.zip |
Fix erlang systemd dependency (bug 508366).
(Portage version: 2.2.10/cvs/Linux x86_64, signed Manifest commit with key 30380381)
-rw-r--r-- | dev-lang/erlang/ChangeLog | 8 | ||||
-rw-r--r-- | dev-lang/erlang/erlang-17.0-r1.ebuild | 162 | ||||
-rw-r--r-- | dev-lang/erlang/files/17.0-systemd.patch | 85 |
3 files changed, 254 insertions, 1 deletions
diff --git a/dev-lang/erlang/ChangeLog b/dev-lang/erlang/ChangeLog index 4da00f581705..74b6795111f8 100644 --- a/dev-lang/erlang/ChangeLog +++ b/dev-lang/erlang/ChangeLog @@ -1,6 +1,12 @@ # ChangeLog for dev-lang/erlang # Copyright 1999-2014 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/dev-lang/erlang/ChangeLog,v 1.252 2014/04/24 11:34:28 djc Exp $ +# $Header: /var/cvsroot/gentoo-x86/dev-lang/erlang/ChangeLog,v 1.253 2014/05/08 08:19:02 djc Exp $ + +*erlang-17.0-r1 (08 May 2014) + + 08 May 2014; Dirkjan Ochtman <djc@gentoo.org> +erlang-17.0-r1.ebuild, + +files/17.0-systemd.patch: + Fix erlang systemd dependency (bug 508366). 24 Apr 2014; Dirkjan Ochtman <djc@gentoo.org> erlang-17.0.ebuild: Remove now-useless elogs for 17.0. diff --git a/dev-lang/erlang/erlang-17.0-r1.ebuild b/dev-lang/erlang/erlang-17.0-r1.ebuild new file mode 100644 index 000000000000..72d336cda36f --- /dev/null +++ b/dev-lang/erlang/erlang-17.0-r1.ebuild @@ -0,0 +1,162 @@ +# Copyright 1999-2014 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/dev-lang/erlang/erlang-17.0-r1.ebuild,v 1.1 2014/05/08 08:19:02 djc Exp $ + +EAPI=4 +WX_GTK_VER="2.8" + +inherit autotools elisp-common eutils java-pkg-opt-2 multilib systemd versionator wxwidgets + +# NOTE: If you need symlinks for binaries please tell maintainers or +# open up a bug to let it be created. + +DESCRIPTION="Erlang programming language, runtime environment, and large collection of libraries" +HOMEPAGE="http://www.erlang.org/" +SRC_URI="http://www.erlang.org/download/otp_src_${PV}.tar.gz + http://erlang.org/download/otp_doc_man_${PV}.tar.gz + doc? ( http://erlang.org/download/otp_doc_html_${PV}.tar.gz )" + +LICENSE="ErlPL-1.1" +SLOT="0" +KEYWORDS="~alpha ~amd64 ~arm ~ia64 ~ppc ~ppc64 ~sparc ~x86 ~x86-fbsd ~x86-freebsd ~amd64-linux ~x86-linux ~ppc-macos ~x64-macos ~x86-macos ~x64-solaris" +IUSE="compat-ethread doc emacs halfword hipe java kpoll odbc smp sctp ssl systemd tk wxwidgets" + +RDEPEND=">=dev-lang/perl-5.6.1 + ssl? ( >=dev-libs/openssl-0.9.7d ) + emacs? ( virtual/emacs ) + java? ( >=virtual/jdk-1.2 ) + odbc? ( dev-db/unixODBC )" +DEPEND="${RDEPEND} + wxwidgets? ( x11-libs/wxGTK:2.8[X,opengl] virtual/glu ) + sctp? ( net-misc/lksctp-tools ) + tk? ( dev-lang/tk )" + +S="${WORKDIR}/otp_src_${PV}" + +SITEFILE=50${PN}-gentoo.el + +pkg_setup() { + if use halfword ; then + use amd64 || die "halfword support is limited to amd64" + fi +} + +src_prepare() { + use odbc || sed -i 's: odbc : :' lib/Makefile + + # bug 263129, don't ignore LDFLAGS, reported upstream + sed -e 's:LDFLAGS = \$(DED_LDFLAGS):LDFLAGS += \$(DED_LDFLAGS):' -i "${S}"/lib/megaco/src/flex/Makefile.in + + # don't ignore LDFLAGS, reported upstream + sed -e 's:LDFLAGS = \$(ODBC_LIB) \$(EI_LDFLAGS):LDFLAGS += \$(ODBC_LIB) \$(EI_LDFLAGS):' -i "${S}"/lib/odbc/c_src/Makefile.in + + if ! use wxwidgets; then + sed -i 's: wx : :' lib/Makefile + rm -rf lib/wx + fi + + # bug 508366: systemd dependency, turn it off by default + epatch "${FILESDIR}/${PV}-systemd.patch" + + # Nasty workaround, reported upstream + cp "${S}"/lib/configure.in.src "${S}"/lib/configure.in + + # bug 383697 + sed -i '1i#define OF(x) x' erts/emulator/drivers/common/gzio.c + cd erts && eautoreconf +} + +src_configure() { + use java || export JAVAC=false + + econf \ + --enable-threads \ + $(use_enable sctp) \ + $(use_enable systemd) \ + $(use_enable halfword halfword-emulator) \ + $(use_enable hipe) \ + $(use_with ssl ssl "${EPREFIX}"/usr) \ + $(use_enable ssl dynamic-ssl-lib) \ + $(use_enable kpoll kernel-poll) \ + $(use_enable smp smp-support) \ + $(use compat-ethread && echo "--enable-ethread-pre-pentium4-compatibility") \ + $(use x64-macos && echo "--enable-darwin-64bit") +} + +src_compile() { + use java || export JAVAC=false + emake + + if use emacs ; then + pushd lib/tools/emacs + elisp-compile *.el + popd + fi +} + +extract_version() { + sed -n -e "/^$2 = \(.*\)$/s::\1:p" "${S}/$1/vsn.mk" +} + +src_install() { + local ERL_LIBDIR=/usr/$(get_libdir)/erlang + local ERL_INTERFACE_VER=$(extract_version lib/erl_interface EI_VSN) + local ERL_ERTS_VER=$(extract_version erts VSN) + + emake INSTALL_PREFIX="${D}" install + dodoc AUTHORS README.md + + dosym "${ERL_LIBDIR}/bin/erl" /usr/bin/erl + dosym "${ERL_LIBDIR}/bin/erlc" /usr/bin/erlc + dosym "${ERL_LIBDIR}/bin/escript" /usr/bin/escript + dosym \ + "${ERL_LIBDIR}/lib/erl_interface-${ERL_INTERFACE_VER}/bin/erl_call" \ + /usr/bin/erl_call + dosym "${ERL_LIBDIR}/erts-${ERL_ERTS_VER}/bin/beam" /usr/bin/beam + use smp && dosym "${ERL_LIBDIR}/erts-${ERL_ERTS_VER}/bin/beam.smp" /usr/bin/beam.smp + + ## Remove ${D} from the following files + sed -e "s:${D}::g" -i "${ED}${ERL_LIBDIR}/bin/erl" + sed -e "s:${D}::g" -i "${ED}${ERL_LIBDIR}/bin/start" + grep -rle "${D}" "${ED}/${ERL_LIBDIR}/erts-${ERL_ERTS_VER}" | xargs sed -i -e "s:${D}::g" + + ## Clean up the no longer needed files + rm "${ED}/${ERL_LIBDIR}/Install" + + for i in "${WORKDIR}"/man/man* ; do + dodir "${ERL_LIBDIR}/${i##${WORKDIR}}" + done + for file in "${WORKDIR}"/man/man*/*.[1-9]; do + # doman sucks so we can't use it + cp ${file} "${ED}/${ERL_LIBDIR}"/man/man${file##*.}/ + done + # extend MANPATH, so the normal man command can find it + # see bug 189639 + dodir /etc/env.d/ + echo "MANPATH=\"${EPREFIX}${ERL_LIBDIR}/man\"" > "${ED}/etc/env.d/90erlang" + + if use doc ; then + dohtml -A README,erl,hrl,c,h,kwc,info -r \ + "${WORKDIR}"/doc "${WORKDIR}"/lib "${WORKDIR}"/erts-* + fi + + if use emacs ; then + pushd "${S}" + elisp-install erlang lib/tools/emacs/*.{el,elc} + sed -e "s:/usr/share:${EPREFIX}/usr/share:g" \ + "${FILESDIR}"/${SITEFILE} > "${T}"/${SITEFILE} + elisp-site-file-install "${T}"/${SITEFILE} + popd + fi + + newinitd "${FILESDIR}"/epmd.init epmd + systemd_dounit "${FILESDIR}"/epmd.service +} + +pkg_postinst() { + use emacs && elisp-site-regen +} + +pkg_postrm() { + use emacs && elisp-site-regen +} diff --git a/dev-lang/erlang/files/17.0-systemd.patch b/dev-lang/erlang/files/17.0-systemd.patch new file mode 100644 index 000000000000..2dba8c897fe6 --- /dev/null +++ b/dev-lang/erlang/files/17.0-systemd.patch @@ -0,0 +1,85 @@ +--- erts/configure.in 2014-05-08 10:07:18.691087332 +0200 ++++ erts/configure.in 2014-05-08 10:12:56.579375822 +0200 +@@ -366,6 +366,11 @@ + $with_assumed_cache_line_size, + [Assumed cache-line size (in bytes)]) + ++AC_ARG_ENABLE(systemd, ++AS_HELP_STRING([--enable-systemd], [enable systemd support in epmd]), ++[], ++[enable_systemd=no]) ++ + dnl Magic test for clearcase. + OTP_RELEASE= + if test "${ERLANG_COMMERCIAL_BUILD}" != ""; then +@@ -1042,8 +1047,6 @@ + AC_CHECK_LIB(inet, main) + AC_CHECK_LIB(util, openpty) + +-AC_CHECK_LIB(systemd-daemon, sd_listen_fds) +- + dnl Try to find a thread library. + dnl + dnl ETHR_LIB_NAME, ETHR_LIBS, ETHR_X_LIBS, ETHR_THR_LIB_BASE and ETHR_DEFS +@@ -1679,7 +1682,29 @@ + #endif + ]) + +-AC_CHECK_HEADERS(systemd/sd-daemon.h) ++dnl ---------------------------------------------------------------------- ++dnl Check the availability of systemd ++dnl ---------------------------------------------------------------------- ++if test x"$enable_systemd" != x"no"; then ++ ++systemd_daemon_save_LIBS=$LIBS ++LIBS= ++AC_SEARCH_LIBS(sd_listen_fds,[systemd systemd-daemon], ++ [have_sd_listen_fds=yes],[have_sd_listen_fds=no],$systemd_daemon_save_LIBS) ++AC_CHECK_HEADERS(systemd/sd-daemon.h, ++ [have_systemd_sd_daemon_h=yes],[have_systemd_sd_daemon_h=no]) ++ ++if test x"$have_sd_listen_fds" = x"yes" && \ ++ test x"$have_systemd_sd_daemon_h" = x"yes"; then ++ AC_DEFINE([HAVE_SYSTEMD_DAEMON],[1],[Define if you have systemd daemon]) ++ SYSTEMD_DAEMON_LIBS=$LIBS ++elif test x"$enable_systemd" = x"yes"; then ++ AC_MSG_FAILURE([--enable-systemd was given, but test for systemd failed]) ++fi ++LIBS=$systemd_daemon_save_LIBS ++fi ++AC_SUBST(SYSTEMD_DAEMON_LIBS) ++ + + dnl ---------------------------------------------------------------------- + dnl Check the availability for libdlpi +--- erts/epmd/src/Makefile.in 2014-05-08 10:07:58.344182314 +0200 ++++ erts/epmd/src/Makefile.in 2014-05-08 10:12:56.580375784 +0200 +@@ -84,7 +84,7 @@ + ifeq ($(findstring ose,$(TARGET)),ose) + LIBS = $(ERTS_INTERNAL_LIBS) @LIBS@ + else +-LIBS = @LIBS@ $(ERTS_INTERNAL_LIBS) ++LIBS = @LIBS@ @SYSTEMD_DAEMON_LIBS@ $(ERTS_INTERNAL_LIBS) + endif + LDFLAGS = @LDFLAGS@ + +--- erts/epmd/src/epmd_srv.c 2014-05-08 10:07:49.137392770 +0200 ++++ erts/epmd/src/epmd_srv.c 2014-05-08 10:12:39.777759407 +0200 +@@ -213,7 +213,7 @@ + node_init(g); + g->conn = conn_init(g); + +-#ifdef HAVE_SYSTEMD_SD_DAEMON_H ++#ifdef HAVE_SYSTEMD_DAEMON + if (g->is_systemd) + { + int n; +@@ -310,7 +310,7 @@ + SET_ADDR(iserv_addr[0],EPMD_ADDR_ANY,sport); + num_sockets = 1; + } +-#ifdef HAVE_SYSTEMD_SD_DAEMON_H ++#ifdef HAVE_SYSTEMD_DAEMON + } + #endif + |