]> git.ipfire.org Git - thirdparty/coreutils.git/commitdiff
ls: fix recent regression in size alignment
authorPádraig Brady <P@draigBrady.com>
Fri, 3 Nov 2023 16:22:22 +0000 (16:22 +0000)
committerPádraig Brady <P@draigBrady.com>
Fri, 3 Nov 2023 16:34:38 +0000 (16:34 +0000)
* src/ls.c (print_long_format): Use correct column width,
introduced due to a copy/paste error in commit v9.4-2-gcbb6dfec5
* tests/ls/size-align.sh: Add a test.
* tests/local.mk: Reference the new test.
Fixes https://bugs.gnu.org/66919

src/ls.c
tests/local.mk
tests/ls/size-align.sh [new file with mode: 0755]

index e16972d3eccc42b8d4e8206148ec187a36f3f4fc..2631526635b3dae1345251849b9f3abe02237ef8 100644 (file)
--- a/src/ls.c
+++ b/src/ls.c
@@ -4444,7 +4444,7 @@ print_long_format (const struct fileinfo *f)
                            hbuf, file_human_output_opts, 1,
                            file_output_block_size));
       int size_width = mbswidth (size, MBSWIDTH_FLAGS);
-      for (int pad = size_width < 0 ? 0 : block_size_width - size_width;
+      for (int pad = size_width < 0 ? 0 : file_size_width - size_width;
            0 < pad; pad--)
         *p++ = ' ';
       while ((*p++ = *size++))
index a5fb62d969ccd3ce5894e3e94d129843ea9ee94e..db4ee7ed87bd2828a9685fb211d34063e43495a8 100644 (file)
@@ -635,6 +635,7 @@ all_tests =                                 \
   tests/ls/no-cap.sh                           \
   tests/ls/selinux-segfault.sh                 \
   tests/ls/quote-align.sh                      \
+  tests/ls/size-align.sh                       \
   tests/ls/readdir-mountpoint-inode.sh         \
   tests/ls/recursive.sh                                \
   tests/ls/removed-directory.sh                        \
diff --git a/tests/ls/size-align.sh b/tests/ls/size-align.sh
new file mode 100755 (executable)
index 0000000..350e85d
--- /dev/null
@@ -0,0 +1,32 @@
+#!/bin/sh
+# test size alignment
+
+# Copyright (C) 2023 Free Software Foundation, Inc.
+
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+
+# You should have received a copy of the GNU General Public License
+# along with this program.  If not, see <https://www.gnu.org/licenses/>.
+
+. "${srcdir=.}/tests/init.sh"; path_prepend_ ./src
+print_ver_ ls truncate
+
+truncate -s      0 small || framework_failure_
+truncate -s 123456 large || framework_failure_
+echo > alloc || framework_failure_
+
+ls -s -l small alloc large > out || fail=1
+len=$(wc -L < out) || framework_failure_
+lines=$(wc -l < out) || framework_failure_
+same=$(grep "^.\\{$len\\}\$" out | wc -l) || framework_failure_
+test "$same" = "$lines" || { cat out; fail=1; }
+
+Exit $fail