forked from TrueCloudLab/rclone
Fix new style directory listing on windows
This commit is contained in:
parent
ce94c0e729
commit
b6f1391da3
2 changed files with 28 additions and 15 deletions
|
@ -12,6 +12,7 @@ import (
|
||||||
"log"
|
"log"
|
||||||
"os"
|
"os"
|
||||||
"path"
|
"path"
|
||||||
|
"runtime"
|
||||||
"sort"
|
"sort"
|
||||||
"strings"
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
|
@ -266,20 +267,17 @@ func TestFsListDirRoot(t *testing.T) {
|
||||||
// TestFsListSubdir tests List works for a subdirectory
|
// TestFsListSubdir tests List works for a subdirectory
|
||||||
func TestFsListSubdir(t *testing.T) {
|
func TestFsListSubdir(t *testing.T) {
|
||||||
skipIfNotOk(t)
|
skipIfNotOk(t)
|
||||||
test := func(fileName string) bool {
|
fileName := file2.Path
|
||||||
dir, _ := path.Split(fileName)
|
if runtime.GOOS == "windows" {
|
||||||
dir = dir[:len(dir)-1]
|
fileName = file2.WinPath
|
||||||
objs, dirs, err := fs.NewLister().Start(remote, dir).GetAll()
|
|
||||||
if err == fs.ErrorDirNotFound {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
require.NoError(t, err)
|
|
||||||
require.Len(t, objs, 1)
|
|
||||||
assert.Equal(t, fileName, objs[0].Remote())
|
|
||||||
require.Len(t, dirs, 0)
|
|
||||||
return true
|
|
||||||
}
|
}
|
||||||
assert.True(t, test(file2.Path) || test(file2.WinPath), "normal and alternative lists failed")
|
dir, _ := path.Split(fileName)
|
||||||
|
dir = dir[:len(dir)-1]
|
||||||
|
objs, dirs, err := fs.NewLister().Start(remote, dir).GetAll()
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Len(t, objs, 1)
|
||||||
|
assert.Equal(t, fileName, objs[0].Remote())
|
||||||
|
require.Len(t, dirs, 0)
|
||||||
}
|
}
|
||||||
|
|
||||||
// TestFsListLevel2 tests List works for 2 levels
|
// TestFsListLevel2 tests List works for 2 levels
|
||||||
|
|
|
@ -212,7 +212,8 @@ func (f *Fs) list(out fs.ListOpts, remote string, dirpath string, level int) (su
|
||||||
// Ignores everything which isn't Storable, eg links etc
|
// Ignores everything which isn't Storable, eg links etc
|
||||||
func (f *Fs) List(out fs.ListOpts, dir string) {
|
func (f *Fs) List(out fs.ListOpts, dir string) {
|
||||||
defer out.Finished()
|
defer out.Finished()
|
||||||
root := path.Join(f.root, dir)
|
dir = filterFragment(f.cleanUtf8(dir))
|
||||||
|
root := filepath.Join(f.root, dir)
|
||||||
_, err := os.Stat(root)
|
_, err := os.Stat(root)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
out.SetError(fs.ErrorDirNotFound)
|
out.SetError(fs.ErrorDirNotFound)
|
||||||
|
@ -670,11 +671,25 @@ func getDirFile(s string) (string, string) {
|
||||||
return dir, file
|
return dir, file
|
||||||
}
|
}
|
||||||
|
|
||||||
func (f *Fs) filterPath(s string) string {
|
// filterFragment cleans a path fragment which is part of a bigger
|
||||||
|
// path and not necessarily absolute
|
||||||
|
func filterFragment(s string) string {
|
||||||
|
if s == "" {
|
||||||
|
return s
|
||||||
|
}
|
||||||
s = filepath.Clean(s)
|
s = filepath.Clean(s)
|
||||||
if runtime.GOOS == "windows" {
|
if runtime.GOOS == "windows" {
|
||||||
s = strings.Replace(s, `/`, `\`, -1)
|
s = strings.Replace(s, `/`, `\`, -1)
|
||||||
|
}
|
||||||
|
return s
|
||||||
|
}
|
||||||
|
|
||||||
|
// filterPath cleans and makes absolute the path passed in.
|
||||||
|
//
|
||||||
|
// On windows it makes the path UNC also.
|
||||||
|
func (f *Fs) filterPath(s string) string {
|
||||||
|
s = filterFragment(s)
|
||||||
|
if runtime.GOOS == "windows" {
|
||||||
if !filepath.IsAbs(s) && !strings.HasPrefix(s, "\\") {
|
if !filepath.IsAbs(s) && !strings.HasPrefix(s, "\\") {
|
||||||
s2, err := filepath.Abs(s)
|
s2, err := filepath.Abs(s)
|
||||||
if err == nil {
|
if err == nil {
|
||||||
|
|
Loading…
Reference in a new issue