mirror of
https://github.com/alsa-project/alsa-utils
synced 2025-01-05 16:36:44 +01:00
aplay/arecord: handle parsing errors of parameter values
when a user enters a command, he expects his command to be executed as specified or aborted if it is impossible to fulfill his request right now a command like "arecord -d hw:1,0 --max-file-time 1h recording.wav" will happily record something and exit without error status while the resulting recording contains definitely not what the user requested to fix this, the patch handles the number parsing function's error channel and checks whether the parsed number has any trailing characters Signed-off-by: erwin <nebelbank@posteo.de> Signed-off-by: Takashi Iwai <tiwai@suse.de>
This commit is contained in:
parent
ccc108fb83
commit
b5c0660230
1 changed files with 76 additions and 12 deletions
|
@ -427,6 +427,22 @@ enum {
|
||||||
OPT_FATAL_ERRORS,
|
OPT_FATAL_ERRORS,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static long parse_long(const char *str, int *err)
|
||||||
|
{
|
||||||
|
long val;
|
||||||
|
char *endptr;
|
||||||
|
|
||||||
|
errno = 0;
|
||||||
|
val = strtol(str, &endptr, 0);
|
||||||
|
|
||||||
|
if (errno != 0 || *endptr != '\0')
|
||||||
|
*err = -1;
|
||||||
|
else
|
||||||
|
*err = 0;
|
||||||
|
|
||||||
|
return val;
|
||||||
|
}
|
||||||
|
|
||||||
int main(int argc, char *argv[])
|
int main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
int option_index;
|
int option_index;
|
||||||
|
@ -558,7 +574,11 @@ int main(int argc, char *argv[])
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 'c':
|
case 'c':
|
||||||
rhwparams.channels = strtol(optarg, NULL, 0);
|
rhwparams.channels = parse_long(optarg, &err);
|
||||||
|
if (err < 0) {
|
||||||
|
error(_("invalid channels argument '%s'"), optarg);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
if (rhwparams.channels < 1 || rhwparams.channels > 256) {
|
if (rhwparams.channels < 1 || rhwparams.channels > 256) {
|
||||||
error(_("value %i for channels is invalid"), rhwparams.channels);
|
error(_("value %i for channels is invalid"), rhwparams.channels);
|
||||||
return 1;
|
return 1;
|
||||||
|
@ -585,7 +605,11 @@ int main(int argc, char *argv[])
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 'r':
|
case 'r':
|
||||||
tmp = strtol(optarg, NULL, 0);
|
tmp = parse_long(optarg, &err);
|
||||||
|
if (err < 0) {
|
||||||
|
error(_("invalid rate argument '%s'"), optarg);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
if (tmp < 300)
|
if (tmp < 300)
|
||||||
tmp *= 1000;
|
tmp *= 1000;
|
||||||
rhwparams.rate = tmp;
|
rhwparams.rate = tmp;
|
||||||
|
@ -595,32 +619,64 @@ int main(int argc, char *argv[])
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 'd':
|
case 'd':
|
||||||
timelimit = strtol(optarg, NULL, 0);
|
timelimit = parse_long(optarg, &err);
|
||||||
|
if (err < 0) {
|
||||||
|
error(_("invalid duration argument '%s'"), optarg);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case 'N':
|
case 'N':
|
||||||
nonblock = 1;
|
nonblock = 1;
|
||||||
open_mode |= SND_PCM_NONBLOCK;
|
open_mode |= SND_PCM_NONBLOCK;
|
||||||
break;
|
break;
|
||||||
case 'F':
|
case 'F':
|
||||||
period_time = strtol(optarg, NULL, 0);
|
period_time = parse_long(optarg, &err);
|
||||||
|
if (err < 0) {
|
||||||
|
error(_("invalid period time argument '%s'"), optarg);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case 'B':
|
case 'B':
|
||||||
buffer_time = strtol(optarg, NULL, 0);
|
buffer_time = parse_long(optarg, &err);
|
||||||
|
if (err < 0) {
|
||||||
|
error(_("invalid buffer time argument '%s'"), optarg);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case OPT_PERIOD_SIZE:
|
case OPT_PERIOD_SIZE:
|
||||||
period_frames = strtol(optarg, NULL, 0);
|
period_frames = parse_long(optarg, &err);
|
||||||
|
if (err < 0) {
|
||||||
|
error(_("invalid period size argument '%s'"), optarg);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case OPT_BUFFER_SIZE:
|
case OPT_BUFFER_SIZE:
|
||||||
buffer_frames = strtol(optarg, NULL, 0);
|
buffer_frames = parse_long(optarg, &err);
|
||||||
|
if (err < 0) {
|
||||||
|
error(_("invalid buffer size argument '%s'"), optarg);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case 'A':
|
case 'A':
|
||||||
avail_min = strtol(optarg, NULL, 0);
|
avail_min = parse_long(optarg, &err);
|
||||||
|
if (err < 0) {
|
||||||
|
error(_("invalid min available space argument '%s'"), optarg);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case 'R':
|
case 'R':
|
||||||
start_delay = strtol(optarg, NULL, 0);
|
start_delay = parse_long(optarg, &err);
|
||||||
|
if (err < 0) {
|
||||||
|
error(_("invalid start delay argument '%s'"), optarg);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case 'T':
|
case 'T':
|
||||||
stop_delay = strtol(optarg, NULL, 0);
|
stop_delay = parse_long(optarg, &err);
|
||||||
|
if (err < 0) {
|
||||||
|
error(_("invalid stop delay argument '%s'"), optarg);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case 'v':
|
case 'v':
|
||||||
verbose++;
|
verbose++;
|
||||||
|
@ -671,7 +727,11 @@ int main(int argc, char *argv[])
|
||||||
test_position = 1;
|
test_position = 1;
|
||||||
break;
|
break;
|
||||||
case OPT_TEST_COEF:
|
case OPT_TEST_COEF:
|
||||||
test_coef = strtol(optarg, NULL, 0);
|
test_coef = parse_long(optarg, &err);
|
||||||
|
if (err < 0) {
|
||||||
|
error(_("invalid test coef argument '%s'"), optarg);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
if (test_coef < 1)
|
if (test_coef < 1)
|
||||||
test_coef = 1;
|
test_coef = 1;
|
||||||
break;
|
break;
|
||||||
|
@ -679,7 +739,11 @@ int main(int argc, char *argv[])
|
||||||
test_nowait = 1;
|
test_nowait = 1;
|
||||||
break;
|
break;
|
||||||
case OPT_MAX_FILE_TIME:
|
case OPT_MAX_FILE_TIME:
|
||||||
max_file_time = strtol(optarg, NULL, 0);
|
max_file_time = parse_long(optarg, &err);
|
||||||
|
if (err < 0) {
|
||||||
|
error(_("invalid max file time argument '%s'"), optarg);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case OPT_PROCESS_ID_FILE:
|
case OPT_PROCESS_ID_FILE:
|
||||||
pidfile_name = optarg;
|
pidfile_name = optarg;
|
||||||
|
|
Loading…
Reference in a new issue