diff options
| author | Clemens Buchacher <drizzd@aon.at> | 2008-05-25 20:27:44 +0200 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2008-05-25 13:07:24 -0700 | 
| commit | 6a491a176593a9ab3bd7ff24ef12323371671112 (patch) | |
| tree | 2a2459a88455a142f38f5b20beac543741c7b668 /http-push.c | |
| parent | a1292939381507be9489451076d49a5b927e9cc4 (diff) | |
| download | git-6a491a176593a9ab3bd7ff24ef12323371671112.tar.gz | |
http-push: remove remote locks on exit signals
If locks are not cleaned up the repository is inaccessible for 10 minutes.
Signed-off-by: Clemens Buchacher <drizzd@aon.at>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'http-push.c')
| -rw-r--r-- | http-push.c | 22 | 
1 files changed, 22 insertions, 0 deletions
| diff --git a/http-push.c b/http-push.c index 42727c8a45..f173dcd64f 100644 --- a/http-push.c +++ b/http-push.c @@ -1349,6 +1349,24 @@ static int unlock_remote(struct remote_lock *lock)  	return rc;  } +static void remove_locks(void) +{ +	struct remote_lock *lock = remote->locks; + +	fprintf(stderr, "Removing remote locks...\n"); +	while (lock) { +		unlock_remote(lock); +		lock = lock->next; +	} +} + +static void remove_locks_on_signal(int signo) +{ +	remove_locks(); +	signal(signo, SIG_DFL); +	raise(signo); +} +  static void remote_ls(const char *path, int flags,  		      void (*userFunc)(struct remote_ls_ctx *ls),  		      void *userData); @@ -2256,6 +2274,10 @@ 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); +  	/* Check whether the remote has server info files */  	remote->can_update_info_refs = 0;  	remote->has_info_refs = remote_exists("info/refs"); | 
