commit:     39c2cef80c2e3c2d6d12ac0c2488db21f01430a5
Author:     William Hubbs <williamh <AT> gentoo <DOT> org>
AuthorDate: Wed Jul 20 13:58:05 2016 +0000
Commit:     William Hubbs <williamh <AT> gentoo <DOT> org>
CommitDate: Wed Jul 20 13:58:39 2016 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=39c2cef8

dev-lang/go: 1.6.3 version bump for #589230

Package-Manager: portage-2.2.28

 dev-lang/go/Manifest                          |   1 +
 dev-lang/go/files/go-1.6.3-gdb-no-shell.patch |  12 ++
 dev-lang/go/go-1.6.3.ebuild                   | 260 ++++++++++++++++++++++++++
 3 files changed, 273 insertions(+)

diff --git a/dev-lang/go/Manifest b/dev-lang/go/Manifest
index 426210b..a1e0299 100644
--- a/dev-lang/go/Manifest
+++ b/dev-lang/go/Manifest
@@ -10,4 +10,5 @@ DIST go-linux-ppc64le-bootstrap.tbz 50134685 SHA256 
ca816a3e3cbd7721200522fa3984
 DIST go-solaris-amd64-bootstrap.tbz 48367195 SHA256 
92ebdbf001f243a78a6c2d8ee30e929ba2cecbedf8e0fc07e129b04b107453ad SHA512 
cf8725db0d001d61badee71624799a3c9e75f61f77ab090c1f6c490d694c4be367019b28d88306045d877ab5a324a1f9b0674293caf3acb19c193fc3746a48f2
 WHIRLPOOL 
672c6642e340b6d4f38b633f67fdc3202e3725022a8a61e2129276fccd6c42ddc24ed06c1d57eb31a25ea8056b79686619cbb36431b9c23b6d4be5bcb715bd89
 DIST go1.6.1.src.tar.gz 12615799 SHA256 
1d4b53cdee51b2298afcf50926a7fa44b286f0bf24ff8323ce690a66daa7193f SHA512 
31ea2504f8ab0fd709005275d0c2129b6cdb4e5d34d6e2b435b23480674b135d1bff8de863b1e01201e757523f4dc28b6ebefeb87d7e855f2509a6837e436fab
 WHIRLPOOL 
6589f311fc3893775352a3c5d6409933397215389f2b25d3b61370acde35ead374403dfdd1dd58962b5066acd61c4acd85cf9c556d05b099e7fec6d23d6daca0
 DIST go1.6.2.src.tar.gz 12617724 SHA256 
787b0b750d037016a30c6ed05a8a70a91b2e9db4bd9b1a2453aa502a63f1bccc SHA512 
e148022f9e18b5d5b05744f1aa9fa3ef82e255752179545711ade077e271216aa5b450859a764fdfb028ae4faa26adad8d0a0a5268b31396ab9d14de3cb2f20a
 WHIRLPOOL 
bbd04cc0b18768b9dcf3b1d3614d2a263d2314ca811e03b390bafeafc7ea4d2aa650a34901da75e55ca58bf9c00601d9924152228ed0d57bbc4b5dbdc081e8a9
+DIST go1.6.3.src.tar.gz 12617426 SHA256 
6326aeed5f86cf18f16d6dc831405614f855e2d416a91fd3fdc334f772345b00 SHA512 
43e9b01220788112a185500bd53f091e7a0023a790092f428e2f40fc1a334dd148558b99d2a1c871b8cc79ad7d2d87a092b93eee7b5a27c2ee675c494de35306
 WHIRLPOOL 
0a22dc08b89ddfaccf1e871037e7ad6cdbf36f914de527011813d57a2d857478278202314b185e26aa905cb135d13cbea490d03337b42148c6fc2ef93a8cd9fe
 DIST go1.6.src.tar.gz 12613308 SHA256 
a96cce8ce43a9bf9b2a4c7d470bc7ee0cb00410da815980681c8353218dcf146 SHA512 
59e9d72a80558fd5e3f176e068897a45333b36e35f6c00393647941a70e741168e65941b6059397378020c3b78ec3471a48809682f7efd97cf33eec6325fc3e8
 WHIRLPOOL 
c6debe1a5039f0ca34c29b4a53f958503a724cae13715ea14f0237b5faacd26e09eb6405462e22abd6806540dd8fb9eb2fa08ff6e8676b0f6dffa267210f5eac

diff --git a/dev-lang/go/files/go-1.6.3-gdb-no-shell.patch 
b/dev-lang/go/files/go-1.6.3-gdb-no-shell.patch
new file mode 100644
index 0000000..ccce6f0
--- /dev/null
+++ b/dev-lang/go/files/go-1.6.3-gdb-no-shell.patch
@@ -0,0 +1,12 @@
+diff --git a/src/runtime/runtime-gdb_test.go b/src/runtime/runtime-gdb_test.go
+index 6ebc69a..648092a 100644
+--- a/src/runtime/runtime-gdb_test.go
++++ b/src/runtime/runtime-gdb_test.go
+@@ -87,6 +87,7 @@ func TestGdbPython(t *testing.T) {
+ 
+       args := []string{"-nx", "-q", "--batch", "-iex",
+               fmt.Sprintf("add-auto-load-safe-path %s/src/runtime", 
runtime.GOROOT()),
++              "-ex", "set startup-with-shell off",
+               "-ex", "info auto-load python-scripts",
+               "-ex", "br main.go:10",
+               "-ex", "run",

diff --git a/dev-lang/go/go-1.6.3.ebuild b/dev-lang/go/go-1.6.3.ebuild
new file mode 100644
index 0000000..ddf85db
--- /dev/null
+++ b/dev-lang/go/go-1.6.3.ebuild
@@ -0,0 +1,260 @@
+# Copyright 1999-2016 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Id$
+
+EAPI=6
+
+export CBUILD=${CBUILD:-${CHOST}}
+export CTARGET=${CTARGET:-${CHOST}}
+
+MY_PV=${PV/_/}
+
+inherit toolchain-funcs
+
+BOOTSTRAP_DIST="https://dev.gentoo.org/~williamh/dist";
+SRC_URI="!gccgo? (
+kernel_Darwin? (
+       x64-macos? ( ${BOOTSTRAP_DIST}/go-darwin-amd64-bootstrap.tbz )
+)
+kernel_FreeBSD? (
+amd64-fbsd? ( ${BOOTSTRAP_DIST}/go-freebsd-amd64-bootstrap.tbz )
+x86-fbsd? ( ${BOOTSTRAP_DIST}/go-freebsd-386-bootstrap-1.tbz )
+)
+kernel_linux? (
+       amd64? ( ${BOOTSTRAP_DIST}/go-linux-amd64-bootstrap.tbz )
+       arm? ( ${BOOTSTRAP_DIST}/go-linux-arm-bootstrap.tbz )
+       arm64? ( ${BOOTSTRAP_DIST}/go-linux-arm64-bootstrap.tbz )
+       ppc64? (
+               ${BOOTSTRAP_DIST}/go-linux-ppc64-bootstrap.tbz
+               ${BOOTSTRAP_DIST}/go-linux-ppc64le-bootstrap.tbz
+       )
+       x86? ( ${BOOTSTRAP_DIST}/go-linux-386-bootstrap-1.tbz )
+)
+kernel_SunOS? (
+       x64-solaris? ( ${BOOTSTRAP_DIST}/go-solaris-amd64-bootstrap.tbz )
+)
+)
+"
+
+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${MY_PV}.src.tar.gz";
+       case ${PV} in
+               *9999*|*_rc*) ;;
+               *)
+                       KEYWORDS="-* ~amd64 ~arm ~arm64 ~ppc64 ~x86 ~amd64-fbsd 
~x86-fbsd ~x64-macos ~x64-solaris"
+                       ;;
+       esac
+fi
+
+DESCRIPTION="A concurrent garbage collected and typesafe programming language"
+HOMEPAGE="http://www.golang.org";
+
+LICENSE="BSD"
+SLOT="0/${PV}"
+IUSE="gccgo"
+
+DEPEND="gccgo? ( >=sys-devel/gcc-5[go] )"
+RDEPEND="!<dev-go/go-tools-0_pre20150902"
+
+# These test data objects have writable/executable stacks.
+QA_EXECSTACK="usr/lib/go/src/debug/elf/testdata/*.obj"
+
+# Do not complain about CFLAGS, etc, since Go doesn't use them.
+QA_FLAGS_IGNORED='.*'
+
+REQUIRES_EXCLUDE="/usr/lib/go/src/debug/elf/testdata/*"
+
+# 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
+
+PATCHES=(
+# patch for #581072
+       "${FILESDIR}"/${P}-gdb-no-shell.patch
+)
+
+go_arch()
+{
+       # By chance most portage arch names match Go
+       local portage_arch=$(tc-arch $@)
+       case "${portage_arch}" in
+               x86)    echo 386;;
+               x64-*)  echo amd64;;
+               ppc64) [[ $(tc-endian $@) = big ]] && echo ppc64 || echo 
ppc64le ;;
+               *)              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_unpack()
+{
+       if [[ ${PV} = 9999 ]]; then
+               git-r3_src_unpack
+       fi
+       default
+}
+
+src_compile()
+{
+       export GOROOT_BOOTSTRAP="${WORKDIR}"/go-$(go_os)-$(go_arch)-bootstrap
+       if use gccgo; then
+               mkdir -p "${GOROOT_BOOTSTRAP}/bin" || die
+               local go_binary=$(gcc-config --get-bin-path)/go-5
+               [[ -x ${go_binary} ]] || go_binary=$(
+                       find "${EPREFIX}"/usr/${CHOST}/gcc-bin/*/go-5 | sort -V 
| tail -n1)
+               [[ -x ${go_binary} ]] || die "go-5: command not found"
+               ln -s "${go_binary}" "${GOROOT_BOOTSTRAP}/bin/go" || die
+       fi
+       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
+       elog "GOROOT_BOOTSTRAP is ${GOROOT_BOOTSTRAP}"
+
+       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 f x
+
+       dodir /usr/lib/go
+       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 bin doc lib pkg src
+       fperms -R +x /usr/lib/go/bin /usr/lib/go/pkg/tool
+
+       cp -a misc "${D}"/usr/lib/go/misc
+
+       if go_cross_compile; then
+               bin_path="bin/$(go_tuple)"
+       else
+               bin_path=bin
+       fi
+       for x in ${bin_path}/*; do
+               f=${x##*/}
+               dosym ../lib/go/${bin_path}/${f} /usr/bin/${f}
+       done
+       dodoc AUTHORS CONTRIBUTORS PATENTS README.md
+}
+
+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
+}

Reply via email to