All,

here are more non-api-breaking updates to golang-vcs.eclass:

1. The GOPATH environment variable is now passed directly to the
commands that need it.
2. The correct directory of source files is copied to the correct
location under ${S}.

I'll post this as a patch since the eclass is in the tree.

Thanks,

William

Index: golang-vcs.eclass
===================================================================
RCS file: /var/cvsroot/gentoo-x86/eclass/golang-vcs.eclass,v
retrieving revision 1.2
diff -u -B -r1.2 golang-vcs.eclass
--- golang-vcs.eclass	18 Jun 2015 15:19:04 -0000	1.2
+++ golang-vcs.eclass	22 Jun 2015 22:12:37 -0000
@@ -50,7 +50,7 @@
 #
 # Example:
 # @CODE
-# EGO_PN="github.com/user/repository/package"
+# EGO_PN="github.com/user/repository/..."
 # EGO_SRC="github.com/user/repository"
 # @CODE
 
@@ -79,7 +79,7 @@
 # @FUNCTION: _golang-vcs_env_setup
 # @INTERNAL
 # @DESCRIPTION:
-# Create EGO_STORE_DIR if necessary and set GOPATH.
+# Create EGO_STORE_DIR if necessary.
 _golang-vcs_env_setup() {
 	debug-print-function ${FUNCNAME} "$@"
 
@@ -96,7 +96,6 @@
 	fi
 
 	addwrite "${EGO_STORE_DIR}"
-	export GOPATH="${EGO_STORE_DIR}"
 
 	[[ -n ${EVCS_UMASK} ]] && eumask_pop
 	mkdir -p "${WORKDIR}/${P}/src" ||
@@ -118,32 +117,26 @@
 	[[ -z ${EGO_PN} ]] &&
 		die "${ECLASS}: EGO_PN is not set"
 
-	if [[ -n ${EVCS_OFFLINE} ]]; then
-		export GOPATH="${WORKDIR}/${P}:${GOPATH}"
-		return 0
-	fi
-
-	[[ -n ${EVCS_UMASK} ]] && eumask_push ${EVCS_UMASK}
+	if [[ -z ${EVCS_OFFLINE} ]]; then
+		[[ -n ${EVCS_UMASK} ]] && eumask_push ${EVCS_UMASK}
 
-	set -- go get -d -t -u -v -x "${EGO_PN}"
-	echo "$@"
-	"$@" || die
-	# The above dies if you pass repositories in EGO_PN instead of
-	# packages, e.g. golang.org/x/tools instead of golang.org/x/tools/cmd/vet.
-	# This is being discussed in the following upstream issue:
-	# https://github.com/golang/go/issues/11090
-	# I am hoping this will be fixed so "go get -d" is successful if
-	# downloading the top level repository is successful.
+		set -- env GOPATH="${EGO_STORE_DIR}" go get -d -t -u -v -x "${EGO_PN}"
+		echo "$@"
+		"$@" || die
+		# The above dies if you pass repositories in EGO_PN instead of
+		# packages, e.g. golang.org/x/tools instead of golang.org/x/tools/cmd/vet.
+		# This is being discussed in the following upstream issue:
+		# https://github.com/golang/go/issues/11090
 
-	[[ -n ${EVCS_UMASK} ]] && eumask_pop
-	export GOPATH="${WORKDIR}/${P}:${EGO_STORE_DIR}"
-	set -- mkdir -p "${WORKDIR}/${P}/src/${EGO_SRC}"
+		[[ -n ${EVCS_UMASK} ]] && eumask_pop
+	fi
+	set -- mkdir -p "${WORKDIR}/${P}/src/${EGO_SRC%/*}"
 	echo "$@"
-	"$@" || die "Unable to create ${WORKDIR}/${P}/src/${EGO_SRC}"
-	set -- cp -r "${EGO_STORE_DIR}/src/${EGO_SRC}/*" \
-		"${WORKDIR}/${P}/src/${EGO_SRC}"
+	"$@" || die "Unable to create ${WORKDIR}/${P}/src"
+	set -- cp -r	"${EGO_STORE_DIR}/src/${EGO_SRC}" \
+		"${WORKDIR}/${P}/src/${EGO_SRC%/*}"
 	echo "$@"
-	$@ || die "Unable to copy sources to ${WORKDIR}/${P}"
+	"$@" || die "Unable to copy sources to ${WORKDIR}/${P}"
 	return 0
 }
 

Attachment: signature.asc
Description: Digital signature

Reply via email to