X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/55315b668b8fa04572a44fd7db6598478f54130a..7d4da75d3980d465053c44b4d5b16afe166912a6:/apps/workbench/app/models/collection.rb diff --git a/apps/workbench/app/models/collection.rb b/apps/workbench/app/models/collection.rb index 305ea01530..f5aef841ea 100644 --- a/apps/workbench/app/models/collection.rb +++ b/apps/workbench/app/models/collection.rb @@ -1,3 +1,7 @@ +# Copyright (C) The Arvados Authors. All rights reserved. +# +# SPDX-License-Identifier: AGPL-3.0 + require "arvados/keep" class Collection < ArvadosBase @@ -64,8 +68,8 @@ class Collection < ArvadosBase .sort.flat_map do |parts| [parts + [nil]] + dir_to_tree.call(File.join(parts)) end - # Then extend that list with files in this directory. - subnodes + tree[File.split(dirname)] + # Then extend that list with files in this directory, except the empty dir placeholders (0:0:. files). + subnodes + tree[File.split(dirname)].reject { |_, basename, size| (basename == '.') and (size == 0) } end dir_to_tree.call('.') end @@ -99,6 +103,6 @@ class Collection < ArvadosBase end def untrash - arvados_api_client.api(self.class, "/#{self.uuid}/untrash", {}) + arvados_api_client.api(self.class, "/#{self.uuid}/untrash", {"ensure_unique_name" => true}) end end