Commit 64e29f94 authored by Brad Fitzpatrick's avatar Brad Fitzpatrick

internal/goversion: add new package, move Go 1.x constant there out of go/build

Found by Josh, who says in the bug that it shrinks cmd/compile by 1.6 MB (6.5%).

Fixes #31563

Change-Id: I35127af539630e628a0a4f2273af519093536c38
Reviewed-on: https://go-review.googlesource.com/c/go/+/172997Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
Reviewed-by: default avatarJosh Bleecher Snyder <josharian@gmail.com>
parent 97252f62
// Copyright 2019 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package gc
import (
"internal/testenv"
"os/exec"
"strings"
"testing"
)
func TestDeps(t *testing.T) {
testenv.MustHaveGoBuild(t)
out, err := exec.Command("go", "list", "-f", "{{.Deps}}", "cmd/compile/internal/gc").Output()
if err != nil {
t.Fatal(err)
}
for _, dep := range strings.Fields(strings.Trim(string(out), "[]")) {
switch dep {
case "go/build", "go/token":
t.Errorf("undesired dependency on %q", dep)
}
}
}
...@@ -19,7 +19,7 @@ import ( ...@@ -19,7 +19,7 @@ import (
"cmd/internal/sys" "cmd/internal/sys"
"flag" "flag"
"fmt" "fmt"
"go/build" "internal/goversion"
"io" "io"
"io/ioutil" "io/ioutil"
"log" "log"
...@@ -1426,8 +1426,7 @@ var flag_lang string ...@@ -1426,8 +1426,7 @@ var flag_lang string
// currentLang returns the current language version. // currentLang returns the current language version.
func currentLang() string { func currentLang() string {
tags := build.Default.ReleaseTags return fmt.Sprintf("go1.%d", goversion.Version)
return tags[len(tags)-1]
} }
// goVersionRE is a regular expression that matches the valid // goVersionRE is a regular expression that matches the valid
......
...@@ -89,6 +89,7 @@ var bootstrapDirs = []string{ ...@@ -89,6 +89,7 @@ var bootstrapDirs = []string{
"debug/elf", "debug/elf",
"debug/macho", "debug/macho",
"debug/pe", "debug/pe",
"internal/goversion",
"internal/xcoff", "internal/xcoff",
"math/big", "math/big",
"math/bits", "math/bits",
......
...@@ -13,6 +13,7 @@ import ( ...@@ -13,6 +13,7 @@ import (
"go/parser" "go/parser"
"go/token" "go/token"
"internal/goroot" "internal/goroot"
"internal/goversion"
"io" "io"
"io/ioutil" "io/ioutil"
"log" "log"
...@@ -292,15 +293,14 @@ func defaultContext() Context { ...@@ -292,15 +293,14 @@ func defaultContext() Context {
c.GOPATH = envOr("GOPATH", defaultGOPATH()) c.GOPATH = envOr("GOPATH", defaultGOPATH())
c.Compiler = runtime.Compiler c.Compiler = runtime.Compiler
// Each major Go release in the Go 1.x series should add a tag here. // Each major Go release in the Go 1.x series adds a new
// Old tags should not be removed. That is, the go1.x tag is present // "go1.x" release tag. That is, the go1.x tag is present in
// in all releases >= Go 1.x. Code that requires Go 1.x or later should // all releases >= Go 1.x. Code that requires Go 1.x or later
// say "+build go1.x", and code that should only be built before Go 1.x // should say "+build go1.x", and code that should only be
// (perhaps it is the stub to use in that case) should say "+build !go1.x". // built before Go 1.x (perhaps it is the stub to use in that
// NOTE: If you add to this list, also update the doc comment in doc.go. // case) should say "+build !go1.x".
// NOTE: The last element in ReleaseTags should be the current release. // The last element in ReleaseTags is the current release.
const version = 13 // go1.13 for i := 1; i <= goversion.Version; i++ {
for i := 1; i <= version; i++ {
c.ReleaseTags = append(c.ReleaseTags, "go1."+strconv.Itoa(i)) c.ReleaseTags = append(c.ReleaseTags, "go1."+strconv.Itoa(i))
} }
......
...@@ -268,7 +268,7 @@ var pkgDeps = map[string][]string{ ...@@ -268,7 +268,7 @@ var pkgDeps = map[string][]string{
"encoding/pem": {"L4"}, "encoding/pem": {"L4"},
"encoding/xml": {"L4", "encoding"}, "encoding/xml": {"L4", "encoding"},
"flag": {"L4", "OS"}, "flag": {"L4", "OS"},
"go/build": {"L4", "OS", "GOPARSER", "internal/goroot"}, "go/build": {"L4", "OS", "GOPARSER", "internal/goroot", "internal/goversion"},
"html": {"L4"}, "html": {"L4"},
"image/draw": {"L4", "image/internal/imageutil"}, "image/draw": {"L4", "image/internal/imageutil"},
"image/gif": {"L4", "compress/lzw", "image/color/palette", "image/draw"}, "image/gif": {"L4", "compress/lzw", "image/color/palette", "image/draw"},
......
// Copyright 2019 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package goversion
// Version is the current Go 1.x version. During development cycles on
// the master branch it changes to be the version of the next Go 1.x
// release.
//
// When incrementing this, also add to the list at src/go/build/doc.go
// (search for "onward").
const Version = 13
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment