aboutsummaryrefslogtreecommitdiff
path: root/libbb/xgetcwd.c
diff options
context:
space:
mode:
authorDenis Vlasenko <vda.linux@googlemail.com>2007-09-29 19:19:55 +0000
committerDenis Vlasenko <vda.linux@googlemail.com>2007-09-29 19:19:55 +0000
commit2450e4ba44707a64920ea6c9276930a1210e76cc (patch)
tree6025995a684c28aa22e9bb8c6dee0547584eb026 /libbb/xgetcwd.c
parent1ebd0a6d9162c377e4b214c0a506d3f78702d66e (diff)
downloadbusybox-2450e4ba44707a64920ea6c9276930a1210e76cc.tar.gz
xrealloc_getcwd_or_warn: smaller cod and less wasted RAM at run time
Diffstat (limited to 'libbb/xgetcwd.c')
-rw-r--r--libbb/xgetcwd.c31
1 files changed, 14 insertions, 17 deletions
diff --git a/libbb/xgetcwd.c b/libbb/xgetcwd.c
index ec1d8f7a4..c194e2303 100644
--- a/libbb/xgetcwd.c
+++ b/libbb/xgetcwd.c
@@ -9,9 +9,6 @@
#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()
@@ -20,25 +17,25 @@
char *
xrealloc_getcwd_or_warn(char *cwd)
{
+#define PATH_INCR 64
+
char *ret;
unsigned path_max;
- path_max = (unsigned) PATH_MAX;
- path_max += 2; /* The getcwd docs say to do this. */
-
- if (cwd == NULL)
- cwd = xmalloc(path_max);
+ path_max = 128; /* 128 + 64 should be enough for 99% of cases */
- while ((ret = getcwd(cwd, path_max)) == NULL && errno == ERANGE) {
+ 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;
}
-
- if (ret == NULL) {
- free(cwd);
- bb_perror_msg("getcwd");
- return NULL;
- }
-
- return cwd;
}