git-rev-list: add documentation for --parents, --no-merges
[git/gitweb.git] / lockfile.c
blob2346e0e9ef0dbd247daf9d77c373029b491068c4
1 /*
2 * Copyright (c) 2005, Junio C Hamano
3 */
4 #include <signal.h>
5 #include "cache.h"
7 static struct lock_file *lock_file_list;
9 static void remove_lock_file(void)
11 while (lock_file_list) {
12 if (lock_file_list->filename[0])
13 unlink(lock_file_list->filename);
14 lock_file_list = lock_file_list->next;
18 static void remove_lock_file_on_signal(int signo)
20 remove_lock_file();
21 signal(SIGINT, SIG_DFL);
22 raise(signo);
25 int hold_lock_file_for_update(struct lock_file *lk, const char *path)
27 int fd;
28 sprintf(lk->filename, "%s.lock", path);
29 fd = open(lk->filename, O_RDWR | O_CREAT | O_EXCL, 0666);
30 if (0 <= fd) {
31 if (!lk->next) {
32 lk->next = lock_file_list;
33 lock_file_list = lk;
34 signal(SIGINT, remove_lock_file_on_signal);
35 atexit(remove_lock_file);
37 if (adjust_shared_perm(lk->filename))
38 return error("cannot fix permission bits on %s",
39 lk->filename);
41 return fd;
44 int commit_lock_file(struct lock_file *lk)
46 char result_file[PATH_MAX];
47 int i;
48 strcpy(result_file, lk->filename);
49 i = strlen(result_file) - 5; /* .lock */
50 result_file[i] = 0;
51 i = rename(lk->filename, result_file);
52 lk->filename[0] = 0;
53 return i;
56 void rollback_lock_file(struct lock_file *lk)
58 if (lk->filename[0])
59 unlink(lk->filename);
60 lk->filename[0] = 0;