mirror of
https://github.com/golang/go
synced 2024-10-01 01:08:33 -06:00
go/internal/gcimporter: remove support for Go versions < Go 1.10
- eliminated special case for isAlias predicate - appended code from bexport19_test.go to bexport_test.go No other changes. Change-Id: Icf10691510e51f4e618b2a48bc1a1215a98832b6 Reviewed-on: https://go-review.googlesource.com/c/142896 Reviewed-by: Alan Donovan <adonovan@google.com>
This commit is contained in:
parent
a019f6b7c5
commit
a53bc13a63
@ -209,7 +209,7 @@ func (p *exporter) obj(obj types.Object) {
|
|||||||
p.value(obj.Val())
|
p.value(obj.Val())
|
||||||
|
|
||||||
case *types.TypeName:
|
case *types.TypeName:
|
||||||
if isAlias(obj) {
|
if obj.IsAlias() {
|
||||||
p.tag(aliasTag)
|
p.tag(aliasTag)
|
||||||
p.pos(obj)
|
p.pos(obj)
|
||||||
p.qualifiedName(obj)
|
p.qualifiedName(obj)
|
||||||
|
@ -1,96 +0,0 @@
|
|||||||
// Copyright 2016 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.
|
|
||||||
|
|
||||||
// +build go1.9
|
|
||||||
|
|
||||||
package gcimporter_test
|
|
||||||
|
|
||||||
import (
|
|
||||||
"go/ast"
|
|
||||||
"go/parser"
|
|
||||||
"go/token"
|
|
||||||
"go/types"
|
|
||||||
"testing"
|
|
||||||
|
|
||||||
"golang.org/x/tools/go/internal/gcimporter"
|
|
||||||
)
|
|
||||||
|
|
||||||
const src = `
|
|
||||||
package p
|
|
||||||
|
|
||||||
type (
|
|
||||||
T0 = int32
|
|
||||||
T1 = struct{}
|
|
||||||
T2 = struct{ T1 }
|
|
||||||
Invalid = foo // foo is undeclared
|
|
||||||
)
|
|
||||||
`
|
|
||||||
|
|
||||||
func checkPkg(t *testing.T, pkg *types.Package, label string) {
|
|
||||||
T1 := types.NewStruct(nil, nil)
|
|
||||||
T2 := types.NewStruct([]*types.Var{types.NewField(0, pkg, "T1", T1, true)}, nil)
|
|
||||||
|
|
||||||
for _, test := range []struct {
|
|
||||||
name string
|
|
||||||
typ types.Type
|
|
||||||
}{
|
|
||||||
{"T0", types.Typ[types.Int32]},
|
|
||||||
{"T1", T1},
|
|
||||||
{"T2", T2},
|
|
||||||
{"Invalid", types.Typ[types.Invalid]},
|
|
||||||
} {
|
|
||||||
obj := pkg.Scope().Lookup(test.name)
|
|
||||||
if obj == nil {
|
|
||||||
t.Errorf("%s: %s not found", label, test.name)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
tname, _ := obj.(*types.TypeName)
|
|
||||||
if tname == nil {
|
|
||||||
t.Errorf("%s: %v not a type name", label, obj)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
if !tname.IsAlias() {
|
|
||||||
t.Errorf("%s: %v: not marked as alias", label, tname)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
if got := tname.Type(); !types.Identical(got, test.typ) {
|
|
||||||
t.Errorf("%s: %v: got %v; want %v", label, tname, got, test.typ)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestTypeAliases(t *testing.T) {
|
|
||||||
// parse and typecheck
|
|
||||||
fset1 := token.NewFileSet()
|
|
||||||
f, err := parser.ParseFile(fset1, "p.go", src, 0)
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal(err)
|
|
||||||
}
|
|
||||||
var conf types.Config
|
|
||||||
pkg1, err := conf.Check("p", fset1, []*ast.File{f}, nil)
|
|
||||||
if err == nil {
|
|
||||||
// foo in undeclared in src; we should see an error
|
|
||||||
t.Fatal("invalid source type-checked without error")
|
|
||||||
}
|
|
||||||
if pkg1 == nil {
|
|
||||||
// despite incorrect src we should see a (partially) type-checked package
|
|
||||||
t.Fatal("nil package returned")
|
|
||||||
}
|
|
||||||
checkPkg(t, pkg1, "export")
|
|
||||||
|
|
||||||
// export
|
|
||||||
exportdata, err := gcimporter.BExportData(fset1, pkg1)
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// import
|
|
||||||
imports := make(map[string]*types.Package)
|
|
||||||
fset2 := token.NewFileSet()
|
|
||||||
_, pkg2, err := gcimporter.BImportData(fset2, imports, exportdata, pkg1.Path())
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("BImportData(%s): %v", pkg1.Path(), err)
|
|
||||||
}
|
|
||||||
checkPkg(t, pkg2, "import")
|
|
||||||
}
|
|
@ -333,3 +333,82 @@ func TestVeryLongFile(t *testing.T) {
|
|||||||
posn2, want, posn1)
|
posn2, want, posn1)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const src = `
|
||||||
|
package p
|
||||||
|
|
||||||
|
type (
|
||||||
|
T0 = int32
|
||||||
|
T1 = struct{}
|
||||||
|
T2 = struct{ T1 }
|
||||||
|
Invalid = foo // foo is undeclared
|
||||||
|
)
|
||||||
|
`
|
||||||
|
|
||||||
|
func checkPkg(t *testing.T, pkg *types.Package, label string) {
|
||||||
|
T1 := types.NewStruct(nil, nil)
|
||||||
|
T2 := types.NewStruct([]*types.Var{types.NewField(0, pkg, "T1", T1, true)}, nil)
|
||||||
|
|
||||||
|
for _, test := range []struct {
|
||||||
|
name string
|
||||||
|
typ types.Type
|
||||||
|
}{
|
||||||
|
{"T0", types.Typ[types.Int32]},
|
||||||
|
{"T1", T1},
|
||||||
|
{"T2", T2},
|
||||||
|
{"Invalid", types.Typ[types.Invalid]},
|
||||||
|
} {
|
||||||
|
obj := pkg.Scope().Lookup(test.name)
|
||||||
|
if obj == nil {
|
||||||
|
t.Errorf("%s: %s not found", label, test.name)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
tname, _ := obj.(*types.TypeName)
|
||||||
|
if tname == nil {
|
||||||
|
t.Errorf("%s: %v not a type name", label, obj)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
if !tname.IsAlias() {
|
||||||
|
t.Errorf("%s: %v: not marked as alias", label, tname)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
if got := tname.Type(); !types.Identical(got, test.typ) {
|
||||||
|
t.Errorf("%s: %v: got %v; want %v", label, tname, got, test.typ)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestTypeAliases(t *testing.T) {
|
||||||
|
// parse and typecheck
|
||||||
|
fset1 := token.NewFileSet()
|
||||||
|
f, err := parser.ParseFile(fset1, "p.go", src, 0)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
var conf types.Config
|
||||||
|
pkg1, err := conf.Check("p", fset1, []*ast.File{f}, nil)
|
||||||
|
if err == nil {
|
||||||
|
// foo in undeclared in src; we should see an error
|
||||||
|
t.Fatal("invalid source type-checked without error")
|
||||||
|
}
|
||||||
|
if pkg1 == nil {
|
||||||
|
// despite incorrect src we should see a (partially) type-checked package
|
||||||
|
t.Fatal("nil package returned")
|
||||||
|
}
|
||||||
|
checkPkg(t, pkg1, "export")
|
||||||
|
|
||||||
|
// export
|
||||||
|
exportdata, err := gcimporter.BExportData(fset1, pkg1)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// import
|
||||||
|
imports := make(map[string]*types.Package)
|
||||||
|
fset2 := token.NewFileSet()
|
||||||
|
_, pkg2, err := gcimporter.BImportData(fset2, imports, exportdata, pkg1.Path())
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("BImportData(%s): %v", pkg1.Path(), err)
|
||||||
|
}
|
||||||
|
checkPkg(t, pkg2, "import")
|
||||||
|
}
|
||||||
|
@ -1,13 +0,0 @@
|
|||||||
// Copyright 2017 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.
|
|
||||||
|
|
||||||
// +build !go1.9
|
|
||||||
|
|
||||||
package gcimporter
|
|
||||||
|
|
||||||
import "go/types"
|
|
||||||
|
|
||||||
func isAlias(obj *types.TypeName) bool {
|
|
||||||
return false // there are no type aliases before Go 1.9
|
|
||||||
}
|
|
@ -1,13 +0,0 @@
|
|||||||
// Copyright 2017 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.
|
|
||||||
|
|
||||||
// +build go1.9
|
|
||||||
|
|
||||||
package gcimporter
|
|
||||||
|
|
||||||
import "go/types"
|
|
||||||
|
|
||||||
func isAlias(obj *types.TypeName) bool {
|
|
||||||
return obj.IsAlias()
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user