diff options
author | Nicholas Marriott <nicm@openbsd.org> | 2011-01-23 11:03:43 +0000 |
---|---|---|
committer | Nicholas Marriott <nicm@openbsd.org> | 2011-01-23 11:03:43 +0000 |
commit | b8023044c35f3099e67793e3573e9e001a43b1fe (patch) | |
tree | 2b08003a9370566d0fd6b32be7a1f02b96caf1a2 /job.c | |
parent | 1377427e708f23275c40a7b86d999bf6f8dd4a94 (diff) | |
download | rtmux-b8023044c35f3099e67793e3573e9e001a43b1fe.tar.gz rtmux-b8023044c35f3099e67793e3573e9e001a43b1fe.tar.bz2 rtmux-b8023044c35f3099e67793e3573e9e001a43b1fe.zip |
Set $TMUX without the session when background jobs are run.
Diffstat (limited to 'job.c')
-rw-r--r-- | job.c | 12 |
1 files changed, 10 insertions, 2 deletions
@@ -137,7 +137,8 @@ job_free(struct job *job) int job_run(struct job *job) { - int nullfd, out[2]; + struct environ env; + int nullfd, out[2]; if (job->fd != -1 || job->pid != -1) return (0); @@ -145,13 +146,19 @@ job_run(struct job *job) if (socketpair(AF_UNIX, SOCK_STREAM, PF_UNSPEC, out) != 0) return (-1); + environ_init(&env); + environ_copy(&global_environ, &env); + server_fill_environ(NULL, &env); + switch (job->pid = fork()) { case -1: + environ_free(&env); return (-1); case 0: /* child */ clear_signals(1); - environ_push(&global_environ); + environ_push(&env); + environ_free(&env); if (dup2(out[1], STDOUT_FILENO) == -1) fatal("dup2 failed"); @@ -174,6 +181,7 @@ job_run(struct job *job) execl(_PATH_BSHELL, "sh", "-c", job->cmd, (char *) NULL); fatal("execl failed"); default: /* parent */ + environ_free(&env); close(out[1]); job->fd = out[0]; |