Merge pull request #3808 from fjl/build-go-1.7
build: require Go >= 1.7
This commit is contained in:
		
						commit
						1c1dc0e0fc
					
				| @ -3,14 +3,6 @@ go_import_path: github.com/ethereum/go-ethereum | |||||||
| sudo: false | sudo: false | ||||||
| matrix: | matrix: | ||||||
|   include: |   include: | ||||||
|     - os: linux |  | ||||||
|       dist: trusty |  | ||||||
|       go: 1.5.4 |  | ||||||
|       env: |  | ||||||
|         - GO15VENDOREXPERIMENT=1 |  | ||||||
|     - os: linux |  | ||||||
|       dist: trusty |  | ||||||
|       go: 1.6.2 |  | ||||||
|     - os: linux |     - os: linux | ||||||
|       dist: trusty |       dist: trusty | ||||||
|       go: 1.7.5 |       go: 1.7.5 | ||||||
|  | |||||||
| @ -16,7 +16,7 @@ For prerequisites and detailed build instructions please read the | |||||||
| [Installation Instructions](https://github.com/ethereum/go-ethereum/wiki/Building-Ethereum) | [Installation Instructions](https://github.com/ethereum/go-ethereum/wiki/Building-Ethereum) | ||||||
| on the wiki. | on the wiki. | ||||||
| 
 | 
 | ||||||
| Building geth requires both a Go and a C compiler. | Building geth requires both a Go (version 1.7 or later) and a C compiler. | ||||||
| You can install them using your favourite package manager. | You can install them using your favourite package manager. | ||||||
| Once the dependencies are installed, run | Once the dependencies are installed, run | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										22
									
								
								build/ci.go
									
									
									
									
									
								
							
							
						
						
									
										22
									
								
								build/ci.go
									
									
									
									
									
								
							| @ -162,9 +162,9 @@ func doInstall(cmdline []string) { | |||||||
| 
 | 
 | ||||||
| 	// Check Go version. People regularly open issues about compilation
 | 	// Check Go version. People regularly open issues about compilation
 | ||||||
| 	// failure with outdated Go. This should save them the trouble.
 | 	// failure with outdated Go. This should save them the trouble.
 | ||||||
| 	if runtime.Version() < "go1.4" && !strings.HasPrefix(runtime.Version(), "devel") { | 	if runtime.Version() < "go1.7" && !strings.HasPrefix(runtime.Version(), "devel") { | ||||||
| 		log.Println("You have Go version", runtime.Version()) | 		log.Println("You have Go version", runtime.Version()) | ||||||
| 		log.Println("go-ethereum requires at least Go version 1.4 and cannot") | 		log.Println("go-ethereum requires at least Go version 1.7 and cannot") | ||||||
| 		log.Println("be compiled with an earlier version. Please upgrade your Go installation.") | 		log.Println("be compiled with an earlier version. Please upgrade your Go installation.") | ||||||
| 		os.Exit(1) | 		os.Exit(1) | ||||||
| 	} | 	} | ||||||
| @ -215,20 +215,9 @@ func doInstall(cmdline []string) { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func buildFlags(env build.Environment) (flags []string) { | func buildFlags(env build.Environment) (flags []string) { | ||||||
| 	if os.Getenv("GO_OPENCL") != "" { |  | ||||||
| 		flags = append(flags, "-tags", "opencl") |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	// Since Go 1.5, the separator char for link time assignments
 |  | ||||||
| 	// is '=' and using ' ' prints a warning. However, Go < 1.5 does
 |  | ||||||
| 	// not support using '='.
 |  | ||||||
| 	sep := " " |  | ||||||
| 	if runtime.Version() > "go1.5" || strings.Contains(runtime.Version(), "devel") { |  | ||||||
| 		sep = "=" |  | ||||||
| 	} |  | ||||||
| 	// Set gitCommit constant via link-time assignment.
 | 	// Set gitCommit constant via link-time assignment.
 | ||||||
| 	if env.Commit != "" { | 	if env.Commit != "" { | ||||||
| 		flags = append(flags, "-ldflags", "-X main.gitCommit"+sep+env.Commit) | 		flags = append(flags, "-ldflags", "-X main.gitCommit="+env.Commit) | ||||||
| 	} | 	} | ||||||
| 	return flags | 	return flags | ||||||
| } | } | ||||||
| @ -249,10 +238,7 @@ func goToolArch(arch string, subcmd string, args ...string) *exec.Cmd { | |||||||
| 			cmd.Args = append(cmd.Args, []string{"-ldflags", "-extldflags -Wl,--allow-multiple-definition"}...) | 			cmd.Args = append(cmd.Args, []string{"-ldflags", "-extldflags -Wl,--allow-multiple-definition"}...) | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	cmd.Env = []string{ | 	cmd.Env = []string{"GOPATH=" + build.GOPATH()} | ||||||
| 		"GO15VENDOREXPERIMENT=1", |  | ||||||
| 		"GOPATH=" + build.GOPATH(), |  | ||||||
| 	} |  | ||||||
| 	if arch == "" || arch == runtime.GOARCH { | 	if arch == "" || arch == runtime.GOARCH { | ||||||
| 		cmd.Env = append(cmd.Env, "GOBIN="+GOBIN) | 		cmd.Env = append(cmd.Env, "GOBIN="+GOBIN) | ||||||
| 	} else { | 	} else { | ||||||
|  | |||||||
| @ -20,8 +20,7 @@ fi | |||||||
| 
 | 
 | ||||||
| # Set up the environment to use the workspace. | # Set up the environment to use the workspace. | ||||||
| GOPATH="$workspace" | GOPATH="$workspace" | ||||||
| GO15VENDOREXPERIMENT=1 | export GOPATH | ||||||
| export GOPATH GO15VENDOREXPERIMENT |  | ||||||
| 
 | 
 | ||||||
| # Run the command inside the workspace. | # Run the command inside the workspace. | ||||||
| cd "$ethdir/go-ethereum" | cd "$ethdir/go-ethereum" | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user