Commit 1d890ac0 authored by Andrew Gerrand's avatar Andrew Gerrand

misc/makerelease: use built in "del" to remove files

Git marks some of its files read only, so os.RemoveAll isn't sufficient
to remove them from the ".git" directory.

Change-Id: I3150596931d1c77e7cf9fb8da1a999d2c6730121
Reviewed-on: https://go-review.googlesource.com/2930Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
parent 90ce1936
...@@ -775,7 +775,19 @@ func setupOAuthClient() error { ...@@ -775,7 +775,19 @@ func setupOAuthClient() error {
func (b *Build) clean(files []string) error { func (b *Build) clean(files []string) error {
for _, name := range files { for _, name := range files {
err := os.RemoveAll(filepath.Join(b.root, name)) path := filepath.Join(b.root, name)
var err error
if b.OS == "windows" {
// Git sets some of its packfiles as 'read only',
// so os.RemoveAll will fail for the ".git" directory.
// Instead, shell out to cmd's 'del' subcommand.
cmd := exec.Command("cmd.exe", "/C", "del", "/Q", "/F", "/S", path)
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
err = cmd.Run()
} else {
err = os.RemoveAll(path)
}
if err != nil { if err != nil {
return err return err
} }
......
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