Commit e8616843 authored by Egon Elbre's avatar Egon Elbre Committed by Robert Griesemer

cmd/fix,cmd/gofmt: flush to disk before diffing

Flush file content to disk before diffing files,
may cause unpredictable results on Windows.

Convert from \r\n to \n when comparing diff result.

Change-Id: Ibcd6154a2382dba1338ee5674333611aea16bb65
Reviewed-on: https://go-review.googlesource.com/36750Reviewed-by: default avatarRobert Griesemer <gri@golang.org>
Run-TryBot: Robert Griesemer <gri@golang.org>
parent c5ddc558
...@@ -17,6 +17,7 @@ import ( ...@@ -17,6 +17,7 @@ import (
"os" "os"
"os/exec" "os/exec"
"path/filepath" "path/filepath"
"runtime"
"sort" "sort"
"strings" "strings"
) )
...@@ -237,25 +238,41 @@ func isGoFile(f os.FileInfo) bool { ...@@ -237,25 +238,41 @@ func isGoFile(f os.FileInfo) bool {
return !f.IsDir() && !strings.HasPrefix(name, ".") && strings.HasSuffix(name, ".go") return !f.IsDir() && !strings.HasPrefix(name, ".") && strings.HasSuffix(name, ".go")
} }
func writeTempFile(dir, prefix string, data []byte) (string, error) {
file, err := ioutil.TempFile(dir, prefix)
if err != nil {
return "", err
}
_, err = file.Write(data)
if err1 := file.Close(); err == nil {
err = err1
}
if err != nil {
os.Remove(file.Name())
return "", err
}
return file.Name(), nil
}
func diff(b1, b2 []byte) (data []byte, err error) { func diff(b1, b2 []byte) (data []byte, err error) {
f1, err := ioutil.TempFile("", "go-fix") f1, err := writeTempFile("", "go-fix", b1)
if err != nil { if err != nil {
return nil, err return
} }
defer os.Remove(f1.Name()) defer os.Remove(f1)
defer f1.Close()
f2, err := ioutil.TempFile("", "go-fix") f2, err := writeTempFile("", "go-fix", b2)
if err != nil { if err != nil {
return nil, err return
} }
defer os.Remove(f2.Name()) defer os.Remove(f2)
defer f2.Close()
f1.Write(b1) cmd := "diff"
f2.Write(b2) if runtime.GOOS == "plan9" {
cmd = "/bin/ape/diff"
}
data, err = exec.Command("diff", "-u", f1.Name(), f2.Name()).CombinedOutput() data, err = exec.Command(cmd, "-u", f1, f2).CombinedOutput()
if len(data) > 0 { if len(data) > 0 {
// diff exits with a non-zero status when the files don't match. // diff exits with a non-zero status when the files don't match.
// Ignore that failure as long as we get output. // Ignore that failure as long as we get output.
......
...@@ -225,36 +225,45 @@ func gofmtMain() { ...@@ -225,36 +225,45 @@ func gofmtMain() {
} }
} }
func writeTempFile(dir, prefix string, data []byte) (string, error) {
file, err := ioutil.TempFile(dir, prefix)
if err != nil {
return "", err
}
_, err = file.Write(data)
if err1 := file.Close(); err == nil {
err = err1
}
if err != nil {
os.Remove(file.Name())
return "", err
}
return file.Name(), nil
}
func diff(b1, b2 []byte, filename string) (data []byte, err error) { func diff(b1, b2 []byte, filename string) (data []byte, err error) {
f1, err := ioutil.TempFile("", "gofmt") f1, err := writeTempFile("", "gofmt", b1)
if err != nil { if err != nil {
return return
} }
defer os.Remove(f1.Name()) defer os.Remove(f1)
defer f1.Close()
f2, err := ioutil.TempFile("", "gofmt") f2, err := writeTempFile("", "gofmt", b2)
if err != nil { if err != nil {
return return
} }
defer os.Remove(f2.Name()) defer os.Remove(f2)
defer f2.Close()
f1.Write(b1)
f2.Write(b2)
cmd := "diff" cmd := "diff"
if runtime.GOOS == "plan9" { if runtime.GOOS == "plan9" {
cmd = "/bin/ape/diff" cmd = "/bin/ape/diff"
} }
data, err = exec.Command(cmd, "-u", f1.Name(), f2.Name()).CombinedOutput() data, err = exec.Command(cmd, "-u", f1, f2).CombinedOutput()
if len(data) > 0 { if len(data) > 0 {
// diff exits with a non-zero status when the files don't match. // diff exits with a non-zero status when the files don't match.
// Ignore that failure as long as we get output. // Ignore that failure as long as we get output.
err = nil return replaceTempFilename(data, filename)
data, err = replaceTempFilename(data, filename)
} }
return return
} }
......
...@@ -198,6 +198,11 @@ func TestDiff(t *testing.T) { ...@@ -198,6 +198,11 @@ func TestDiff(t *testing.T) {
if err != nil { if err != nil {
t.Fatal(err) t.Fatal(err)
} }
if runtime.GOOS == "windows" {
b = bytes.Replace(b, []byte{'\r', '\n'}, []byte{'\n'}, -1)
}
bs := bytes.SplitN(b, []byte{'\n'}, 3) bs := bytes.SplitN(b, []byte{'\n'}, 3)
line0, line1 := bs[0], bs[1] line0, line1 := bs[0], bs[1]
......
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