From 2a953aed3831f8705444e720783ad4781904a625 Mon Sep 17 00:00:00 2001 From: Matt Kraai Date: Fri, 24 Aug 2001 19:07:31 +0000 Subject: Fix a memory leak if parent directory creation failed. --- libbb/make_directory.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) (limited to 'libbb/make_directory.c') diff --git a/libbb/make_directory.c b/libbb/make_directory.c index 0a9d7b160..7b7fde911 100644 --- a/libbb/make_directory.c +++ b/libbb/make_directory.c @@ -49,16 +49,16 @@ int make_directory (char *path, long mode, int flags) struct stat st; if (stat (path, &st) < 0 && errno == ENOENT) { + int status; char *parent = dirname (path); mode_t mask = umask (0); umask (mask); - if (make_directory (parent, (0777 & ~mask) | 0300, - FILEUTILS_RECUR) < 0) - return -1; + status = make_directory (parent, (0777 & ~mask) | 0300, + FILEUTILS_RECUR); free (parent); - if (make_directory (path, mode, 0) < 0) + if (status < 0 || make_directory (path, mode, 0) < 0) return -1; } } -- cgit v1.2.3