summaryrefslogtreecommitdiffstats
path: root/apps/rsautl.c
diff options
context:
space:
mode:
authorLutz Jänicke <jaenicke@openssl.org>2008-04-17 15:36:13 +0200
committerLutz Jänicke <jaenicke@openssl.org>2008-04-17 15:36:13 +0200
commit6b6fe3d8e4a1ec0f79ad8323933ce29f50261eee (patch)
tree769081804a77256abdc776dce36f1a6cc7cfac7f /apps/rsautl.c
parentApply mingw patches as supplied by Roumen Petrov an Alon Bar-Lev (diff)
downloadopenssl-6b6fe3d8e4a1ec0f79ad8323933ce29f50261eee.tar.xz
openssl-6b6fe3d8e4a1ec0f79ad8323933ce29f50261eee.zip
Correctly handle case of bad arguments supplied to rsautl
PR: 1659
Diffstat (limited to 'apps/rsautl.c')
-rw-r--r--apps/rsautl.c36
1 files changed, 24 insertions, 12 deletions
diff --git a/apps/rsautl.c b/apps/rsautl.c
index 463890950e..f3c458ed27 100644
--- a/apps/rsautl.c
+++ b/apps/rsautl.c
@@ -119,24 +119,36 @@ int MAIN(int argc, char **argv)
while(argc >= 1)
{
if (!strcmp(*argv,"-in")) {
- if (--argc < 1) badarg = 1;
- infile= *(++argv);
+ if (--argc < 1)
+ badarg = 1;
+ else
+ infile= *(++argv);
} else if (!strcmp(*argv,"-out")) {
- if (--argc < 1) badarg = 1;
- outfile= *(++argv);
+ if (--argc < 1)
+ badarg = 1;
+ else
+ outfile= *(++argv);
} else if(!strcmp(*argv, "-inkey")) {
- if (--argc < 1) badarg = 1;
- keyfile = *(++argv);
+ if (--argc < 1)
+ badarg = 1;
+ else
+ keyfile = *(++argv);
} else if (!strcmp(*argv,"-passin")) {
- if (--argc < 1) badarg = 1;
- passargin= *(++argv);
+ if (--argc < 1)
+ badarg = 1;
+ else
+ passargin= *(++argv);
} else if (strcmp(*argv,"-keyform") == 0) {
- if (--argc < 1) badarg = 1;
- keyform=str2fmt(*(++argv));
+ if (--argc < 1)
+ badarg = 1;
+ else
+ keyform=str2fmt(*(++argv));
#ifndef OPENSSL_NO_ENGINE
} else if(!strcmp(*argv, "-engine")) {
- if (--argc < 1) badarg = 1;
- engine = *(++argv);
+ if (--argc < 1)
+ badarg = 1;
+ else
+ engine = *(++argv);
#endif
} else if(!strcmp(*argv, "-pubin")) {
key_type = KEY_PUBKEY;