about summary refs log tree commit diff
path: root/Src/exec.c
diff options
context:
space:
mode:
authorBart Schaefer <barts@users.sourceforge.net>2001-06-23 18:30:55 +0000
committerBart Schaefer <barts@users.sourceforge.net>2001-06-23 18:30:55 +0000
commitf11e227cb010cab274715e7db816d7406dc62c19 (patch)
tree2332193d34ed30c833c820bad321b77c81a31fcd /Src/exec.c
parent791e11a084882f69e1e7373c80024d3f78b10baa (diff)
downloadzsh-f11e227cb010cab274715e7db816d7406dc62c19.tar.gz
zsh-f11e227cb010cab274715e7db816d7406dc62c19.tar.xz
zsh-f11e227cb010cab274715e7db816d7406dc62c19.zip
POSIX exit status changes.
Diffstat (limited to 'Src/exec.c')
-rw-r--r--Src/exec.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/Src/exec.c b/Src/exec.c
index 426d151b5..16ff92392 100644
--- a/Src/exec.c
+++ b/Src/exec.c
@@ -502,7 +502,7 @@ execute(Cmdnam not_used_yet, int dash)
 		(arg0[0] == '.' && (arg0 + 1 == s ||
 				    (arg0[1] == '.' && arg0 + 2 == s)))) {
 		zerr("%e: %s", arg0, errno);
-		_exit(1);
+		_exit((errno == EACCES || errno == ENOEXEC) ? 126 : 127);
 	    }
 	    break;
 	}
@@ -556,7 +556,7 @@ execute(Cmdnam not_used_yet, int dash)
 	zerr("%e: %s", arg0, eno);
     else
 	zerr("command not found: %s", arg0, 0);
-    _exit(1);
+    _exit((eno == EACCES || eno == ENOEXEC) ? 126 : 127);
 }
 
 #define RET_IF_COM(X) { if (iscom(X)) return docopy ? dupstring(X) : arg0; }