summaryrefslogtreecommitdiffstats
path: root/apps
diff options
context:
space:
mode:
authorAndy Polyakov <appro@openssl.org>2018-07-08 18:57:30 +0200
committerAndy Polyakov <appro@openssl.org>2018-07-09 19:11:24 +0200
commit750d5587d1d688df964cb37e86942da7e639d47b (patch)
tree92b8aafedaf5bfed18063b760a87faa69317a554 /apps
parent5d58e8f1710fbcf955bc949734aa8d594523276d (diff)
apps/req.c: fix -addext option.
Address even Coverity nit. Reviewed-by: Paul Dale <paul.dale@oracle.com> Reviewed-by: Rich Salz <rsalz@openssl.org> (Merged from https://github.com/openssl/openssl/pull/6671)
Diffstat (limited to 'apps')
-rw-r--r--apps/req.c25
1 files changed, 11 insertions, 14 deletions
diff --git a/apps/req.c b/apps/req.c
index 3d89f2000c..066e7c668f 100644
--- a/apps/req.c
+++ b/apps/req.c
@@ -24,7 +24,6 @@
#include <openssl/objects.h>
#include <openssl/pem.h>
#include <openssl/bn.h>
-#include <openssl/bn.h>
#include <openssl/lhash.h>
#ifndef OPENSSL_NO_RSA
# include <openssl/rsa.h>
@@ -177,21 +176,22 @@ static void exts_cleanup(OPENSSL_STRING *x)
static int duplicated(LHASH_OF(OPENSSL_STRING) *addexts, char *kv)
{
char *p;
+ size_t off;
/* Check syntax. */
- if (strchr(kv, '=') == NULL)
- return 1;
-
/* Skip leading whitespace, make a copy. */
while (*kv && isspace(*kv))
if (*++kv == '\0')
return 1;
+ if ((p = strchr(kv, '=')) == NULL)
+ return 1;
+ off = p - kv;
if ((kv = OPENSSL_strdup(kv)) == NULL)
return -1;
/* Skip trailing space before the equal sign. */
- for (p = strchr(kv, '='); p > kv; --p)
- if (p[-1] != ' ' && p[-1] != '\t')
+ for (p = kv + off; p > kv; --p)
+ if (!isspace(p[-1]))
break;
if (p == kv) {
OPENSSL_free(kv);
@@ -199,16 +199,13 @@ static int duplicated(LHASH_OF(OPENSSL_STRING) *addexts, char *kv)
}
*p = '\0';
- /* Finally have a clean "key"; see if it's there. */
- if (lh_OPENSSL_STRING_retrieve(addexts, (OPENSSL_STRING*)kv) != NULL) {
- BIO_printf(bio_err, "Extension \"%s\" repeated\n", kv);
- OPENSSL_free(kv);
- return 1;
+ /* Finally have a clean "key"; see if it's there [by attempt to add it]. */
+ if ((p = (char *)lh_OPENSSL_STRING_insert(addexts, (OPENSSL_STRING*)kv))
+ != NULL || lh_OPENSSL_STRING_error(addexts)) {
+ OPENSSL_free(p != NULL ? p : kv);
+ return -1;
}
- /* Not found; add it. */
- if (lh_OPENSSL_STRING_insert(addexts, (OPENSSL_STRING*)kv) == NULL)
- return -1;
return 0;
}