Commit 12c0f1b3 authored by Ian Lance Taylor's avatar Ian Lance Taylor

cmd/cgo: set correct column for user-written code

Take advantage of the new /*line*/ comments.

Fixes #26745

Change-Id: I8098642e0f11f7418fe81b9a08dbe07671f930fe
Reviewed-on: https://go-review.googlesource.com/c/151598
Run-TryBot: Ian Lance Taylor <iant@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: default avatarRobert Griesemer <gri@golang.org>
parent cee9dfc3
...@@ -121,6 +121,7 @@ func TestReportsTypeErrors(t *testing.T) { ...@@ -121,6 +121,7 @@ func TestReportsTypeErrors(t *testing.T) {
"issue16591.go", "issue16591.go",
"issue18452.go", "issue18452.go",
"issue18889.go", "issue18889.go",
"issue26745.go",
"issue28721.go", "issue28721.go",
} { } {
check(t, file) check(t, file)
......
// Copyright 2018 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
// int a;
// void CF(int i) {}
import "C"
func F1(i int) int {
return C.a + 1 // ERROR HERE: :13
}
func F2(i int) {
C.CF(i) // ERROR HERE: :6
}
...@@ -891,6 +891,7 @@ func (p *Package) rewriteCall(f *File, call *Call) (string, bool) { ...@@ -891,6 +891,7 @@ func (p *Package) rewriteCall(f *File, call *Call) (string, bool) {
// Write _cgoCheckPointer calls to sbCheck. // Write _cgoCheckPointer calls to sbCheck.
var sbCheck bytes.Buffer var sbCheck bytes.Buffer
for i, param := range params { for i, param := range params {
origArg := args[i]
arg, nu := p.mangle(f, &args[i]) arg, nu := p.mangle(f, &args[i])
if nu { if nu {
needsUnsafe = true needsUnsafe = true
...@@ -910,7 +911,7 @@ func (p *Package) rewriteCall(f *File, call *Call) (string, bool) { ...@@ -910,7 +911,7 @@ func (p *Package) rewriteCall(f *File, call *Call) (string, bool) {
} }
if !p.needsPointerCheck(f, param.Go, args[i]) { if !p.needsPointerCheck(f, param.Go, args[i]) {
fmt.Fprintf(&sb, "_cgo%d := %s; ", i, gofmtLine(arg)) fmt.Fprintf(&sb, "_cgo%d := %s; ", i, gofmtPos(arg, origArg.Pos()))
continue continue
} }
...@@ -924,7 +925,7 @@ func (p *Package) rewriteCall(f *File, call *Call) (string, bool) { ...@@ -924,7 +925,7 @@ func (p *Package) rewriteCall(f *File, call *Call) (string, bool) {
continue continue
} }
fmt.Fprintf(&sb, "_cgo%d := %s; ", i, gofmtLine(arg)) fmt.Fprintf(&sb, "_cgo%d := %s; ", i, gofmtPos(arg, origArg.Pos()))
fmt.Fprintf(&sbCheck, "_cgoCheckPointer(_cgo%d); ", i) fmt.Fprintf(&sbCheck, "_cgoCheckPointer(_cgo%d); ", i)
} }
...@@ -1147,10 +1148,10 @@ func (p *Package) checkIndex(sb, sbCheck *bytes.Buffer, arg ast.Expr, i int) boo ...@@ -1147,10 +1148,10 @@ func (p *Package) checkIndex(sb, sbCheck *bytes.Buffer, arg ast.Expr, i int) boo
return false return false
} }
fmt.Fprintf(sb, "_cgoIndex%d := %s; ", i, gofmtLine(index.X)) fmt.Fprintf(sb, "_cgoIndex%d := %s; ", i, gofmtPos(index.X, index.X.Pos()))
origX := index.X origX := index.X
index.X = ast.NewIdent(fmt.Sprintf("_cgoIndex%d", i)) index.X = ast.NewIdent(fmt.Sprintf("_cgoIndex%d", i))
fmt.Fprintf(sb, "_cgo%d := %s; ", i, gofmtLine(arg)) fmt.Fprintf(sb, "_cgo%d := %s; ", i, gofmtPos(arg, arg.Pos()))
index.X = origX index.X = origX
fmt.Fprintf(sbCheck, "_cgoCheckPointer(_cgo%d, _cgoIndex%d); ", i, i) fmt.Fprintf(sbCheck, "_cgoCheckPointer(_cgo%d, _cgoIndex%d); ", i, i)
...@@ -1182,11 +1183,11 @@ func (p *Package) checkAddr(sb, sbCheck *bytes.Buffer, arg ast.Expr, i int) bool ...@@ -1182,11 +1183,11 @@ func (p *Package) checkAddr(sb, sbCheck *bytes.Buffer, arg ast.Expr, i int) bool
return false return false
} }
fmt.Fprintf(sb, "_cgoBase%d := %s; ", i, gofmtLine(*px)) fmt.Fprintf(sb, "_cgoBase%d := %s; ", i, gofmtPos(*px, (*px).Pos()))
origX := *px origX := *px
*px = ast.NewIdent(fmt.Sprintf("_cgoBase%d", i)) *px = ast.NewIdent(fmt.Sprintf("_cgoBase%d", i))
fmt.Fprintf(sb, "_cgo%d := %s; ", i, gofmtLine(arg)) fmt.Fprintf(sb, "_cgo%d := %s; ", i, gofmtPos(arg, arg.Pos()))
*px = origX *px = origX
// Use "0 == 0" to do the right thing in the unlikely event // Use "0 == 0" to do the right thing in the unlikely event
...@@ -1388,7 +1389,18 @@ func (p *Package) rewriteRef(f *File) { ...@@ -1388,7 +1389,18 @@ func (p *Package) rewriteRef(f *File) {
// Record source-level edit for cgo output. // Record source-level edit for cgo output.
if !r.Done { if !r.Done {
repl := gofmt(expr) repl := gofmtPos(expr, old.Pos())
end := fset.Position(old.End())
// Subtract 1 from the column if we are going to
// append a close parenthesis. That will set the
// correct column for the following characters.
sub := 0
if r.Name.Kind != "type" {
sub = 1
}
if end.Column > sub {
repl = fmt.Sprintf("%s/*line :%d:%d*/", repl, end.Line, end.Column-sub)
}
if r.Name.Kind != "type" { if r.Name.Kind != "type" {
repl = "(" + repl + ")" repl = "(" + repl + ")"
} }
...@@ -1506,6 +1518,17 @@ func (p *Package) rewriteName(f *File, r *Ref) ast.Expr { ...@@ -1506,6 +1518,17 @@ func (p *Package) rewriteName(f *File, r *Ref) ast.Expr {
return expr return expr
} }
// gofmtPos returns the gofmt-formatted string for an AST node,
// with a comment setting the position before the node.
func gofmtPos(n ast.Expr, pos token.Pos) string {
s := gofmtLine(n)
p := fset.Position(pos)
if p.Column == 0 {
return s
}
return fmt.Sprintf("/*line :%d:%d*/%s", p.Line, p.Column, s)
}
// gccBaseCmd returns the start of the compiler command line. // gccBaseCmd returns the start of the compiler command line.
// It uses $CC if set, or else $GCC, or else the compiler recorded // It uses $CC if set, or else $GCC, or else the compiler recorded
// during the initial build as defaultCC. // during the initial build as defaultCC.
......
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