Skip to content

Commit

Permalink
Import versionsort implementation from musl for systems without versi…
Browse files Browse the repository at this point in the history
…onsort

versionsort is a GNU extension, not available on *BSD systems.
  • Loading branch information
valpackett committed Jul 16, 2018
1 parent 8362031 commit f8b4120
Show file tree
Hide file tree
Showing 4 changed files with 77 additions and 0 deletions.
4 changes: 4 additions & 0 deletions meson.build
Expand Up @@ -83,6 +83,10 @@ if get_option('coverity')
config_h.set('_Float64x', 'long')
endif

if cc.has_header_symbol('dirent.h', 'versionsort', prefix : prefix)
config_h.set('HAVE_VERSIONSORT', '1')
endif

# Dependencies
pkgconfig = import('pkgconfig')
dep_udev = dependency('libudev')
Expand Down
71 changes: 71 additions & 0 deletions src/libinput-versionsort.h
@@ -0,0 +1,71 @@
#pragma once

#include "config.h"

#ifndef HAVE_VERSIONSORT

/* Copyright © 2005-2014 Rich Felker, et al.
*
* Permission is hereby granted, free of charge, to any person obtaining
* a copy of this software and associated documentation files (the
* "Software"), to deal in the Software without restriction, including
* without limitation the rights to use, copy, modify, merge, publish,
* distribute, sublicense, and/or sell copies of the Software, and to
* permit persons to whom the Software is furnished to do so, subject to
* the following conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*/

#include <ctype.h>
#include <string.h>
#include <dirent.h>

static int
strverscmp(const char *l0, const char *r0)
{
const unsigned char *l = (const void *)l0;
const unsigned char *r = (const void *)r0;
size_t i, dp, j;
int z = 1;

/* Find maximal matching prefix and track its maximal digit
* suffix and whether those digits are all zeros. */
for (dp=i=0; l[i]==r[i]; i++) {
int c = l[i];
if (!c) return 0;
if (!isdigit(c)) dp=i+1, z=1;
else if (c!='0') z=0;
}

if (l[dp]!='0' && r[dp]!='0') {
/* If we're not looking at a digit sequence that began
* with a zero, longest digit string is greater. */
for (j=i; isdigit(l[j]); j++)
if (!isdigit(r[j])) return 1;
if (isdigit(r[j])) return -1;
} else if (z && dp<i && (isdigit(l[i]) || isdigit(r[i]))) {
/* Otherwise, if common prefix of digit sequence is
* all zeros, digits order less than non-digits. */
return (unsigned char)(l[i]-'0') - (unsigned char)(r[i]-'0');
}

return l[i] - r[i];
}

static int
versionsort(const struct dirent **a, const struct dirent **b)
{
return strverscmp((*a)->d_name, (*b)->d_name);
}

#endif
1 change: 1 addition & 0 deletions src/quirks.c
Expand Up @@ -35,6 +35,7 @@
#include <dirent.h>
#include <fnmatch.h>

#include "libinput-versionsort.h"
#include "libinput-util.h"
#include "libinput-private.h"

Expand Down
1 change: 1 addition & 0 deletions tools/libinput-record.c
Expand Up @@ -40,6 +40,7 @@
#include <signal.h>
#include <stdbool.h>

#include "libinput-versionsort.h"
#include "libinput-util.h"
#include "libinput-version.h"
#include "libinput-git-version.h"
Expand Down

0 comments on commit f8b4120

Please sign in to comment.