aboutsummaryrefslogtreecommitdiffstats
path: root/apps
diff options
context:
space:
mode:
authorRichard Levitte <levitte@openssl.org>2017-02-22 16:48:55 +0100
committerRichard Levitte <levitte@openssl.org>2017-02-22 18:36:32 +0100
commit5c80e2af3a7d8aa5129a1668c286c1464983e1ac (patch)
tree2cb08115d4b925a891e22e6e2fccef8d175a50ef /apps
parentd8eaaf15356e1559f0f669b430b0d22b3514f8f0 (diff)
downloadopenssl-5c80e2af3a7d8aa5129a1668c286c1464983e1ac.tar.gz
Make "openssl rehash" work on VMS 8.3 and up
A spelling error prevented it from building correctly. Furthermore, we need to be more careful when to add a / at the end of the dirname and when not. Reviewed-by: Rich Salz <rsalz@openssl.org> (Merged from https://github.com/openssl/openssl/pull/2706)
Diffstat (limited to 'apps')
-rw-r--r--apps/rehash.c18
1 files changed, 16 insertions, 2 deletions
diff --git a/apps/rehash.c b/apps/rehash.c
index 281e6cd428..77541120a8 100644
--- a/apps/rehash.c
+++ b/apps/rehash.c
@@ -16,7 +16,7 @@
#include "apps.h"
#if defined(OPENSSL_SYS_UNIX) || defined(__APPLE__) || \
- (defined(__VMS) && defined(__DECC) && __CTRL_VER >= 80300000)
+ (defined(__VMS) && defined(__DECC) && __CRTL_VER >= 80300000)
# include <unistd.h>
# include <stdio.h>
# include <limits.h>
@@ -267,6 +267,20 @@ static void str_free(char *s)
OPENSSL_free(s);
}
+static int ends_with_dirsep(const char *path)
+{
+ if (*path != '\0')
+ path += strlen(path) - 1;
+# ifdef __VMS
+ if (*path == ']' || *path == '>' || *path == ':')
+ return 1;
+# elif _WIN32
+ if (*path == '\\')
+ return 1;
+# endif
+ return *path == '/';
+}
+
/*
* Process a directory; return number of errors found.
*/
@@ -289,7 +303,7 @@ static int do_dir(const char *dirname, enum Hash h)
return 1;
}
buflen = strlen(dirname);
- pathsep = (buflen && dirname[buflen - 1] == '/') ? "" : "/";
+ pathsep = (buflen && !ends_with_dirsep(dirname)) ? "/": "";
buflen += NAME_MAX + 1 + 1;
buf = app_malloc(buflen, "filename buffer");