Commit ba30c082 authored by Matthew Dempsky's avatar Matthew Dempsky Committed by Ian Lance Taylor

cmd/cgo: check for compiler errors in the C preamble

E.g., here's the new "go build" output:

$ go build misc/cgo/errors/issue8442.go
# command-line-arguments
could not determine kind of name for C.issue8442foo

gcc errors for preamble:
misc/cgo/errors/issue8442.go:11:19: error: unknown type name 'UNDEF'

Fixes #8442.

LGTM=iant
R=iant, alex.brainman
CC=golang-codereviews
https://golang.org/cl/129160043
parent 937f0d59
// Copyright 2014 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 main
// Issue 8442. Cgo output unhelpful error messages for
// invalid C preambles.
/*
void issue8442foo(UNDEF*); // ERROR HERE
*/
import "C"
func main() {
C.issue8442foo(nil)
}
...@@ -28,6 +28,7 @@ check err1.go ...@@ -28,6 +28,7 @@ check err1.go
check err2.go check err2.go
check err3.go check err3.go
check issue7757.go check issue7757.go
check issue8442.go
rm -rf errs _obj rm -rf errs _obj
exit 0 exit 0
...@@ -332,6 +332,7 @@ func (p *Package) guessKinds(f *File) []*Name { ...@@ -332,6 +332,7 @@ func (p *Package) guessKinds(f *File) []*Name {
const ( const (
notType = 1 << iota notType = 1 << iota
notConst notConst
notDeclared
) )
for _, line := range strings.Split(stderr, "\n") { for _, line := range strings.Split(stderr, "\n") {
if !strings.Contains(line, ": error:") { if !strings.Contains(line, ": error:") {
...@@ -366,7 +367,7 @@ func (p *Package) guessKinds(f *File) []*Name { ...@@ -366,7 +367,7 @@ func (p *Package) guessKinds(f *File) []*Name {
completed = true completed = true
case "not-declared": case "not-declared":
error_(token.NoPos, "%s", strings.TrimSpace(line[c2+1:])) sniff[i] |= notDeclared
case "not-type": case "not-type":
sniff[i] |= notType sniff[i] |= notType
case "not-const": case "not-const":
...@@ -375,12 +376,12 @@ func (p *Package) guessKinds(f *File) []*Name { ...@@ -375,12 +376,12 @@ func (p *Package) guessKinds(f *File) []*Name {
} }
if !completed { if !completed {
fatalf("%s did not produce error at completed:1\non input:\n%s", p.gccBaseCmd()[0], b.Bytes()) fatalf("%s did not produce error at completed:1\non input:\n%s\nfull error output:\n%s", p.gccBaseCmd()[0], b.Bytes(), stderr)
} }
for i, n := range names { for i, n := range names {
switch sniff[i] { switch sniff[i] {
case 0: default:
error_(token.NoPos, "could not determine kind of name for C.%s", fixGo(n.Go)) error_(token.NoPos, "could not determine kind of name for C.%s", fixGo(n.Go))
case notType: case notType:
n.Kind = "const" n.Kind = "const"
...@@ -391,6 +392,14 @@ func (p *Package) guessKinds(f *File) []*Name { ...@@ -391,6 +392,14 @@ func (p *Package) guessKinds(f *File) []*Name {
} }
} }
if nerrors > 0 { if nerrors > 0 {
// Check if compiling the preamble by itself causes any errors,
// because the messages we've printed out so far aren't helpful
// to users debugging preamble mistakes. See issue 8442.
preambleErrors := p.gccErrors([]byte(f.Preamble))
if len(preambleErrors) > 0 {
error_(token.NoPos, "\n%s errors for preamble:\n%s", p.gccBaseCmd()[0], preambleErrors)
}
fatalf("unresolved names") fatalf("unresolved names")
} }
......
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