mirror of
https://github.com/AFLplusplus/AFLplusplus.git
synced 2025-06-13 02:28:09 +00:00
portability fix: getcwd(NULL, 0) is a non-POSIX glibc extension. Refactor
detect_file_args() in a separate file in order to avoid multiple copies.
This commit is contained in:
76
afl-fuzz.c
76
afl-fuzz.c
@ -32,6 +32,7 @@
|
||||
#include "alloc-inl.h"
|
||||
#include "hash.h"
|
||||
#include "sharedmem.h"
|
||||
#include "afl-common.h"
|
||||
|
||||
#include <stdio.h>
|
||||
#include <unistd.h>
|
||||
@ -8068,58 +8069,6 @@ static void check_asan_opts(void) {
|
||||
}
|
||||
|
||||
|
||||
/* Detect @@ in args. */
|
||||
|
||||
EXP_ST void detect_file_args(char** argv) {
|
||||
|
||||
u32 i = 0;
|
||||
u8* cwd = getcwd(NULL, 0);
|
||||
|
||||
if (!cwd) PFATAL("getcwd() failed");
|
||||
|
||||
while (argv[i]) {
|
||||
|
||||
u8* aa_loc = strstr(argv[i], "@@");
|
||||
|
||||
if (aa_loc) {
|
||||
|
||||
u8 *aa_subst, *n_arg;
|
||||
|
||||
/* If we don't have a file name chosen yet, use a safe default. */
|
||||
|
||||
if (!out_file) {
|
||||
if (file_extension) {
|
||||
out_file = alloc_printf("%s/.cur_input.%s", out_dir, file_extension);
|
||||
} else {
|
||||
out_file = alloc_printf("%s/.cur_input", out_dir);
|
||||
}
|
||||
}
|
||||
|
||||
/* Be sure that we're always using fully-qualified paths. */
|
||||
|
||||
if (out_file[0] == '/') aa_subst = out_file;
|
||||
else aa_subst = alloc_printf("%s/%s", cwd, out_file);
|
||||
|
||||
/* Construct a replacement argv value. */
|
||||
|
||||
*aa_loc = 0;
|
||||
n_arg = alloc_printf("%s%s%s", argv[i], aa_subst, aa_loc + 2);
|
||||
argv[i] = n_arg;
|
||||
*aa_loc = '@';
|
||||
|
||||
if (out_file[0] != '/') ck_free(aa_subst);
|
||||
|
||||
}
|
||||
|
||||
i++;
|
||||
|
||||
}
|
||||
|
||||
free(cwd); /* not tracked */
|
||||
|
||||
}
|
||||
|
||||
|
||||
/* Set up signal handlers. More complicated that needs to be, because libc on
|
||||
Solaris doesn't resume interrupted reads(), sets SA_RESETHAND when you call
|
||||
siginterrupt(), and does other stupid things. */
|
||||
@ -8628,7 +8577,28 @@ int main(int argc, char** argv) {
|
||||
|
||||
if (!timeout_given) find_timeout();
|
||||
|
||||
detect_file_args(argv + optind + 1);
|
||||
/* If we don't have a file name chosen yet, use a safe default. */
|
||||
|
||||
if (!out_file) {
|
||||
u32 i = optind + 1;
|
||||
while (argv[i]) {
|
||||
|
||||
u8* aa_loc = strstr(argv[i], "@@");
|
||||
|
||||
if (aa_loc && !out_file) {
|
||||
if (file_extension) {
|
||||
out_file = alloc_printf("%s/.cur_input.%s", out_dir, file_extension);
|
||||
} else {
|
||||
out_file = alloc_printf("%s/.cur_input", out_dir);
|
||||
}
|
||||
detect_file_args(argv + optind + 1, out_file);
|
||||
break;
|
||||
}
|
||||
|
||||
i++;
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
if (!out_file) setup_stdio_file();
|
||||
|
||||
|
Reference in New Issue
Block a user