GNU bug report logs -
#10016
ls -lk is wrong
Previous Next
Full log
Message #8 received at 10016 <at> debbugs.gnu.org (full text, mbox):
On 11/10/2011 04:35 PM, Alan Curry wrote:
> I mentioned this already in the bug#9939 thread, but nobody replied and it's
> really a separate issue so here's an independent report.
>
> This behavior:
>
> $ ls -l /bin/ls
> -rwxr-xr-x 1 root root 107124 Feb 8 2011 /bin/ls
> $ ls -lk /bin/ls
> -rwxr-xr-x 1 root root 105 Feb 8 2011 /bin/ls
>
> is awful. -k should not have any effect on the ls -l field that reports
> st_size. It is only supposed to possibly affect the reporting of st_blocks
> by -s and the "total" line at the start of a full directory listing.
I just re-read POSIX, and it looks like you are correct:
http://pubs.opengroup.org/onlinepubs/9699919799/utilities/ls.html
-k
Set the block size for the -s option and the per-directory block
count written for the -l, -n, -s, [XSI] [Option Start] -g, and -o
[Option End] options (see the STDOUT section) to 1024 bytes.
POSIX has no mention of -k affecting the file size output, just the
initial column for -s and the per-directory summary on "total" lines.
>
> I won't make any claims about what --block-size should do, but -k comes from
> BSD and it should act like BSD.
It's not so much what BSD says, but what POSIX specifies, that matters
here - I think you've made a pretty clear case that coreutils has a bug.
--
Eric Blake eblake <at> redhat.com +1-801-349-2682
Libvirt virtualization library http://libvirt.org
This bug report was last modified 13 years and 253 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.