bug-coreutils
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

bug#41563: Possible bug with 'sort -Vr' version sorting


From: Erik Auerswald
Subject: bug#41563: Possible bug with 'sort -Vr' version sorting
Date: Thu, 28 May 2020 11:02:43 +0200
User-agent: Mutt/1.5.21 (2010-09-15)

Hi,

On Thu, May 28, 2020 at 08:48:16AM +0200, Kamil Dudka wrote:
> On Wednesday, May 27, 2020 2:07:32 PM CEST Danie de Jager via GNU coreutils 
> Bug Reports wrote:
> > 
> > I use sort -Vr to sort version numbers. I noticed this discrepancy on
> > the latest kernel version from Centos 7.8.
> > 
> > command to get output:
> > # ls -t /boot/vmlinuz-* | sed "s/\/boot\/vmlinuz-//g" | grep -v rescue | 
> > sort -Vr
> > 
> > 3.10.0-1127.el7.x86_64
> > 3.10.0-1127.8.2.el7.x86_64
> > 3.10.0-1062.18.1.el7.x86_64
> 
> It is the underscore in the .x86_64 suffix what breaks the version compare 
> algorithm.  If you replace the underscore by an alphabetic character, it
> sorts as you expect:
> 
> # ls -t /boot/vmlinuz-* | sed "s/\/boot\/vmlinuz-//g" | grep -v rescue | \
>     sed 's/x86_64/x86X64/' | sort -Vr | sed 's/x86X64/x86_64/'
> 
> 3.10.0-1127.8.2.el7.x86_64
> 3.10.0-1127.el7.x86_64
> 3.10.0-1062.18.1.el7.x86_64

That is interesting.  The underscore can be replaced by a digit or even
removed as well.  Replacing it with a dot (.)  does not help.

This differs from Debian's "dpkg --compare-versions", where the results
of the comparison do not change by replacing the underscore with a
digit or character, or by removing it (the underscore is identified as
problematic, though):

    $ dpkg --compare-versions 3.10.0-1127.8.2.el7.x86_64 lt 
3.10.0-1127.el7.x86_64 && echo less
    dpkg: warning: version '3.10.0-1127.8.2.el7.x86_64' has bad syntax: invalid 
character in revision number
    dpkg: warning: version '3.10.0-1127.el7.x86_64' has bad syntax: invalid 
character in revision number
    less
    $ dpkg --compare-versions 3.10.0-1127.8.2.el7.x86.64 lt 
3.10.0-1127.el7.x86.64 && echo less
    less
    $ dpkg --compare-versions 3.10.0-1127.8.2.el7.x86X64 lt 
3.10.0-1127.el7.x86X64 && echo less
    less
    $ dpkg --compare-versions 3.10.0-1127.8.2.el7.x86164 lt 
3.10.0-1127.el7.x86164 && echo less
    less
    $ dpkg --compare-versions 3.10.0-1127.8.2.el7.x8664 lt 
3.10.0-1127.el7.x8664 && echo less
    less

The way I read the GNU Coreutils documentation, removing the underscore
should not affect the version sort comparison result.

Thanks,
Erik
-- 
There is no remedy for anything in life.
                        -- Ernest Hemingway





reply via email to

[Prev in Thread] Current Thread [Next in Thread]