Page Menu
Home
FreeBSD
Search
Configure Global Search
Log In
Files
F102845345
D34617.id104044.diff
No One
Temporary
Actions
View File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Flag For Later
Award Token
Size
2 KB
Referenced Files
None
Subscribers
None
D34617.id104044.diff
View Options
diff --git a/usr.sbin/mixer/mixer.c b/usr.sbin/mixer/mixer.c
--- a/usr.sbin/mixer/mixer.c
+++ b/usr.sbin/mixer/mixer.c
@@ -30,9 +30,11 @@
#include <string.h>
#include <unistd.h>
-#define C_VOL 0
-#define C_MUT 1
-#define C_SRC 2
+enum {
+ C_VOL = 0,
+ C_MUT,
+ C_SRC,
+};
static void usage(void) __dead2;
static void initctls(struct mixer *);
@@ -64,7 +66,7 @@
mix_ctl_t *cp;
char *name = NULL, buf[NAME_MAX];
char *p, *q, *devstr, *ctlstr, *valstr = NULL;
- int dunit, i, n, pall = 1;
+ int dunit, i, n, pall = 1, shorthand;
int aflag = 0, dflag = 0, oflag = 0, sflag = 0;
int ch;
@@ -135,6 +137,19 @@
while (argc > 0) {
if ((p = strdup(*argv)) == NULL)
err(1, "strdup(%s)", *argv);
+
+ /* Check if we're using the shorthand syntax for volume setting. */
+ shorthand = 0;
+ for (q = p; *q != '\0'; q++) {
+ if (*q == '=') {
+ q++;
+ shorthand = ((*q >= '0' && *q <= '9') ||
+ *q == '+' || *q == '-' || *q == '.');
+ break;
+ } else if (*q == '.')
+ break;
+ }
+
/* Split the string into device, control and value. */
devstr = strsep(&p, ".=");
if ((m->dev = mixer_get_dev_byname(m, devstr)) == NULL) {
@@ -146,22 +161,23 @@
printdev(m, 1);
pall = 0;
goto next;
- } else {
- for (q = p; (*q >= '0' && *q <= '9') || *q == '.'; q++)
- ; /* nothing */
- /* Input: `dev=N` -> shorthand for `dev.volume=N`. */
- if (*q == '\0') {
- cp = mixer_get_ctl(m->dev, C_VOL);
- cp->mod(cp->parent_dev, p);
- goto next;
- }
+ } else if (shorthand) {
+ /*
+ * Input: `dev=N` -> shorthand for `dev.volume=N`.
+ *
+ * We don't care what the rest of the string contains as
+ * long as we're sure the very beginning is right,
+ * mod_volume() will take care of parsing it properly.
+ */
+ cp = mixer_get_ctl(m->dev, C_VOL);
+ cp->mod(cp->parent_dev, p);
+ goto next;
}
ctlstr = strsep(&p, "=");
if ((cp = mixer_get_ctl_byname(m->dev, ctlstr)) == NULL) {
warnx("%s.%s: no such control", devstr, ctlstr);
goto next;
}
-
/* Input: `dev.control`. */
if (p == NULL) {
(void)cp->print(cp->parent_dev, cp->name);
File Metadata
Details
Attached
Mime Type
text/plain
Expires
Mon, Nov 18, 10:21 PM (5 h, 44 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
14698655
Default Alt Text
D34617.id104044.diff (2 KB)
Attached To
Mode
D34617: mixer(8): fix shorthand syntax bug
Attached
Detach File
Event Timeline
Log In to Comment