mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2024-12-26 15:36:14 +01:00
b1315988fc
https://gitlab.gnome.org/GNOME/glib/-/jobs/1875915 ``` ../fuzzing/fuzz_paths.c: In function ‘LLVMFuzzerTestOneInput’: ../fuzzing/fuzz_paths.c:7:16: error: variable ‘skipped_root’ set but not used [-Werror=unused-but-set-variable] 7 | const gchar *skipped_root; | ^~~~~~~~~~~~ cc1: all warnings being treated as errors ``` Signed-off-by: Philip Withnall <pwithnall@endlessos.org>
33 lines
1.1 KiB
C
33 lines
1.1 KiB
C
#include "fuzz.h"
|
|
|
|
int
|
|
LLVMFuzzerTestOneInput (const unsigned char *data, size_t size)
|
|
{
|
|
unsigned char *nul_terminated_data = NULL;
|
|
const gchar *skipped_root G_GNUC_UNUSED /* when compiling with G_DISABLE_ASSERT */;
|
|
gchar *basename = NULL, *dirname = NULL;
|
|
|
|
fuzz_set_logging_func ();
|
|
|
|
/* ignore @size (none of the functions support it); ensure @data is nul-terminated */
|
|
nul_terminated_data = (unsigned char *) g_strndup ((const gchar *) data, size);
|
|
|
|
g_path_is_absolute ((const gchar *) nul_terminated_data);
|
|
|
|
skipped_root = g_path_skip_root ((const gchar *) nul_terminated_data);
|
|
g_assert (skipped_root == NULL || skipped_root >= (const gchar *) nul_terminated_data);
|
|
g_assert (skipped_root == NULL || skipped_root <= (const gchar *) nul_terminated_data + size);
|
|
|
|
basename = g_path_get_basename ((const gchar *) nul_terminated_data);
|
|
g_assert (strcmp (basename, ".") == 0 || strlen (basename) <= size);
|
|
|
|
dirname = g_path_get_dirname ((const gchar *) nul_terminated_data);
|
|
g_assert (strcmp (dirname, ".") == 0 || strlen (dirname) <= size);
|
|
|
|
g_free (nul_terminated_data);
|
|
g_free (dirname);
|
|
g_free (basename);
|
|
|
|
return 0;
|
|
}
|