Improve RemoveRepo implementation

This commit is contained in:
Amolith 2024-02-29 15:51:42 -05:00
parent dde4c97802
commit 9a91d4f2ea
Signed by: Amolith
SSH Key Fingerprint: SHA256:JBKEeoO/72Fz03rtlzeO49PATFT2maMancH3opcT0h0
1 changed files with 9 additions and 29 deletions

View File

@ -7,7 +7,6 @@ package git
import (
"errors"
"fmt"
"io"
"net/url"
"os"
"strings"
@ -149,42 +148,23 @@ func RemoveRepo(url string) (err error) {
return err
}
// TODO: Check whether the two parent directories are empty and remove them if
// so
for i := 0; i < 2; i++ {
path = strings.TrimSuffix(path, "/")
path = path[:strings.LastIndex(path, "/")]
dirs := strings.Split(path, "/")
for range dirs {
if path == "data" {
break
}
empty, err := dirEmpty(path)
if err != nil {
return err
}
if empty {
err = os.Remove(path)
if err != nil {
return err
}
// This folder likely has data, so might as well save some time by
// not checking the parents we can't delete anyway.
break
}
path = path[:strings.LastIndex(path, "/")]
}
return err
}
// dirEmpty checks if a directory is empty.
func dirEmpty(name string) (empty bool, err error) {
f, err := os.Open(name)
if err != nil {
return false, err
}
defer f.Close()
_, err = f.Readdirnames(1)
if err == io.EOF {
return true, nil
}
return false, err
return nil
}
// stringifyRepo accepts a repository URI string and the corresponding local