aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRuss Cox <rsc@swtch.com>2012-10-22 12:32:31 -0400
committerRuss Cox <rsc@swtch.com>2012-10-22 12:32:31 -0400
commit9ca6e21f3d0ea9b9bab8b4661d03d30ed61fd79d (patch)
treefc97ae51eea0c3daead2752b797fedab92053f44
parent9e4b56e7645e08311590355824863ecf9f334f0c (diff)
downloadplan9port-9ca6e21f3d0ea9b9bab8b4661d03d30ed61fd79d.tar.gz
plan9port-9ca6e21f3d0ea9b9bab8b4661d03d30ed61fd79d.tar.bz2
plan9port-9ca6e21f3d0ea9b9bab8b4661d03d30ed61fd79d.zip
acme: use threadspawnd to avoid changing "." of current process
R=rsc http://codereview.appspot.com/6736060
-rw-r--r--src/cmd/acme/exec.c37
1 files changed, 8 insertions, 29 deletions
diff --git a/src/cmd/acme/exec.c b/src/cmd/acme/exec.c
index 81a2fcd9..39d05eca 100644
--- a/src/cmd/acme/exec.c
+++ b/src/cmd/acme/exec.c
@@ -1352,7 +1352,6 @@ runproc(void *argvp)
int sfd[3];
int pipechar;
char buf[512];
- int olddir;
int ret;
/*static void *parg[2]; */
char *rcarg[4];
@@ -1507,24 +1506,11 @@ runproc(void *argvp)
av[ac] = nil;
c->av = av;
- /*
- * clumsy -- we're not running in a separate thread
- * so we have to save the current directory and put
- * it back when we're done. if this gets to be a regular
- * thing we could change threadexec to take a directory too.
- */
- olddir = -1;
- if(rdir != nil){
- olddir = open(".", OREAD);
+ dir = nil;
+ if(rdir != nil)
dir = runetobyte(rdir, ndir);
- chdir(dir); /* ignore error: probably app. window */
- free(dir);
- }
- ret = threadspawn(sfd, av[0], av);
- if(olddir >= 0){
- fchdir(olddir);
- close(olddir);
- }
+ ret = threadspawnd(sfd, av[0], av, dir);
+ free(dir);
if(ret >= 0){
if(cpid)
sendul(cpid, ret);
@@ -1572,13 +1558,9 @@ Hard:
c->text = news;
}
}
- olddir = -1;
- if(rdir != nil){
- olddir = open(".", OREAD);
+ dir = nil;
+ if(rdir != nil)
dir = runetobyte(rdir, ndir);
- chdir(dir); /* ignore error: probably app. window */
- free(dir);
- }
shell = acmeshell;
if(shell == nil)
shell = "rc";
@@ -1586,11 +1568,8 @@ Hard:
rcarg[1] = "-c";
rcarg[2] = t;
rcarg[3] = nil;
- ret = threadspawn(sfd, rcarg[0], rcarg);
- if(olddir >= 0){
- fchdir(olddir);
- close(olddir);
- }
+ ret = threadspawnd(sfd, rcarg[0], rcarg, dir);
+ free(dir);
if(ret >= 0){
if(cpid)
sendul(cpid, ret);