root/lib/filevercmp.h

/* [<][>][^][v][top][bottom][index][help] */

INCLUDED FROM


     1 /* Compare file names containing version numbers.
     2 
     3    Copyright (C) 1995 Ian Jackson <iwj10@cus.cam.ac.uk>
     4    Copyright (C) 2001 Anthony Towns <aj@azure.humbug.org.au>
     5    Copyright (C) 2008-2023 Free Software Foundation, Inc.
     6 
     7    This file is free software: you can redistribute it and/or modify
     8    it under the terms of the GNU Lesser General Public License as
     9    published by the Free Software Foundation, either version 3 of the
    10    License, or (at your option) any later version.
    11 
    12    This file is distributed in the hope that it will be useful,
    13    but WITHOUT ANY WARRANTY; without even the implied warranty of
    14    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    15    GNU Lesser General Public License for more details.
    16 
    17    You should have received a copy of the GNU Lesser General Public License
    18    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
    19 
    20 #ifndef FILEVERCMP_H
    21 #define FILEVERCMP_H
    22 
    23 #include <stddef.h>
    24 
    25 /* Compare strings A and B as file names containing version numbers,
    26    and return an integer that is negative, zero, or positive depending
    27    on whether A compares less than, equal to, or greater than B.
    28 
    29    Use the following version sort algorithm:
    30 
    31      1. Compare the strings' maximal-length non-digit prefixes lexically.
    32         If there is a difference return that difference.
    33         Otherwise discard the prefixes and continue with the next step.
    34 
    35      2. Compare the strings' maximal-length digit prefixes, using
    36         numeric comparison of the numbers represented by each prefix.
    37         (Treat an empty prefix as zero; this can happen only at string end.)
    38         If there is a difference, return that difference.
    39         Otherwise discard the prefixes and continue with the next step.
    40 
    41      3. If both strings are empty, return 0.  Otherwise continue with step 1.
    42 
    43    In version sort, lexical comparison is left to right, byte by byte,
    44    using the byte's numeric value (0-255), except that:
    45 
    46      1. ASCII letters sort before other bytes.
    47      2. A tilde sorts before anything, even an empty string.
    48 
    49    In addition to the version sort rules, the following strings have
    50    special priority and sort before all other strings (listed in order):
    51 
    52      1. The empty string.
    53      2. ".".
    54      3. "..".
    55      4. Strings starting with "." sort before other strings.
    56 
    57    Before comparing two strings where both begin with non-".",
    58    or where both begin with "." but neither is "." or "..",
    59    suffixes matching the C-locale extended regular expression
    60    (\.[A-Za-z~][A-Za-z0-9~]*)*$ are removed and the strings compared
    61    without them, using version sort without special priority;
    62    if they do not compare equal, this comparison result is used and
    63    the suffixes are effectively ignored.  Otherwise, the entire
    64    strings are compared using version sort.  When removing a suffix
    65    from a nonempty string, remove the maximal-length suffix such that
    66    the remaining string is nonempty.
    67 
    68    This function is intended to be a replacement for strverscmp.  */
    69 int filevercmp (char const *a, char const *b) _GL_ATTRIBUTE_PURE;
    70 
    71 /* Like filevercmp, except compare the byte arrays A (of length ALEN)
    72    and B (of length BLEN) so that A and B can contain '\0', which
    73    sorts just before '\1'.  But if ALEN is -1 treat A as a string
    74    terminated by '\0', and similarly for BLEN.  */
    75 int filenvercmp (char const *a, ptrdiff_t alen, char const *b, ptrdiff_t blen)
    76   _GL_ATTRIBUTE_PURE;
    77 
    78 #endif /* FILEVERCMP_H */

/* [<][>][^][v][top][bottom][index][help] */