summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/cli_new.c6
-rw-r--r--src/commit2.c1
2 files changed, 4 insertions, 3 deletions
diff --git a/src/cli_new.c b/src/cli_new.c
index 19aae1c..b0535d8 100644
--- a/src/cli_new.c
+++ b/src/cli_new.c
@@ -117,8 +117,6 @@ void bye(const char *msg, ...)
fprintf(out_stream, "%s failed\n",
(cli_operation_name) ? cli_operation_name : "Operation");
- if (is_silent_msg())
- exit(-1);
va_start(ap, msg);
if (is_echo())
printf("echo \"");
@@ -2447,8 +2445,9 @@ system_out(const char *cmd, const char **outbuf)
close( cp[0]);
int ret = system(cmd);
+
close( cp[1]);
- exit(ret);
+ exit(WEXITSTATUS(ret));
}
else {
//parent
@@ -2463,6 +2462,7 @@ system_out(const char *cmd, const char **outbuf)
int status;
wait(&status);
close(cp[0]);
+
return WEXITSTATUS(status);
}
}
diff --git a/src/commit2.c b/src/commit2.c
index e3cc3df..05b3d9d 100644
--- a/src/commit2.c
+++ b/src/commit2.c
@@ -368,6 +368,7 @@ main(int argc, char** argv)
setenv(ENV_COMMIT_STATUS,"FAILURE",1);
}
struct dirent *dirp = NULL;
+ restore_output();
while ((dirp = readdir(dp)) != NULL) {
if (strcmp(dirp->d_name, ".") != 0 &&
strcmp(dirp->d_name, "..") != 0) {