dev-lang/go: version bump for 1.5
authorWilliam Hubbs <williamh@gentoo.org>
Fri, 21 Aug 2015 00:32:00 +0000 (19:32 -0500)
committerWilliam Hubbs <williamh@gentoo.org>
Fri, 21 Aug 2015 00:36:12 +0000 (19:36 -0500)
This is for bug #558200.

dev-lang/go/Manifest
dev-lang/go/go-1.5.ebuild [new file with mode: 0644]

index dfae9c0a277988b93af3d313a167eb46c609d826..b136b3223ba6d863385be01a02eccb072e83dfd5 100644 (file)
@@ -1 +1,2 @@
 DIST go1.4.2.src.tar.gz 10921896 SHA256 299a6fd8f8adfdce15bc06bde926e7b252ae8e24dd5b16b7d8791ed79e7b5e9b SHA512 cda1a29d4418875dffaf3324004ddae8e1bbb573f7668e6e0c03d8b61284f4db7fca244c181f2859f8ccdd3db6391fb21e0d98a1a9fc15096c15883249d48a9c WHIRLPOOL d06c27f6ff3a6499a6c7cb3c5eccd53eb588896c4d837e1fe9855c22ee3caa5cc48fd68cbeceff105b7c47fafbbf0eb3dc28ee3af7196692c5bf18511c6760ef
+DIST go1.5.src.tar.gz 12045689 SHA256 be81abec996d5126c05f2d36facc8e58a94d9183a56f026fc9441401d80062db SHA512 dac657d3ce8226e247449ce8b0bf34bcacd2479764e29f04562bd07af0bd054a4b3b8d309898dc0775450005c9d077fd4cebb3d1831c9a09d3f093579e32d54f WHIRLPOOL 4cc1ea76c18255f15fd03943a92a29e2496b1d1a77b9dd105442f9c6f4c285f621dbbaa051f120c50679f9d8b03ffe49aa94b96cbdf8df84509fd6754e3f9690
diff --git a/dev-lang/go/go-1.5.ebuild b/dev-lang/go/go-1.5.ebuild
new file mode 100644 (file)
index 0000000..691efef
--- /dev/null
@@ -0,0 +1,208 @@
+# Copyright 1999-2015 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Id$
+
+EAPI=5
+
+export CBUILD=${CBUILD:-${CHOST}}
+export CTARGET=${CTARGET:-${CHOST}}
+
+inherit eutils toolchain-funcs
+
+if [[ ${PV} = 9999 ]]; then
+       EGIT_REPO_URI="git://github.com/golang/go.git"
+       inherit git-r3
+else
+       SRC_URI="https://storage.googleapis.com/golang/go${PV}.src.tar.gz"
+       # go-bootstrap-1.4 only supports go on amd64, arm and x86 architectures.
+       # Allowing other bootstrap options would enable arm64 and ppc64 builds.
+       KEYWORDS="-* ~amd64 ~arm ~x86 ~amd64-fbsd ~x86-fbsd ~x64-macos ~x86-macos"
+fi
+
+DESCRIPTION="A concurrent garbage collected and typesafe programming language"
+HOMEPAGE="http://www.golang.org"
+
+LICENSE="BSD"
+SLOT="0/${PV}"
+IUSE=""
+
+DEPEND=">=dev-lang/go-bootstrap-1.4.1"
+RDEPEND=""
+
+# These test data objects have writable/executable stacks.
+QA_EXECSTACK="usr/lib/go/src/debug/elf/testdata/*.obj"
+
+# The tools in /usr/lib/go should not cause the multilib-strict check to fail.
+QA_MULTILIB_PATHS="usr/lib/go/pkg/tool/.*/.*"
+
+# The go language uses *.a files which are _NOT_ libraries and should not be
+# stripped. The test data objects should also be left alone and unstripped.
+STRIP_MASK="/usr/lib/go/pkg/*.a
+       /usr/lib/go/src/debug/elf/testdata/*
+       /usr/lib/go/src/debug/dwarf/testdata/*
+       /usr/lib/go/src/runtime/race/*.syso"
+
+if [[ ${PV} != 9999 ]]; then
+       S="${WORKDIR}"/go
+fi
+
+go_arch()
+{
+       # By chance most portage arch names match Go
+       local portage_arch=$(tc-arch $@)
+       case "${portage_arch}" in
+               x86)    echo 386;;
+               *)              echo "${portage_arch}";;
+       esac
+}
+
+go_arm()
+{
+       case "${1:-${CHOST}}" in
+               armv5)  echo 5;;
+               armv6)  echo 6;;
+               armv7)  echo 7;;
+               *)
+                       die "unknown GOARM for ${1:-${CHOST}}"
+                       ;;
+       esac
+}
+
+go_os()
+{
+       case "${1:-${CHOST}}" in
+               *-linux*)       echo linux;;
+               *-darwin*)      echo darwin;;
+               *-freebsd*)     echo freebsd;;
+               *-netbsd*)      echo netbsd;;
+               *-openbsd*)     echo openbsd;;
+               *-solaris*)     echo solaris;;
+               *-cygwin*|*-interix*|*-winnt*)
+                       echo windows
+                       ;;
+               *)
+                       die "unknown GOOS for ${1:-${CHOST}}"
+                       ;;
+       esac
+}
+
+go_tuple()
+{
+       echo "$(go_os $@)_$(go_arch $@)"
+}
+
+go_cross_compile()
+{
+       [[ $(go_tuple ${CBUILD}) != $(go_tuple) ]]
+}
+
+pkg_pretend()
+{
+       # make.bash does not understand cross-compiling a cross-compiler
+       if [[ $(go_tuple) != $(go_tuple ${CTARGET}) ]]; then
+               die "CHOST CTARGET pair unsupported: CHOST=${CHOST} CTARGET=${CTARGET}"
+       fi
+}
+
+src_prepare()
+{
+       if [[ ${PV} != 9999 ]]; then
+               sed -i -e 's/"-Werror",//g' src/cmd/dist/build.go ||
+                       die 'sed failed'
+       fi
+       epatch_user
+}
+
+src_compile()
+{
+       export GOROOT_BOOTSTRAP="${EPREFIX}"/usr/lib/go1.4
+       export GOROOT_FINAL="${EPREFIX}"/usr/lib/go
+       export GOROOT="$(pwd)"
+       export GOBIN="${GOROOT}/bin"
+
+       # Go's build script does not use BUILD/HOST/TARGET consistently. :(
+       export GOHOSTARCH=$(go_arch ${CBUILD})
+       export GOHOSTOS=$(go_os ${CBUILD})
+       export CC=$(tc-getBUILD_CC)
+
+       export GOARCH=$(go_arch)
+       export GOOS=$(go_os)
+       export CC_FOR_TARGET=$(tc-getCC)
+       export CXX_FOR_TARGET=$(tc-getCXX)
+       if [[ ${ARCH} == arm ]]; then
+               export GOARM=$(go_arm)
+       fi
+
+       cd src
+       ./make.bash || die "build failed"
+}
+
+src_test()
+{
+       go_cross_compile && return 0
+
+       cd src
+       PATH="${GOBIN}:${PATH}" \
+               ./run.bash -no-rebuild || die "tests failed"
+}
+
+src_install()
+{
+       local bin_path="${GOBIN}"
+       if go_cross_compile; then
+               bin_path="${GOBIN}/$(go_tuple)"
+       fi
+       dobin "${bin_path}"/*
+       dodoc AUTHORS CONTRIBUTORS PATENTS README.md
+
+       dodir /usr/lib/go /usr/lib/go/pkg /usr/lib/go/pkg/tool
+       insinto /usr/lib/go
+
+       # There is a known issue which requires the source tree to be installed [1].
+       # Once this is fixed, we can consider using the doc use flag to control
+       # installing the doc and src directories.
+       # [1] https://golang.org/issue/2775
+       doins -r doc lib src
+
+       # Selectively install pkg directory to exclude the bootstrap build
+       insinto /usr/lib/go/pkg
+       doins -r pkg/include "pkg/$(go_tuple)"
+       insinto /usr/lib/go/pkg/tool
+       doins -r "pkg/tool/$(go_tuple)"
+       fperms -R +x /usr/lib/go/pkg/tool
+}
+
+pkg_preinst()
+{
+       has_version '<dev-lang/go-1.4' &&
+               export had_support_files=true ||
+               export had_support_files=false
+}
+
+pkg_postinst()
+{
+       # If the go tool sees a package file timestamped older than a dependancy it
+       # will rebuild that file.  So, in order to stop go from rebuilding lots of
+       # packages for every build we need to fix the timestamps.  The compiler and
+       # linker are also checked - so we need to fix them too.
+       ebegin "fixing timestamps to avoid unnecessary rebuilds"
+       tref="usr/lib/go/pkg/*/runtime.a"
+       find "${EROOT}"usr/lib/go -type f \
+               -exec touch -r "${EROOT}"${tref} {} \;
+       eend $?
+
+       if [[ ${PV} != 9999 && -n ${REPLACING_VERSIONS} &&
+               ${REPLACING_VERSIONS} != ${PV} ]]; then
+               elog "Release notes are located at http://golang.org/doc/go${PV}"
+       fi
+
+       if $had_support_files; then
+               ewarn
+               ewarn "All editor support, IDE support, shell completion"
+               ewarn "support, etc has been removed from the go package"
+               ewarn "upstream."
+               ewarn "For more information on which support is available, see"
+               ewarn "the following URL:"
+               ewarn "https://github.com/golang/go/wiki/IDEsAndTextEditorPlugins"
+       fi
+}