mirror of
https://github.com/golang/go
synced 2024-11-21 19:34:46 -07:00
gofix: fixes for path/filepath changes
Fixes #1970. R=rsc, r CC=golang-dev https://golang.org/cl/4650050
This commit is contained in:
parent
69905c6213
commit
da19831c17
@ -6,6 +6,7 @@ include ../../Make.inc
|
||||
|
||||
TARG=gofix
|
||||
GOFILES=\
|
||||
filepath.go\
|
||||
fix.go\
|
||||
httpfinalurl.go\
|
||||
httpheaders.go\
|
||||
|
53
src/cmd/gofix/filepath.go
Normal file
53
src/cmd/gofix/filepath.go
Normal file
@ -0,0 +1,53 @@
|
||||
// Copyright 2011 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
|
||||
|
||||
import (
|
||||
"go/ast"
|
||||
)
|
||||
|
||||
func init() {
|
||||
register(fix{
|
||||
"filepath",
|
||||
filepathFunc,
|
||||
`Adapt code from filepath.[List]SeparatorString to string(filepath.[List]Separator).
|
||||
|
||||
http://codereview.appspot.com/4527090
|
||||
`,
|
||||
})
|
||||
}
|
||||
|
||||
func filepathFunc(f *ast.File) (fixed bool) {
|
||||
if !imports(f, "path/filepath") {
|
||||
return
|
||||
}
|
||||
|
||||
walk(f, func(n interface{}) {
|
||||
e, ok := n.(*ast.Expr)
|
||||
if !ok {
|
||||
return
|
||||
}
|
||||
|
||||
var ident string
|
||||
switch {
|
||||
case isPkgDot(*e, "filepath", "SeparatorString"):
|
||||
ident = "filepath.Separator"
|
||||
case isPkgDot(*e, "filepath", "ListSeparatorString"):
|
||||
ident = "filepath.ListSeparator"
|
||||
default:
|
||||
return
|
||||
}
|
||||
|
||||
// string(filepath.[List]Separator)
|
||||
*e = &ast.CallExpr{
|
||||
Fun: ast.NewIdent("string"),
|
||||
Args: []ast.Expr{ast.NewIdent(ident)},
|
||||
}
|
||||
|
||||
fixed = true
|
||||
})
|
||||
|
||||
return
|
||||
}
|
33
src/cmd/gofix/filepath_test.go
Normal file
33
src/cmd/gofix/filepath_test.go
Normal file
@ -0,0 +1,33 @@
|
||||
// Copyright 2011 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
|
||||
|
||||
func init() {
|
||||
addTestCases(filepathTests)
|
||||
}
|
||||
|
||||
var filepathTests = []testCase{
|
||||
{
|
||||
Name: "filepath.0",
|
||||
In: `package main
|
||||
|
||||
import (
|
||||
"path/filepath"
|
||||
)
|
||||
|
||||
var _ = filepath.SeparatorString
|
||||
var _ = filepath.ListSeparatorString
|
||||
`,
|
||||
Out: `package main
|
||||
|
||||
import (
|
||||
"path/filepath"
|
||||
)
|
||||
|
||||
var _ = string(filepath.Separator)
|
||||
var _ = string(filepath.ListSeparator)
|
||||
`,
|
||||
},
|
||||
}
|
Loading…
Reference in New Issue
Block a user