summaryrefslogtreecommitdiffstats
path: root/apps
diff options
context:
space:
mode:
authorRichard Levitte <levitte@openssl.org>2017-02-23 01:45:04 +0100
committerRichard Levitte <levitte@openssl.org>2017-02-23 02:19:55 +0100
commit39aceac320a1561d50c7d71ac2560aec7ab8eddb (patch)
tree974a781946570f1474a0a7cc0491c87ce88f945f /apps
parent341de5f1997d21b60cee69be656f1ae709bccdac (diff)
On VMS, massage the fetch file names to remove the generation number
The generation number is ';nnn' at the end of the file name fetched with readdir(). Because rehash checks for specific extensions and doesn't expect an additional generation number, the easiest is to massage the received file name early by simply removing the generation number. Reviewed-by: Rich Salz <rsalz@openssl.org> (Merged from https://github.com/openssl/openssl/pull/2717)
Diffstat (limited to 'apps')
-rw-r--r--apps/rehash.c19
1 files changed, 19 insertions, 0 deletions
diff --git a/apps/rehash.c b/apps/rehash.c
index 77541120a8..e837d27614 100644
--- a/apps/rehash.c
+++ b/apps/rehash.c
@@ -281,6 +281,24 @@ static int ends_with_dirsep(const char *path)
return *path == '/';
}
+static int massage_filename(char *name)
+{
+# ifdef __VMS
+ char *p = strchr(name, ';');
+ char *q = p;
+
+ if (q != NULL) {
+ for (q++; *q != '\0'; q++) {
+ if (!isdigit(*q))
+ return 1;
+ }
+ }
+
+ *p = '\0';
+# endif
+ return 1;
+}
+
/*
* Process a directory; return number of errors found.
*/
@@ -316,6 +334,7 @@ static int do_dir(const char *dirname, enum Hash h)
}
while ((filename = OPENSSL_DIR_read(&d, dirname)) != NULL) {
if ((copy = strdup(filename)) == NULL
+ || !massage_filename(copy)
|| sk_OPENSSL_STRING_push(files, copy) == 0) {
BIO_puts(bio_err, "out of memory\n");
exit(1);