cmd/goimports: flush to disk before diffing
Port of gofmt change at golang.org/cl/36750 Change-Id: Ie0ef6770be6361264ed45a9a9ece950aba24e852 Reviewed-on: https://go-review.googlesource.com/39073 Reviewed-by: Brad Fitzpatrick <bradfitz@golang.org> Run-TryBot: Brad Fitzpatrick <bradfitz@golang.org> TryBot-Result: Gobot Gobot <gobot@golang.org>
This commit is contained in:
parent
d63e2b22b0
commit
d83db204ce
|
|
@ -277,36 +277,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
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue