mirror of
https://github.com/LCTT/TranslateProject.git
synced 2024-12-26 21:30:55 +08:00
eda6cdd3df
This reverts commit 8ed24fe795
.
112 lines
4.0 KiB
Markdown
112 lines
4.0 KiB
Markdown
Trying Other Go Versions
|
||
============================================================
|
||
|
||
While I generally use the current release of Go, sometimes I need to try a different version. For example, I need to check that all the examples in my [Guide to JSON][2] work with [both the supported releases of Go][3](1.8.6 and 1.9.3 at time of writing) along with go1.10rc1.
|
||
|
||
I primarily use the current version of Go, updating it when new versions are released. I try out other versions as needed following the methods described in this article.
|
||
|
||
### Trying Betas and Release Candidates[¶][4]
|
||
|
||
When [go1.8beta2 was released][5], a new tool for trying the beta and release candidates was also released that allowed you to `go get` the beta. It allowed you to easily run the beta alongside your Go installation by getting the beta with:
|
||
|
||
```
|
||
go get golang.org/x/build/version/go1.8beta2
|
||
```
|
||
|
||
This downloads and builds a small program that will act like the `go` tool for that specific version. The full release can then be downloaded and installed with:
|
||
|
||
```
|
||
go1.8beta2 download
|
||
```
|
||
|
||
This downloads the release from [https://golang.org/dl][6] and installs it into `$HOME/sdk` or `%USERPROFILE%\sdk`.
|
||
|
||
Now you can use `go1.8beta2` as if it were the normal Go command.
|
||
|
||
This method works for [all the beta and release candidates][7] released after go1.8beta2.
|
||
|
||
### Trying a Specific Release[¶][8]
|
||
|
||
While only beta and release candidates are provided, they can easily be adapted to work with any released version. For example, to use go1.9.2:
|
||
|
||
```
|
||
package main
|
||
|
||
import (
|
||
"golang.org/x/build/version"
|
||
)
|
||
|
||
func main() {
|
||
version.Run("go1.9.2")
|
||
}
|
||
```
|
||
|
||
Replace `go1.9.2` with the release you want to run and build/install as usual.
|
||
|
||
Since the program I use to build my [Guide to JSON][9] calls `go` itself (for each example), I build this as `go` and prepend the directory to my `PATH` so it will use this one instead of my normal version.
|
||
|
||
### Trying Any Release[¶][10]
|
||
|
||
This small program can be extended so you can specify the release to use instead of having to maintain binaries for each version.
|
||
|
||
```
|
||
package main
|
||
|
||
import (
|
||
"fmt"
|
||
"os"
|
||
|
||
"golang.org/x/build/version"
|
||
)
|
||
|
||
func main() {
|
||
if len(os.Args) < 2 {
|
||
fmt.Printf("USAGE: %v <version> [commands as normal]\n",
|
||
os.Args[0])
|
||
os.Exit(1)
|
||
}
|
||
|
||
v := os.Args[1]
|
||
os.Args = append(os.Args[0:1], os.Args[2:]...)
|
||
|
||
version.Run("go" + v)
|
||
}
|
||
```
|
||
|
||
I have this installed as `gov` and run it like `gov 1.8.6 version`, using the version I want to run.
|
||
|
||
### Trying a Source Build (e.g., tip)[¶][11]
|
||
|
||
I also use this same infrastructure to manage source builds of Go, such as tip. There’s just a little trick to it:
|
||
|
||
* use the directory `$HOME/sdk/go<version>` (e.g., `$HOME/sdk/gotip`)
|
||
|
||
* [build as normal][1]
|
||
|
||
* `touch $HOME/sdk/go<version>/.unpacked-success` This is an empty file used as a sentinel to indicate the download and unpacking was successful.
|
||
|
||
(On Windows, replace `$HOME/sdk` with `%USERPROFILE%\sdk`)
|
||
|
||
|
||
--------------------------------------------------------------------------------
|
||
|
||
via: https://pocketgophers.com/trying-other-versions/
|
||
|
||
作者:[Nathan Kerr ][a]
|
||
译者:[译者ID](https://github.com/译者ID)
|
||
校对:[校对者ID](https://github.com/校对者ID)
|
||
|
||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
|
||
|
||
[a]:nathan@pocketgophers.com
|
||
[1]:https://golang.org/doc/install/source
|
||
[2]:https://pocketgophers.com/guide-to-json/
|
||
[3]:https://pocketgophers.com/when-should-you-upgrade-go/
|
||
[4]:https://pocketgophers.com/trying-other-versions/#trying-betas-and-release-candidates
|
||
[5]:https://groups.google.com/forum/#!topic/golang-announce/LvfYP-Wk1s0
|
||
[6]:https://golang.org/dl
|
||
[7]:https://godoc.org/golang.org/x/build/version#pkg-subdirectories
|
||
[8]:https://pocketgophers.com/trying-other-versions/#trying-a-specific-release
|
||
[9]:https://pocketgophers.com/guide-to-json/
|
||
[10]:https://pocketgophers.com/trying-other-versions/#trying-any-release
|
||
[11]:https://pocketgophers.com/trying-other-versions/#trying-a-source-build-e-g-tip |