From 4aca87515a5083ae0e31ce3177189fd43b6d05ac Mon Sep 17 00:00:00 2001 From: Andreas Baumann Date: Sat, 3 Jan 2015 13:58:15 +0100 Subject: patch to Vanilla Tomato 1.28 --- release/src/router/busybox/libbb/xgetcwd.c | 65 +++++++++++++----------------- 1 file changed, 28 insertions(+), 37 deletions(-) (limited to 'release/src/router/busybox/libbb/xgetcwd.c') diff --git a/release/src/router/busybox/libbb/xgetcwd.c b/release/src/router/busybox/libbb/xgetcwd.c index 27466816..10febe32 100644 --- a/release/src/router/busybox/libbb/xgetcwd.c +++ b/release/src/router/busybox/libbb/xgetcwd.c @@ -1,52 +1,43 @@ +/* vi: set sw=4 ts=4: */ /* * xgetcwd.c -- return current directory with unlimited length * Copyright (C) 1992, 1996 Free Software Foundation, Inc. * Written by David MacKenzie . * - * Special function for busybox written by Vladimir Oleynik -*/ + * Special function for busybox written by Vladimir Oleynik + * + * Licensed under GPLv2, see file LICENSE in this tarball for details. + */ -#include -#include -#include -#include #include "libbb.h" -/* Amount to increase buffer size by in each try. */ -#define PATH_INCR 32 - /* Return the current directory, newly allocated, arbitrarily long. Return NULL and set errno on error. If argument is not NULL (previous usage allocate memory), call free() */ -char * -xgetcwd (char *cwd) +char* FAST_FUNC +xrealloc_getcwd_or_warn(char *cwd) { - char *ret; - unsigned path_max; - - errno = 0; - path_max = (unsigned) PATH_MAX; - path_max += 2; /* The getcwd docs say to do this. */ - - if(cwd==0) - cwd = xmalloc (path_max); - - errno = 0; - while ((ret = getcwd (cwd, path_max)) == NULL && errno == ERANGE) { - path_max += PATH_INCR; - cwd = xrealloc (cwd, path_max); - errno = 0; - } - - if (ret == NULL) { - int save_errno = errno; - free (cwd); - errno = save_errno; - perror_msg("getcwd()"); - return NULL; - } - - return cwd; +#define PATH_INCR 64 + + char *ret; + unsigned path_max; + + path_max = 128; /* 128 + 64 should be enough for 99% of cases */ + + while (1) { + path_max += PATH_INCR; + cwd = xrealloc(cwd, path_max); + ret = getcwd(cwd, path_max); + if (ret == NULL) { + if (errno == ERANGE) + continue; + free(cwd); + bb_perror_msg("getcwd"); + return NULL; + } + cwd = xrealloc(cwd, strlen(cwd) + 1); + return cwd; + } } -- cgit v1.2.3-54-g00ecf