|
|
@ -14,8 +14,6 @@ |
|
|
|
|
|
|
|
|
|
|
|
#include "util.h" |
|
|
|
#include "util.h" |
|
|
|
|
|
|
|
|
|
|
|
static char *shell = NULL; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void |
|
|
|
void |
|
|
|
error(char *errstr, ...) { |
|
|
|
error(char *errstr, ...) { |
|
|
|
va_list ap; |
|
|
|
va_list ap; |
|
|
@ -85,21 +83,17 @@ swap(void **p1, void **p2) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
void |
|
|
|
void |
|
|
|
spawn(Display *dpy, const char *cmd) |
|
|
|
spawn(Display *dpy, char *argv[]) |
|
|
|
{ |
|
|
|
{ |
|
|
|
if(!shell && !(shell = getenv("SHELL"))) |
|
|
|
if(!argv || !argv[0]) |
|
|
|
shell = "/bin/sh"; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(!cmd) |
|
|
|
|
|
|
|
return; |
|
|
|
return; |
|
|
|
if(fork() == 0) { |
|
|
|
if(fork() == 0) { |
|
|
|
if(fork() == 0) { |
|
|
|
if(fork() == 0) { |
|
|
|
if(dpy) |
|
|
|
if(dpy) |
|
|
|
close(ConnectionNumber(dpy)); |
|
|
|
close(ConnectionNumber(dpy)); |
|
|
|
setsid(); |
|
|
|
setsid(); |
|
|
|
fprintf(stderr, "gridwm: execlp %s %s -c %s", shell, shell, cmd); |
|
|
|
execvp(argv[0], argv); |
|
|
|
execlp(shell, shell, "-c", cmd, NULL); |
|
|
|
fprintf(stderr, "gridwm: execvp %s", argv[0]); |
|
|
|
fprintf(stderr, "gridwm: execlp %s", cmd); |
|
|
|
|
|
|
|
perror(" failed"); |
|
|
|
perror(" failed"); |
|
|
|
} |
|
|
|
} |
|
|
|
exit (0); |
|
|
|
exit (0); |
|
|
@ -108,15 +102,12 @@ spawn(Display *dpy, const char *cmd) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
void |
|
|
|
void |
|
|
|
pipe_spawn(char *buf, unsigned int len, Display *dpy, const char *cmd) |
|
|
|
pipe_spawn(char *buf, unsigned int len, Display *dpy, char *argv[]) |
|
|
|
{ |
|
|
|
{ |
|
|
|
unsigned int l, n; |
|
|
|
unsigned int l, n; |
|
|
|
int pfd[2]; |
|
|
|
int pfd[2]; |
|
|
|
|
|
|
|
|
|
|
|
if(!shell && !(shell = getenv("SHELL"))) |
|
|
|
if(!argv || !argv[0]) |
|
|
|
shell = "/bin/sh"; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(!cmd) |
|
|
|
|
|
|
|
return; |
|
|
|
return; |
|
|
|
|
|
|
|
|
|
|
|
if(pipe(pfd) == -1) { |
|
|
|
if(pipe(pfd) == -1) { |
|
|
@ -131,8 +122,8 @@ pipe_spawn(char *buf, unsigned int len, Display *dpy, const char *cmd) |
|
|
|
dup2(pfd[1], STDOUT_FILENO); |
|
|
|
dup2(pfd[1], STDOUT_FILENO); |
|
|
|
close(pfd[0]); |
|
|
|
close(pfd[0]); |
|
|
|
close(pfd[1]); |
|
|
|
close(pfd[1]); |
|
|
|
execlp(shell, shell, "-c", cmd, NULL); |
|
|
|
execvp(argv[0], argv); |
|
|
|
fprintf(stderr, "gridwm: execlp %s", cmd); |
|
|
|
fprintf(stderr, "gridwm: execvp %s", argv[0]); |
|
|
|
perror(" failed"); |
|
|
|
perror(" failed"); |
|
|
|
} |
|
|
|
} |
|
|
|
else { |
|
|
|
else { |
|
|
|