diff options
Diffstat (limited to 'usr.bin')
-rw-r--r-- | usr.bin/audioctl/audioctl.1 | 9 | ||||
-rw-r--r-- | usr.bin/audioctl/audioctl.c | 113 |
2 files changed, 60 insertions, 62 deletions
diff --git a/usr.bin/audioctl/audioctl.1 b/usr.bin/audioctl/audioctl.1 index b92ecab3fe0..e4628030758 100644 --- a/usr.bin/audioctl/audioctl.1 +++ b/usr.bin/audioctl/audioctl.1 @@ -1,4 +1,4 @@ -.\" $OpenBSD: audioctl.1,v 1.17 2004/05/09 03:37:45 beck Exp $ +.\" $OpenBSD: audioctl.1,v 1.18 2004/07/06 02:46:06 vincent Exp $ .\" $NetBSD: audioctl.1,v 1.7 1998/04/27 16:55:23 augustss Exp $ .\" Copyright (c) 1997 The NetBSD Foundation, Inc. .\" All rights reserved. @@ -52,7 +52,6 @@ .Nm audioctl .Op Fl f Ar file .Op Fl n -.Fl w .Ar name=value .Op Ar ... .Sh DESCRIPTION @@ -72,7 +71,7 @@ The options are as follows: .Bl -tag -width Ds .It Fl a Print all device variables and their current values. -.It Fl w Ar name=value +.It Ar name=value Attempt to set the specified variable .Ar name to @@ -95,7 +94,7 @@ default audio control device .Sh EXAMPLES To set the playing sampling rate to 11025 you can enter .Pp -.Dl $ audioctl -w play.sample_rate=11025 +.Dl $ audioctl play.sample_rate=11025 .Pp Note that many of the variables that can be inspected and changed are reset when the @@ -106,7 +105,7 @@ This can be circumvented like so: .Dl $ (cat file.au; audioctl -f /dev/audioctl -a) > /dev/audio or .Bd -literal -offset indent -compact -$ (audioctl -f /dev/audioctl -w blocksize=1024; cat file.au) \e +$ (audioctl -f /dev/audioctl blocksize=1024; cat file.au) \e > /dev/audio .Ed .Sh SEE ALSO diff --git a/usr.bin/audioctl/audioctl.c b/usr.bin/audioctl/audioctl.c index 57e55a66114..fe6b0246b3d 100644 --- a/usr.bin/audioctl/audioctl.c +++ b/usr.bin/audioctl/audioctl.c @@ -1,4 +1,4 @@ -/* $OpenBSD: audioctl.c,v 1.10 2003/06/21 01:39:07 deraadt Exp $ */ +/* $OpenBSD: audioctl.c,v 1.11 2004/07/06 02:46:06 vincent Exp $ */ /* $NetBSD: audioctl.c,v 1.14 1998/04/27 16:55:23 augustss Exp $ */ /* @@ -324,7 +324,7 @@ usage(void) fprintf(stderr, "usage: %s [-f file] [-n] -a\n" " %s [-f file] [-n] name [...]\n" - " %s [-f file] [-n] -w name=value [...]\n", __progname, + " %s [-f file] [-n] name=value [...]\n", __progname, __progname, __progname); exit(1); @@ -334,8 +334,9 @@ int main(int argc, char **argv) { int fd, i, ch; - int aflag = 0, wflag = 0; + int aflag = 0, canwrite, writeinfo = 0; struct stat dstat, ostat; + struct field *p; char *file; char *sep = "="; @@ -348,7 +349,7 @@ main(int argc, char **argv) aflag++; break; case 'w': - wflag++; + /* backward compatibility */ break; case 'n': sep = 0; @@ -356,16 +357,19 @@ main(int argc, char **argv) case 'f': file = optarg; break; - case '?': default: usage(); } } argc -= optind; argv += optind; - - if ((fd = open(file, wflag ? O_RDWR : O_RDONLY)) < 0) - err(1, "%s", file); + + if ((fd = open(file, O_RDWR)) < 0) { + if ((fd = open(file, O_RDONLY)) < 0) + err(1, "%s", file); + canwrite = 0; + } else + canwrite = 1; /* Check if stdout is the same device as the audio device. */ if (fstat(fd, &dstat) < 0) @@ -378,70 +382,65 @@ main(int argc, char **argv) /* We can't write to stdout so use stderr */ out = stderr; - if (!wflag) - getinfo(fd); + if (!argc && !aflag) + usage(); + + getinfo(fd); - if (!argc && aflag && !wflag) { - for(i = 0; fields[i].name; i++) { + if (aflag) { + for (i = 0; fields[i].name; i++) { if (!(fields[i].flags & ALIAS)) { prfield(&fields[i], sep); fprintf(out, "\n"); } } - } else if (argc > 0 && !aflag) { - struct field *p; - if (wflag) { - AUDIO_INITINFO(&info); - while(argc--) { - char *q; + } else { + while (argc--) { + char *q; - if ((q = strchr(*argv, '='))) { - *q++ = 0; - p = findfield(*argv); - if (p == 0) - warnx("field `%s' does not exist", *argv); + if ((q = strchr(*argv, '=')) != NULL) { + *q++ = 0; + p = findfield(*argv); + if (p == 0) + warnx("field `%s' does not exist", *argv); + else { + if (!canwrite) + errx(1, "%s: permission denied", + *argv); + if (p->flags & READONLY) + warnx("`%s' is read only", *argv); else { - if (p->flags & READONLY) - warnx("`%s' is read only", *argv); - else { - rdfield(p, q); - if (p->valp == &fullduplex) - if (ioctl(fd, AUDIO_SETFD, &fullduplex) < 0) - err(1, "set failed"); - } - } - } else - warnx("No `=' in %s", *argv); - argv++; - } - if (ioctl(fd, AUDIO_SETINFO, &info) < 0) - err(1, "set failed"); - if (sep) { - getinfo(fd); - for(i = 0; fields[i].name; i++) { - if (fields[i].flags & SET) { - fprintf(out, "%s: -> ", fields[i].name); - prfield(&fields[i], 0); - fprintf(out, "\n"); + rdfield(p, q); + if (p->valp == &fullduplex) + if (ioctl(fd, AUDIO_SETFD, + &fullduplex) < 0) + err(1, "set failed"); } + writeinfo = 1; } - } - } else { - while(argc--) { + } else { p = findfield(*argv); - if (p == 0) { - if (strchr(*argv, '=')) - warnx("field %s does not exist (use -w to set a variable)", *argv); - else - warnx("field %s does not exist", *argv); - } else { + if (p == 0) + warnx("field %s does not exist", *argv); + else { prfield(p, sep); fprintf(out, "\n"); } - argv++; } + argv++; } - } else - usage(); + if (writeinfo && ioctl(fd, AUDIO_SETINFO, &info) < 0) + err(1, "set failed"); + if (sep) { + getinfo(fd); + for (i = 0; fields[i].name; i++) { + if (fields[i].flags & SET) { + fprintf(out, "%s: -> ", fields[i].name); + prfield(&fields[i], 0); + fprintf(out, "\n"); + } + } + } + } exit(0); } |