command: check for empty string after strtol()
An empty string is obviously not a valid integer.
This commit is contained in:
parent
1baaaa40cc
commit
52e9cab1c1
@ -122,7 +122,7 @@ check_uint32(struct client *client, uint32_t *dst,
|
|||||||
char *test;
|
char *test;
|
||||||
|
|
||||||
*dst = strtoul(s, &test, 10);
|
*dst = strtoul(s, &test, 10);
|
||||||
if (*test != '\0') {
|
if (test == s || *test != '\0') {
|
||||||
va_list args;
|
va_list args;
|
||||||
va_start(args, fmt);
|
va_start(args, fmt);
|
||||||
command_error_v(client, ACK_ERROR_ARG, fmt, args);
|
command_error_v(client, ACK_ERROR_ARG, fmt, args);
|
||||||
@ -140,7 +140,7 @@ check_int(struct client *client, int *value_r,
|
|||||||
long value;
|
long value;
|
||||||
|
|
||||||
value = strtol(s, &test, 10);
|
value = strtol(s, &test, 10);
|
||||||
if (*test != '\0') {
|
if (test == s || *test != '\0') {
|
||||||
va_list args;
|
va_list args;
|
||||||
va_start(args, fmt);
|
va_start(args, fmt);
|
||||||
command_error_v(client, ACK_ERROR_ARG, fmt, args);
|
command_error_v(client, ACK_ERROR_ARG, fmt, args);
|
||||||
@ -168,7 +168,7 @@ check_range(struct client *client, unsigned *value_r1, unsigned *value_r2,
|
|||||||
long value;
|
long value;
|
||||||
|
|
||||||
value = strtol(s, &test, 10);
|
value = strtol(s, &test, 10);
|
||||||
if (*test != '\0' && *test != ':') {
|
if (test == s || (*test != '\0' && *test != ':')) {
|
||||||
va_list args;
|
va_list args;
|
||||||
va_start(args, fmt);
|
va_start(args, fmt);
|
||||||
command_error_v(client, ACK_ERROR_ARG, fmt, args);
|
command_error_v(client, ACK_ERROR_ARG, fmt, args);
|
||||||
@ -202,7 +202,7 @@ check_range(struct client *client, unsigned *value_r1, unsigned *value_r2,
|
|||||||
|
|
||||||
if (*test == ':') {
|
if (*test == ':') {
|
||||||
value = strtol(++test, &test2, 10);
|
value = strtol(++test, &test2, 10);
|
||||||
if (*test2 != '\0') {
|
if (test2 == test || *test2 != '\0') {
|
||||||
va_list args;
|
va_list args;
|
||||||
va_start(args, fmt);
|
va_start(args, fmt);
|
||||||
command_error_v(client, ACK_ERROR_ARG, fmt, args);
|
command_error_v(client, ACK_ERROR_ARG, fmt, args);
|
||||||
@ -241,7 +241,7 @@ check_unsigned(struct client *client, unsigned *value_r, const char *s)
|
|||||||
char *endptr;
|
char *endptr;
|
||||||
|
|
||||||
value = strtoul(s, &endptr, 10);
|
value = strtoul(s, &endptr, 10);
|
||||||
if (*endptr != 0) {
|
if (endptr == s || *endptr != 0) {
|
||||||
command_error(client, ACK_ERROR_ARG,
|
command_error(client, ACK_ERROR_ARG,
|
||||||
"Integer expected: %s", s);
|
"Integer expected: %s", s);
|
||||||
return false;
|
return false;
|
||||||
@ -264,7 +264,7 @@ check_bool(struct client *client, bool *value_r, const char *s)
|
|||||||
char *endptr;
|
char *endptr;
|
||||||
|
|
||||||
value = strtol(s, &endptr, 10);
|
value = strtol(s, &endptr, 10);
|
||||||
if (*endptr != 0 || (value != 0 && value != 1)) {
|
if (endptr == s || *endptr != 0 || (value != 0 && value != 1)) {
|
||||||
command_error(client, ACK_ERROR_ARG,
|
command_error(client, ACK_ERROR_ARG,
|
||||||
"Boolean (0/1) expected: %s", s);
|
"Boolean (0/1) expected: %s", s);
|
||||||
return false;
|
return false;
|
||||||
@ -281,7 +281,7 @@ check_float(struct client *client, float *value_r, const char *s)
|
|||||||
char *endptr;
|
char *endptr;
|
||||||
|
|
||||||
value = strtof(s, &endptr);
|
value = strtof(s, &endptr);
|
||||||
if (*endptr != 0 && endptr == s) {
|
if (endptr == s || *endptr != 0) {
|
||||||
command_error(client, ACK_ERROR_ARG,
|
command_error(client, ACK_ERROR_ARG,
|
||||||
"Float expected: %s", s);
|
"Float expected: %s", s);
|
||||||
return false;
|
return false;
|
||||||
|
Loading…
Reference in New Issue
Block a user