From 584a3f5bf2671886bd3f7dc2b252762b5aa2a087 Mon Sep 17 00:00:00 2001 From: Edward Muller Date: Thu, 7 Apr 2016 14:27:32 -0700 Subject: [PATCH] Note new go1.6+ behavior of not checking out master This is very annoying, but I guess I had my time to complain and didn't. --- Changelog.md | 4 ++++ Readme.md | 17 ++++++++++------- restore.go | 4 ++++ version.go | 2 +- 4 files changed, 19 insertions(+), 8 deletions(-) diff --git a/Changelog.md b/Changelog.md index c2155d8..4726595 100644 --- a/Changelog.md +++ b/Changelog.md @@ -1,3 +1,7 @@ +#v62 (2016/04/07) + +* Note new go1.6+ behavior of not checking out master in README / restore help text. + #v61 (2016/04/06) * Obey go version build tags based on recorded major go version. Fixes #448. diff --git a/Readme.md b/Readme.md index 732ea46..d5e9965 100644 --- a/Readme.md +++ b/Readme.md @@ -68,7 +68,10 @@ time** you run a Go-related command, you wrap it in one of these two ways: ### Restore The `godep restore` command is the opposite of `godep save`. It will install the -package versions specified in `Godeps/Godeps.json` to your `$GOPATH`. This modifies the state of packages in your `$GOPATH`. +package versions specified in `Godeps/Godeps.json` to your `$GOPATH`. This +modifies the state of packages in your `$GOPATH`. NOTE: `godep restore` leaves +git repositories in a detached state. `go1.6`+ no longer checks out the master +branch when doing a `go get`, see [here](https://github.com/golang/go/commit/42206598671a44111c8f726ad33dc7b265bdf669). ### Edit-test Cycle @@ -144,16 +147,16 @@ Example Godeps: Godep supports the Go 1.5+ vendor/ [experiment](https://github.com/golang/go/commit/183cc0cd41f06f83cb7a2490a499e3f9101befff) -utilizing the same environment variable that the go tooling itself supports +utilizing the same environment variable that the go tooling itself supports (`GO15VENDOREXPERIMENT`). -godep mostly works the same way as the `go` command line tool. If you have go -1.5.X and set `GO15VENDOREXPERIMENT=1` or have go1.6.X (or devel) `vendor/` +godep mostly works the same way as the `go` command line tool. If you have go +1.5.X and set `GO15VENDOREXPERIMENT=1` or have go1.6.X (or devel) `vendor/` is enabled. **Unless** you already have a `Godeps/_workspace`. This is a safety -feature and godep warns you about this. +feature and godep warns you about this. When `vendor/` is enabled godep will write the vendored code into the top level -`./vendor/` directory. A `./Godeps/Godeps.json` file is created to track +`./vendor/` directory. A `./Godeps/Godeps.json` file is created to track the dependencies and revisions. `vendor/` is not compatible with rewrites. There is currently no automated migration between the old Godeps workspace and @@ -176,7 +179,7 @@ $ rm -rf Godeps # If on go1.5.X to enable `vendor/` $ export GO15VENDOREXPERIMENT=1 -# re-analyze deps and save to `vendor/`. +# re-analyze deps and save to `vendor/`. $ godep save # Add the changes to your VCS diff --git a/restore.go b/restore.go index 44091ed..eb18331 100644 --- a/restore.go +++ b/restore.go @@ -16,6 +16,10 @@ var cmdRestore = &Command{ Long: ` Restore checks out the Godeps-specified version of each package in GOPATH. +NOTE: restore leaves git repositories in a detached state. go1.6+ no longer +checks out the master branch when doing a "go get", see: +https://github.com/golang/go/commit/42206598671a44111c8f726ad33dc7b265bdf669. + `, Run: runRestore, OnlyInGOPATH: true, diff --git a/version.go b/version.go index 5d6d816..876087e 100644 --- a/version.go +++ b/version.go @@ -8,7 +8,7 @@ import ( "strings" ) -const version = 61 +const version = 62 var cmdVersion = &Command{ Name: "version",