diff options
author | Zac Medico <zmedico@gentoo.org> | 2016-10-20 00:35:33 -0700 |
---|---|---|
committer | Zac Medico <zmedico@gentoo.org> | 2016-10-20 00:37:04 -0700 |
commit | b53e33c650566e5455b695c9ee78f3325e06895c (patch) | |
tree | ac5a3efab9606711dcea005071978beff12429a6 /app-admin/consul-template/consul-template-0.16.0.ebuild | |
parent | net-misc/youtube-dl: Old. (diff) | |
download | gentoo-b53e33c650566e5455b695c9ee78f3325e06895c.tar.gz gentoo-b53e33c650566e5455b695c9ee78f3325e06895c.tar.bz2 gentoo-b53e33c650566e5455b695c9ee78f3325e06895c.zip |
app-admin/consul-template: version bump to 0.16.0
Package-Manager: portage-2.3.2
Diffstat (limited to 'app-admin/consul-template/consul-template-0.16.0.ebuild')
-rw-r--r-- | app-admin/consul-template/consul-template-0.16.0.ebuild | 119 |
1 files changed, 119 insertions, 0 deletions
diff --git a/app-admin/consul-template/consul-template-0.16.0.ebuild b/app-admin/consul-template/consul-template-0.16.0.ebuild new file mode 100644 index 000000000000..ff553accb848 --- /dev/null +++ b/app-admin/consul-template/consul-template-0.16.0.ebuild @@ -0,0 +1,119 @@ +# Copyright 1999-2016 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Id$ + +EAPI=6 + +inherit golang-base systemd user + +KEYWORDS="~amd64" +DESCRIPTION="Generic template rendering and notifications with Consul" +EGO_PN="github.com/hashicorp/${PN}/..." +HOMEPAGE="http://${EGO_PN%/*}" +LICENSE="MPL-2.0" +SLOT="0" +IUSE="" +RESTRICT="test" + +DEPEND=">=dev-lang/go-1.6:=" +RDEPEND="" + +SRC_URI="https://${EGO_PN%/*}/archive/v${PV}.tar.gz -> ${P}.tar.gz + https://github.com/mitchellh/gox/archive/c9740af9c6574448fd48eb30a71f964014c7a837.tar.gz -> gox-c9740af9c6574448fd48eb30a71f964014c7a837.tar.gz + https://github.com/mitchellh/iochan/archive/87b45ffd0e9581375c491fef3d32130bb15c5bd7.tar.gz -> iochan-87b45ffd0e9581375c491fef3d32130bb15c5bd7.tar.gz +" + +STRIP_MASK="*.a" + +pkg_setup() { + enewgroup ${PN} + enewuser ${PN} -1 -1 -1 ${PN} +} + +get_archive_go_package() { + local archive=${1} uri x + for x in ${SRC_URI}; do + if [[ ${x} == http* ]]; then + uri=${x} + elif [[ ${x} == ${archive} ]]; then + break + fi + done + uri=${uri#https://} + echo ${uri%/archive/*} +} + +unpack_go_packages() { + local go_package x + # Unpack packages to appropriate locations for GOPATH + for x in ${A}; do + unpack ${x} + if [[ ${x} == *.tar.gz ]]; then + go_package=$(get_archive_go_package ${x}) + mkdir -p src/${go_package%/*} + mv ${go_package##*/}-* src/${go_package} || die + fi + done +} + +src_unpack() { + mkdir "${S}" && cd "${S}" || die + unpack_go_packages +} + +src_prepare() { + eapply_user + # Avoid the need to have a git checkout + sed -e 's:^GIT.*::' -i src/${EGO_PN%/*}/scripts/build.sh || die +} + +src_compile() { + export GOPATH=${S} + go install -v -work -x ${EGO_BUILD_FLAGS} "github.com/mitchellh/gox/..." || die + go install -v -work -x ${EGO_BUILD_FLAGS} "${EGO_PN}" || die + # the previous command returns 2 on success... + #[[ -d ${S}/pkg/$(go env GOOS)_$(go env GOARCH)/${EGO_PN%/*} ]] || die + cd "${S}"/src/${EGO_PN%/*} || die + PATH=${PATH}:${S}/bin \ + XC_ARCH=$(go env GOARCH) \ + XC_OS=$(go env GOOS) \ + emake bin +} + +src_test() { + cd "${S}"/src/${EGO_PN%/*} || die + emake test || die +} + +src_install() { + dobin "${S}/bin/${PN}" + dodoc "${S}"/src/${EGO_PN%/*}/{CHANGELOG.md,README.md} + + keepdir /var/log/${PN} + fowners ${PN}:${PN} /var/log/${PN} + + newinitd "${FILESDIR}/${PN}.initd" "${PN}" + insinto /etc/logrotate.d + newins "${FILESDIR}/${PN}.logrotated" "${PN}" + newconfd "${FILESDIR}/${PN}.confd" "${PN}" + systemd_dounit "${FILESDIR}/${PN}.service" + + keepdir /etc/${PN}.d + insinto /etc/${PN}.d + doins "${FILESDIR}/"*.json.example + + rm -rf "${S}"/{src,pkg/$(go env GOOS)_$(go env GOARCH)}/${EGO_PN%/*}/vendor + find "${S}"/src/${EGO_PN%/*} -mindepth 1 -maxdepth 1 -type f -delete || die + + while read -r -d '' x; do + x=${x#${S}/src} + [[ -d ${S}/pkg/$(go env GOOS)_$(go env GOARCH)/${x} || + -f ${S}/pkg/$(go env GOOS)_$(go env GOARCH)/${x}.a ]] && continue + rm -rf "${S}"/src/${x} + done < <(find "${S}"/src/${EGO_PN%/*} -mindepth 1 -maxdepth 1 -type d -print0) + insopts -m0644 -p # preserve timestamps for bug 551486 + insinto $(dirname "$(get_golibdir)/pkg/$(go env GOOS)_$(go env GOARCH)/${EGO_PN%/*}") + doins -r "${S}"/pkg/$(go env GOOS)_$(go env GOARCH)/${EGO_PN%/*} + insinto $(dirname "$(get_golibdir)/src/${EGO_PN%/*}") + doins -r "${S}"/src/${EGO_PN%/*} +} |