fix(columns): hide misleading directory sizes in size column
Problem: the size column shows the filesystem inode size (typically 4096 = 4.1k) for directories, which is misleading — users expect no size for directories. Solution: add an early return for directory entries in the size render function of the files, SSH, and S3 adapters. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
parent
abc4879688
commit
2aff22aa18
3 changed files with 15 additions and 2 deletions
|
|
@ -60,6 +60,9 @@ file_columns.size = {
|
|||
if not stat then
|
||||
return columns.EMPTY
|
||||
end
|
||||
if entry[FIELD_TYPE] == 'directory' then
|
||||
return columns.EMPTY
|
||||
end
|
||||
if stat.size >= 1e9 then
|
||||
return string.format('%.1fG', stat.size / 1e9)
|
||||
elseif stat.size >= 1e6 then
|
||||
|
|
|
|||
|
|
@ -8,6 +8,7 @@ local s3fs = require('canola.adapters.s3.s3fs')
|
|||
local util = require('canola.util')
|
||||
local M = {}
|
||||
|
||||
local FIELD_TYPE = constants.FIELD_TYPE
|
||||
local FIELD_META = constants.FIELD_META
|
||||
|
||||
---@class (exact) canola.s3Url
|
||||
|
|
@ -84,7 +85,11 @@ s3_columns.size = {
|
|||
local meta = entry[FIELD_META]
|
||||
if not meta or not meta.size then
|
||||
return ''
|
||||
elseif meta.size >= 1e9 then
|
||||
end
|
||||
if entry[FIELD_TYPE] == 'directory' then
|
||||
return ''
|
||||
end
|
||||
if meta.size >= 1e9 then
|
||||
return string.format('%.1fG', meta.size / 1e9)
|
||||
elseif meta.size >= 1e6 then
|
||||
return string.format('%.1fM', meta.size / 1e6)
|
||||
|
|
|
|||
|
|
@ -11,6 +11,7 @@ local util = require('canola.util')
|
|||
local M = {}
|
||||
|
||||
local FIELD_NAME = constants.FIELD_NAME
|
||||
local FIELD_TYPE = constants.FIELD_TYPE
|
||||
local FIELD_META = constants.FIELD_META
|
||||
|
||||
---@class (exact) canola.sshUrl
|
||||
|
|
@ -152,7 +153,11 @@ ssh_columns.size = {
|
|||
local meta = entry[FIELD_META]
|
||||
if not meta or not meta.size then
|
||||
return ''
|
||||
elseif meta.size >= 1e9 then
|
||||
end
|
||||
if entry[FIELD_TYPE] == 'directory' then
|
||||
return ''
|
||||
end
|
||||
if meta.size >= 1e9 then
|
||||
return string.format('%.1fG', meta.size / 1e9)
|
||||
elseif meta.size >= 1e6 then
|
||||
return string.format('%.1fM', meta.size / 1e6)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue