about summary refs log tree commit diff
path: root/Src/options.c
diff options
context:
space:
mode:
authorPeter Stephenson <pws@users.sourceforge.net>2006-08-22 09:23:30 +0000
committerPeter Stephenson <pws@users.sourceforge.net>2006-08-22 09:23:30 +0000
commit17001a765dd1056a769d9d8fe6820ada132125f2 (patch)
treeb93891022c28372fb45b42a3b72108dc0070b0ba /Src/options.c
parentf20b66dd24e490fbfedac7787760b4732daa8119 (diff)
downloadzsh-17001a765dd1056a769d9d8fe6820ada132125f2.tar.gz
zsh-17001a765dd1056a769d9d8fe6820ada132125f2.tar.xz
zsh-17001a765dd1056a769d9d8fe6820ada132125f2.zip
22656: improve handling of monitor option
Diffstat (limited to 'Src/options.c')
-rw-r--r--Src/options.c11
1 files changed, 10 insertions, 1 deletions
diff --git a/Src/options.c b/Src/options.c
index 05e878687..d30553050 100644
--- a/Src/options.c
+++ b/Src/options.c
@@ -687,7 +687,16 @@ dosetopt(int optno, int value, int force)
 	setuid(getuid());
 	setgid(getgid());
 #endif /* HAVE_SETUID */
-#ifndef JOB_CONTROL
+#ifdef JOB_CONTROL
+    } else if (!force && optno == MONITOR && value) {
+	if (opts[optno] == value)
+	    return 0;
+	if (interact && (SHTTY != -1)) {
+	    origpgrp = GETPGRP();
+	    acquire_pgrp();
+	} else
+	    return -1;
+#else
     } else if(optno == MONITOR && value) {
 	    return -1;
 #endif /* not JOB_CONTROL */