From 35632b67457f15e27a6414ecbe7fdfaf800beaf7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Niels=20M=C3=B6ller?= <nisse@lysator.liu.se> Date: Sun, 10 Nov 2002 17:27:54 +0100 Subject: [PATCH] * tools/sexp-conv.c (sexp_get_token_string): Fixed end of file handling. (sexp_get_string): Fixed end of encoding/end of file handling. (parse_options): Check for negative width and complain. Rev: src/nettle/tools/sexp-conv.c:1.3 --- tools/sexp-conv.c | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/tools/sexp-conv.c b/tools/sexp-conv.c index 060c7ab9..0cb0269c 100644 --- a/tools/sexp-conv.c +++ b/tools/sexp-conv.c @@ -302,7 +302,7 @@ sexp_get_token_string(struct sexp_input *input) sexp_push_char(input); sexp_get_char(input); } - while (TOKEN_CHAR(input->c)); + while (input->ctype == SEXP_NORMAL_CHAR && TOKEN_CHAR(input->c)); assert (input->string.size); } @@ -459,7 +459,7 @@ sexp_get_token(struct sexp_input *input, enum sexp_mode mode) case SEXP_END_CHAR: input->token = SEXP_CODING_END; sexp_input_end_coding(input); - sexp_next_char(input); + sexp_get_char(input); return; case SEXP_NORMAL_CHAR: @@ -1022,10 +1022,11 @@ parse_options(struct conv_options *o, case 'w': { char *end; - o->width = strtol(optarg, &end , 0); - if (!*optarg || *end || o->width < 0) - die("sexp-conv: Invalid width `%s'.\n", - optarg); + int width = strtol(optarg, &end , 0); + if (!*optarg || *end || width < 0) + die("sexp-conv: Invalid width `%s'.\n", optarg); + + o->width = width; break; } case 's': -- GitLab