diff options
author | Junio C Hamano <gitster@pobox.com> | 2009-01-31 17:43:56 -0800 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2009-01-31 17:43:56 -0800 |
commit | fa5bc8abb35e34f673c41cb5c66d0a2f21536861 (patch) | |
tree | e76e7f9d8d64db34f148f7ddfa6bca928c194d65 /http-push.c | |
parent | 2edefe38a813deb4dfbd62dcf47520aeb1af15fc (diff) | |
parent | 0ea8039644968e53d79a8dfbf739c87af4261d46 (diff) | |
download | git-fa5bc8abb35e34f673c41cb5c66d0a2f21536861.tar.gz |
Merge branch 'jk/signal-cleanup'
* jk/signal-cleanup:
t0005: use SIGTERM for sigchain test
pager: do wait_for_pager on signal death
refactor signal handling for cleanup functions
chain kill signals for cleanup functions
diff: refactor tempfile cleanup handling
Windows: Fix signal numbers
Diffstat (limited to 'http-push.c')
-rw-r--r-- | http-push.c | 8 |
1 files changed, 3 insertions, 5 deletions
diff --git a/http-push.c b/http-push.c index 59037df502..53c14141e0 100644 --- a/http-push.c +++ b/http-push.c @@ -10,6 +10,7 @@ #include "exec_cmd.h" #include "remote.h" #include "list-objects.h" +#include "sigchain.h" #include <expat.h> @@ -1384,7 +1385,7 @@ static void remove_locks(void) static void remove_locks_on_signal(int signo) { remove_locks(); - signal(signo, SIG_DFL); + sigchain_pop(signo); raise(signo); } @@ -2277,10 +2278,7 @@ int main(int argc, char **argv) goto cleanup; } - signal(SIGINT, remove_locks_on_signal); - signal(SIGHUP, remove_locks_on_signal); - signal(SIGQUIT, remove_locks_on_signal); - signal(SIGTERM, remove_locks_on_signal); + sigchain_push_common(remove_locks_on_signal); /* Check whether the remote has server info files */ remote->can_update_info_refs = 0; |