Browse Source

test-path-utils: handle const parameter of basename and dirname

The parameter to basename(3) and dirname(3) traditionally had the type
"char *", but on OpenBSD it's been "const char *" for years.  That
causes (at least) Clang to throw an incompatible-pointer-types warning
for test-path-utils, where we try to pass around pointers to these
functions.

Avoid this warning (which is fatal in DEVELOPER mode) by ignoring the
promise of OpenBSD's implementations to keep input strings unmodified
and enclosing them in POSIX-compatible wrappers.

Signed-off-by: Rene Scharfe <l.s.r@web.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
maint
René Scharfe 8 years ago committed by Junio C Hamano
parent
commit
29c2eda80b
  1. 18
      t/helper/test-path-utils.c

18
t/helper/test-path-utils.c

@ -38,6 +38,20 @@ struct test_data { @@ -38,6 +38,20 @@ struct test_data {
const char *alternative; /* output: ... or this. */
};

/*
* Compatibility wrappers for OpenBSD, whose basename(3) and dirname(3)
* have const parameters.
*/
static char *posix_basename(char *path)
{
return basename(path);
}

static char *posix_dirname(char *path)
{
return dirname(path);
}

static int test_function(struct test_data *data, char *(*func)(char *input),
const char *funcname)
{
@ -251,10 +265,10 @@ int cmd_main(int argc, const char **argv) @@ -251,10 +265,10 @@ int cmd_main(int argc, const char **argv)
}

if (argc == 2 && !strcmp(argv[1], "basename"))
return test_function(basename_data, basename, argv[1]);
return test_function(basename_data, posix_basename, argv[1]);

if (argc == 2 && !strcmp(argv[1], "dirname"))
return test_function(dirname_data, dirname, argv[1]);
return test_function(dirname_data, posix_dirname, argv[1]);

fprintf(stderr, "%s: unknown function name: %s\n", argv[0],
argv[1] ? argv[1] : "(there was none)");

Loading…
Cancel
Save