diff options
| author | Mike Vink <mike@pionative.com> | 2025-01-19 14:03:13 +0100 |
|---|---|---|
| committer | Mike Vink <mike@pionative.com> | 2025-01-19 14:03:13 +0100 |
| commit | 883055eb4182cdb8ebf784a2171771de7334f95e (patch) | |
| tree | f909a2c824a21050ce510b9603ba881a34167d66 /mut/tabbed/xembed.c | |
| parent | 6d83cc53aa950a8f8e6c8fbabdda8abddebea027 (diff) | |
| parent | a481aa1ad86e16dcf3083734696bae29b5fd8ebb (diff) | |
Merge commit 'a481aa1ad86e16dcf3083734696bae29b5fd8ebb' as 'mut/tabbed'
Diffstat (limited to 'mut/tabbed/xembed.c')
| -rw-r--r-- | mut/tabbed/xembed.c | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/mut/tabbed/xembed.c b/mut/tabbed/xembed.c new file mode 100644 index 0000000..cbb0e97 --- /dev/null +++ b/mut/tabbed/xembed.c @@ -0,0 +1,45 @@ +/* + * See LICENSE file for copyright and license details. + */ + +#include <fcntl.h> +#include <stdio.h> +#include <stdlib.h> +#include <unistd.h> + +int +main(int argc, char *argv[]) +{ + char *xembed; + int tty; + pid_t pgrp, tcpgrp; + + if (argc < 3) { + fprintf(stderr, "usage: %s flag cmd ...\n", argv[0]); + return 2; + } + + if (!(xembed = getenv("XEMBED"))) + goto noembed; + + if ((tty = open("/dev/tty", O_RDONLY)) < 0) + goto noembed; + + pgrp = getpgrp(); + tcpgrp = tcgetpgrp(tty); + + close(tty); + + if (pgrp == tcpgrp) { /* in foreground of tty */ + argv[0] = argv[2]; + argv[2] = xembed; + } else { +noembed: + argv += 2; + } + + execvp(argv[0], argv); + + perror(argv[0]); /* failed to execute */ + return 1; +} |
