Skip to content

Commit

Permalink
go/printer: predict the position of the '.' in SelectorExpr
Browse files Browse the repository at this point in the history
Workarorund for issue golang#70978, see the same issue for more details.

Fixes golang#70978

Change-Id: I7934d51af0679ac6fc10128d77001b0092bd7392
  • Loading branch information
mateusz834 committed Dec 24, 2024
1 parent 500675a commit ff6d2eb
Show file tree
Hide file tree
Showing 2 changed files with 83 additions and 0 deletions.
8 changes: 8 additions & 0 deletions src/go/printer/nodes.go
Original file line number Diff line number Diff line change
Expand Up @@ -1156,6 +1156,14 @@ func (p *printer) possibleSelectorExpr(expr ast.Expr, prec1, depth int) bool {
// multiple lines.
func (p *printer) selectorExpr(x *ast.SelectorExpr, depth int, isMethod bool) bool {
p.expr1(x.X, token.HighestPrec, depth)

// We don't have the position of the dot, so we have to predict it,
// to avoid issues with comment handling.
// See https://go.dev/issue/70978 and TestIssue70978 for more details.
if x.Sel.Pos().IsValid() && p.pos.Offset > p.posFor(x.Sel.Pos()).Offset {
p.setPos(x.Sel.Pos())
}

p.print(token.PERIOD)
if line := p.lineFor(x.Sel.Pos()); p.pos.IsValid() && p.pos.Line < line {
p.print(indent, newline)
Expand Down
75 changes: 75 additions & 0 deletions src/go/printer/printer_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ import (
"io"
"os"
"path/filepath"
"strings"
"testing"
"time"
)
Expand Down Expand Up @@ -863,3 +864,77 @@ func TestEmptyDecl(t *testing.T) { // issue 63566
}
}
}

func TestIssue70978(t *testing.T) {
cases := []struct {
src string
want string
newName string
}{
{
newName: "someotherfmtpackage",
src: `package main
func main() {
// comment
fmt.Println() // Comment
}
`,
want: `package main
func main() {
// comment
someotherfmtpackage.Println() // Comment
}
`,
},
{
newName: "someotherfmtpkg",
src: `package main
func main() {
// comment
fmt.Println() // Comment
}
`,
want: `package main
func main() {
// comment
someotherfmtpkg.Println() // Comment
}
`,
},
}

for _, tt := range cases {
fset := token.NewFileSet()
f, err := parser.ParseFile(fset, "test.go", tt.src, parser.SkipObjectResolution|parser.ParseComments)
if err != nil {
t.Fatal(err)
}

ast.Inspect(f, func(n ast.Node) bool {
switch n := n.(type) {
case *ast.SelectorExpr:
switch x := n.X.(type) {
case *ast.Ident:
x.Name = tt.newName
}
}
return true
})

var b strings.Builder
config := Config{Mode: UseSpaces | TabIndent, Tabwidth: 8}
config.Fprint(&b, fset, f)
got := b.String()
if got != tt.want {
t.Errorf("unexpected Fprint output:\n%s\nwant:\n%s", got, tt.want)
}
}
}

0 comments on commit ff6d2eb

Please sign in to comment.