Merge pull request #949 from krishnasrinivas/rm-empty-dirs

Remove empty directories while removing an oobject
This commit is contained in:
Harshavardhana 2015-10-30 00:16:27 -07:00
commit 7df81f8707
2 changed files with 57 additions and 9 deletions

View File

@ -268,6 +268,37 @@ func (fs Filesystem) CreateObject(bucket, object, expectedMD5Sum string, size in
return newObject, nil return newObject, nil
} }
func deleteObjectPath(basePath, deletePath, bucket, object string) *probe.Error {
if basePath == deletePath {
return nil
}
fi, err := os.Stat(deletePath)
if err != nil {
if os.IsNotExist(err) {
return probe.NewError(ObjectNotFound{Bucket: bucket, Object: object})
}
return probe.NewError(err)
}
if fi.IsDir() {
empty, err := isDirEmpty(deletePath)
if err != nil {
return err.Trace()
}
if !empty {
return nil
}
}
if err := os.Remove(deletePath); err != nil {
return probe.NewError(err)
}
if err := deleteObjectPath(basePath, filepath.Dir(deletePath), bucket, object); err != nil {
return err.Trace()
}
return nil
}
// DeleteObject - delete and object // DeleteObject - delete and object
func (fs Filesystem) DeleteObject(bucket, object string) *probe.Error { func (fs Filesystem) DeleteObject(bucket, object string) *probe.Error {
fs.lock.Lock() fs.lock.Lock()
@ -278,6 +309,7 @@ func (fs Filesystem) DeleteObject(bucket, object string) *probe.Error {
return probe.NewError(BucketNameInvalid{Bucket: bucket}) return probe.NewError(BucketNameInvalid{Bucket: bucket})
} }
bucketPath := filepath.Join(fs.path, bucket)
// check bucket exists // check bucket exists
if _, err := os.Stat(filepath.Join(fs.path, bucket)); os.IsNotExist(err) { if _, err := os.Stat(filepath.Join(fs.path, bucket)); os.IsNotExist(err) {
return probe.NewError(BucketNotFound{Bucket: bucket}) return probe.NewError(BucketNotFound{Bucket: bucket})
@ -296,16 +328,12 @@ func (fs Filesystem) DeleteObject(bucket, object string) *probe.Error {
} else { } else {
objectPath = fs.path + string(os.PathSeparator) + bucket + string(os.PathSeparator) + object objectPath = fs.path + string(os.PathSeparator) + bucket + string(os.PathSeparator) + object
} }
err := deleteObjectPath(bucketPath, objectPath, bucket, object)
_, err := os.Stat(objectPath) if os.IsNotExist(err.ToGoError()) {
if err != nil {
if os.IsNotExist(err) {
return probe.NewError(ObjectNotFound{Bucket: bucket, Object: object}) return probe.NewError(ObjectNotFound{Bucket: bucket, Object: object})
} }
return probe.NewError(err) if err != nil {
} return err.Trace()
if err := os.Remove(objectPath); err != nil {
return probe.NewError(err)
} }
return nil return nil
} }

View File

@ -18,11 +18,31 @@ package fs
import ( import (
"errors" "errors"
"io"
"os" "os"
"path/filepath" "path/filepath"
"sort" "sort"
"github.com/minio/minio-xl/pkg/probe"
) )
// Check if a directory is empty
func isDirEmpty(dirname string) (bool, *probe.Error) {
f, err := os.Open(dirname)
defer f.Close()
if err != nil {
return false, probe.NewError(err)
}
names, err := f.Readdirnames(1)
if err != nil && err != io.EOF {
return false, probe.NewError(err)
}
if len(names) > 0 {
return false, nil
}
return true, nil
}
// RemoveAllDirs - removes only itself and all subdirectories // RemoveAllDirs - removes only itself and all subdirectories
func RemoveAllDirs(path string) error { func RemoveAllDirs(path string) error {
allFiles := func(fp string, fl os.FileInfo, err error) error { allFiles := func(fp string, fl os.FileInfo, err error) error {