Mercurial > hg > mercurial-crew-with-dirclash
annotate mercurial/lock.py @ 222:87484f627422
make pull work for multiple heads
-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA1
make pull work for multiple heads
add repository.heads()
teach remoterepository and hgweb about heads command
teach getchangegroup about multiple heads
break apart addchangegroup and merge (cleaning up merge saved for later)
after this change, it is now possible to pull and get multiple heads, but
not possible to merge the heads
manifest hash: 86fe3ede296254698fdd4c97df02944993ef2cbb
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.4.0 (GNU/Linux)
iD8DBQFCn8SZywK+sNU5EO8RAkSvAJ9NOA4UZ3cFyyzymlYBZnV+PpGRcACeLL+R
PFaSgJHGKvxsXpvPYiZA0O0=
=L2Xr
-----END PGP SIGNATURE-----
author | mpm@selenic.com |
---|---|
date | Thu, 02 Jun 2005 18:46:49 -0800 |
parents | 0b4c5cb953d9 |
children | 10c43444a38e 688d03d6997a |
rev | line source |
---|---|
161 | 1 # lock.py - simple locking scheme for mercurial |
2 # | |
3 # Copyright 2005 Matt Mackall <mpm@selenic.com> | |
4 # | |
5 # This software may be used and distributed according to the terms | |
6 # of the GNU General Public License, incorporated herein by reference. | |
7 | |
8 import os, time | |
9 | |
10 class LockHeld(Exception): | |
11 pass | |
12 | |
13 class lock: | |
14 def __init__(self, file, wait = 1): | |
15 self.f = file | |
16 self.held = 0 | |
17 self.wait = wait | |
18 self.lock() | |
19 | |
20 def __del__(self): | |
21 self.release() | |
22 | |
23 def lock(self): | |
24 while 1: | |
25 try: | |
26 self.trylock() | |
27 return 1 | |
28 except LockHeld, inst: | |
29 if self.wait: | |
30 time.sleep(1) | |
31 continue | |
32 raise inst | |
33 | |
34 def trylock(self): | |
35 pid = os.getpid() | |
36 try: | |
37 os.symlink(str(pid), self.f) | |
38 self.held = 1 | |
39 except: | |
40 raise LockHeld(os.readlink(self.f)) | |
41 | |
42 def release(self): | |
43 if self.held: | |
44 self.held = 0 | |
45 os.unlink(self.f) | |
46 |