last_patch41 from vodz to fix stty -F and similar
This commit is contained in:
parent
ff7661d9de
commit
fc059090b6
@ -572,14 +572,34 @@ extern int main(int argc, char **argv)
|
|||||||
|
|
||||||
speed_was_set = 0;
|
speed_was_set = 0;
|
||||||
require_set_attr = 0;
|
require_set_attr = 0;
|
||||||
k = optind;
|
k = 0;
|
||||||
while (k < argc) {
|
while (++k < argc) {
|
||||||
int match_found = 0;
|
int match_found = 0;
|
||||||
int reversed = 0;
|
int reversed = 0;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
if (argv[k][0] == '-') {
|
if (argv[k][0] == '-') {
|
||||||
|
char *find_dev_opt;
|
||||||
|
|
||||||
++argv[k];
|
++argv[k];
|
||||||
|
|
||||||
|
/* Handle "-a", "-ag", "-aF/dev/foo", "-aF /dev/foo", etc.
|
||||||
|
Find the options that have been parsed. This is really
|
||||||
|
gross, but it's needed because stty SETTINGS look like options to
|
||||||
|
getopt(), so we need to work around things in a really horrible
|
||||||
|
way. If any new options are ever added to stty, the short option
|
||||||
|
MUST NOT be a letter which is the first letter of one of the
|
||||||
|
possible stty settings.
|
||||||
|
*/
|
||||||
|
find_dev_opt = strchr(argv[k], 'F'); /* find -*F* */
|
||||||
|
if(find_dev_opt) {
|
||||||
|
if(find_dev_opt[1]==0) /* -*F /dev/foo */
|
||||||
|
k++; /* skip /dev/foo */
|
||||||
|
continue; /* else -*F/dev/foo - no skip */
|
||||||
|
}
|
||||||
|
if(argv[k][0]=='a' || argv[k][0]=='g')
|
||||||
|
continue;
|
||||||
|
/* Is not options - is reverse params */
|
||||||
reversed = 1;
|
reversed = 1;
|
||||||
}
|
}
|
||||||
for (i = 0; i < NUM_mode_info; ++i)
|
for (i = 0; i < NUM_mode_info; ++i)
|
||||||
@ -661,7 +681,6 @@ extern int main(int argc, char **argv)
|
|||||||
} else
|
} else
|
||||||
error_msg_and_die("invalid argument `%s'", argv[k]);
|
error_msg_and_die("invalid argument `%s'", argv[k]);
|
||||||
}
|
}
|
||||||
k++;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (require_set_attr) {
|
if (require_set_attr) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user