Skip to content

Commit

Permalink
go.tools/go/types: don't crash dealing with unknown constants
Browse files Browse the repository at this point in the history
Also: Better tracing for top-level declarations.

Fixes golang/go#8518.

LGTM=adonovan
R=adonovan
CC=golang-codereviews
https://golang.org/cl/132310043
  • Loading branch information
griesemer committed Aug 28, 2014
1 parent 61ce470 commit 87b4cd9
Show file tree
Hide file tree
Showing 3 changed files with 45 additions and 4 deletions.
40 changes: 38 additions & 2 deletions go/types/api_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -647,15 +647,15 @@ func TestSelection(t *testing.T) {
conf.Packages[path] = pkg
}

libSrc := `
const libSrc = `
package lib
type T float64
const C T = 3
var V T
func F() {}
func (T) M() {}
`
mainSrc := `
const mainSrc = `
package main
import "lib"
Expand Down Expand Up @@ -791,3 +791,39 @@ func main() {
}
}
}

func TestIssue8518(t *testing.T) {
fset := token.NewFileSet()
conf := Config{
Packages: make(map[string]*Package),
Error: func(err error) { t.Log(err) }, // don't exit after first error
Import: func(imports map[string]*Package, path string) (*Package, error) {
return imports[path], nil
},
}
makePkg := func(path, src string) {
f, err := parser.ParseFile(fset, path, src, 0)
if err != nil {
t.Fatal(err)
}
pkg, _ := conf.Check(path, fset, []*ast.File{f}, nil) // errors logged via conf.Error
conf.Packages[path] = pkg
}

const libSrc = `
package a
import "missing"
const C1 = foo
const C2 = missing.C
`

const mainSrc = `
package main
import "a"
var _ = a.C1
var _ = a.C2
`

makePkg("a", libSrc)
makePkg("main", mainSrc) // don't crash when type-checking this package
}
2 changes: 1 addition & 1 deletion go/types/check.go
Original file line number Diff line number Diff line change
Expand Up @@ -253,7 +253,7 @@ func (check *Checker) recordTypeAndValue(x ast.Expr, mode operandMode, typ Type,
assert(typ != nil)
if mode == constant {
assert(val != nil)
assert(isConstType(typ))
assert(typ == Typ[Invalid] || isConstType(typ))
}
if m := check.Types; m != nil {
m[x] = TypeAndValue{mode, typ, val}
Expand Down
7 changes: 6 additions & 1 deletion go/types/decl.go
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,12 @@ func (check *Checker) objDecl(obj Object, def *Named, path []*TypeName) {
}

if trace {
check.trace(obj.Pos(), "-- resolving %s", obj.Name())
check.trace(obj.Pos(), "-- declaring %s", obj.Name())
check.indent++
defer func() {
check.indent--
check.trace(obj.Pos(), "=> %s", obj)
}()
}

d := check.objMap[obj]
Expand Down

0 comments on commit 87b4cd9

Please # to comment.