From f84ffd0130da9eab0bdc3bf22af07837fe68aa04 Mon Sep 17 00:00:00 2001 From: Richard Levitte Date: Thu, 18 Apr 2002 16:20:21 +0000 Subject: [PATCH] Make sure the opened directory is closed on exit. Notified by Lorinczy Zsigmond --- ssl/ssl_cert.c | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/ssl/ssl_cert.c b/ssl/ssl_cert.c index 1a873d2cb7..79e89fe14a 100644 --- a/ssl/ssl_cert.c +++ b/ssl/ssl_cert.c @@ -773,6 +773,7 @@ int SSL_add_dir_cert_subjects_to_stack(STACK_OF(X509_NAME) *stack, ret = 1; err: + if (d) closedir(d); CRYPTO_w_unlock(CRYPTO_LOCK_READDIR); return ret; } @@ -798,7 +799,7 @@ int SSL_add_dir_cert_subjects_to_stack(STACK_OF(X509_NAME) *stack, SYSerr(SYS_F_OPENDIR, get_last_sys_error()); ERR_add_error_data(3, "opendir('", dir, "')"); SSLerr(SSL_F_SSL_ADD_DIR_CERT_SUBJECTS_TO_STACK, ERR_R_SYS_LIB); - goto err; + goto err_noclose; } do @@ -819,10 +820,12 @@ int SSL_add_dir_cert_subjects_to_stack(STACK_OF(X509_NAME) *stack, goto err; } while (FindNextFile(hFind, &FindFileData) != FALSE); - FindClose(hFind); ret = 1; err: + FindClose(hFind); +err_noclose: + if (d) closedir(d); CRYPTO_w_unlock(CRYPTO_LOCK_READDIR); return ret; } -- 2.25.1