From 10201db13962cd9b2236cdbd613ffb34f417fc05 Mon Sep 17 00:00:00 2001 From: Lucas Molas Date: Thu, 12 Jul 2018 11:05:56 -0300 Subject: [PATCH 1/2] mfs: remove `sort` from `ListNames()` License: MIT Signed-off-by: Lucas Molas --- mfs/dir.go | 3 --- 1 file changed, 3 deletions(-) diff --git a/mfs/dir.go b/mfs/dir.go index 17f09356f18..d5991581280 100644 --- a/mfs/dir.go +++ b/mfs/dir.go @@ -6,7 +6,6 @@ import ( "fmt" "os" "path" - "sort" "sync" "time" @@ -245,8 +244,6 @@ func (d *Directory) ListNames(ctx context.Context) ([]string, error) { return nil, err } - sort.Strings(out) - return out, nil } From dfb81abf8013eeed325f39699c573e6a3e6c2745 Mon Sep 17 00:00:00 2001 From: Lucas Molas Date: Thu, 12 Jul 2018 19:42:32 -0300 Subject: [PATCH 2/2] commands: files ls: sort output Imitate Unix `ls` command, sort by default; disable with `-U` flag. License: MIT Signed-off-by: Lucas Molas --- core/commands/files.go | 11 ++++++++++- test/sharness/t0250-files-api.sh | 16 +++++++++++++--- 2 files changed, 23 insertions(+), 4 deletions(-) diff --git a/core/commands/files.go b/core/commands/files.go index 17751c17eb2..e9c021aef10 100644 --- a/core/commands/files.go +++ b/core/commands/files.go @@ -8,6 +8,7 @@ import ( "io" "os" gopath "path" + "sort" "strings" bservice "github.com/ipfs/go-ipfs/blockservice" @@ -405,6 +406,7 @@ Examples: }, Options: []cmdkit.Option{ cmdkit.BoolOption("l", "Use long listing format."), + cmdkit.BoolOption("U", "Do not sort; list entries in directory order."), }, Run: func(req oldcmds.Request, res oldcmds.Response) { var arg string @@ -482,8 +484,15 @@ Examples: } buf := new(bytes.Buffer) - long, _, _ := res.Request().Option("l").Bool() + noSort, _, _ := res.Request().Option("U").Bool() + if !noSort { + sort.Slice(out.Entries, func(i, j int) bool { + return strings.Compare(out.Entries[i].Name, out.Entries[j].Name) < 0 + }) + } + + long, _, _ := res.Request().Option("l").Bool() for _, o := range out.Entries { if long { fmt.Fprintf(buf, "%s\t%s\t%d\n", o.Name, o.Hash, o.Size) diff --git a/test/sharness/t0250-files-api.sh b/test/sharness/t0250-files-api.sh index adf72efdc1d..fbc77aad41d 100755 --- a/test/sharness/t0250-files-api.sh +++ b/test/sharness/t0250-files-api.sh @@ -56,19 +56,29 @@ test_sharding() { test_expect_success "can make 100 files in a directory $EXTRA" ' printf "" > list_exp_raw - for i in `seq 100` + for i in `seq 100 -1 1` do echo $i | ipfs files write --create /foo/file$i || return 1 echo file$i >> list_exp_raw done ' + # Create the files in reverse (unsorted) order (`seq 100 -1 1`) + # to check the sort in the `ipfs files ls` command. `ProtoNode` + # links are always sorted at the DAG layer so the sorting feature + # is tested with sharded directories. - test_expect_success "listing works $EXTRA" ' - ipfs files ls /foo |sort > list_out && + test_expect_success "sorted listing works $EXTRA" ' + ipfs files ls /foo > list_out && sort list_exp_raw > list_exp && test_cmp list_exp list_out ' + test_expect_success "unsorted listing works $EXTRA" ' + ipfs files ls -U /foo > list_out && + sort list_exp_raw > sort_list_not_exp && + ! test_cmp sort_list_not_exp list_out + ' + test_expect_success "can read a file from sharded directory $EXTRA" ' ipfs files read /foo/file65 > file_out && echo "65" > file_exp &&