author | Matt Mackall <mpm@selenic.com> |
Mon, 02 Nov 2015 17:17:33 -0600 | |
changeset 26963 | de5ae97ce9f4 |
parent 19008 | 9d33d6e0d442 |
child 28439 | b6e71f8af5b8 |
permissions | -rw-r--r-- |
15168 | 1 |
# Copyright 2010-2011 Fog Creek Software |
2 |
# |
|
3 |
# This software may be used and distributed according to the terms of the |
|
4 |
# GNU General Public License version 2 or any later version. |
|
5 |
||
15252
6e809bb4f969
largefiles: improve comments, internal docstrings
Greg Ward <greg@gerg.ca>
parents:
15168
diff
changeset
|
6 |
'''largefile store working over Mercurial's wire protocol''' |
15168 | 7 |
|
8 |
import lfutil |
|
9 |
import remotestore |
|
10 |
||
11 |
class wirestore(remotestore.remotestore): |
|
12 |
def __init__(self, ui, repo, remote): |
|
13 |
cap = remote.capable('largefiles') |
|
14 |
if not cap: |
|
15 |
raise lfutil.storeprotonotcapable([]) |
|
16 |
storetypes = cap.split(',') |
|
16686
67964cda8701
cleanup: "not x in y" -> "x not in y"
Brodie Rao <brodie@sf.io>
parents:
15252
diff
changeset
|
17 |
if 'serve' not in storetypes: |
15168 | 18 |
raise lfutil.storeprotonotcapable(storetypes) |
19 |
self.remote = remote |
|
20 |
super(wirestore, self).__init__(ui, repo, remote.url()) |
|
21 |
||
22 |
def _put(self, hash, fd): |
|
23 |
return self.remote.putlfile(hash, fd) |
|
24 |
||
25 |
def _get(self, hash): |
|
26 |
return self.remote.getlfile(hash) |
|
27 |
||
17127
9e1616307c4c
largefiles: batch statlfile requests when pushing a largefiles repo (issue3386)
Na'Tosha Bard <natosha@unity3d.com>
parents:
16686
diff
changeset
|
28 |
def _stat(self, hashes): |
19008
9d33d6e0d442
largefiles: stat all largefiles in one batch before downloading
Mads Kiilerich <madski@unity3d.com>
parents:
18481
diff
changeset
|
29 |
'''For each hash, return 0 if it is available, other values if not. |
9d33d6e0d442
largefiles: stat all largefiles in one batch before downloading
Mads Kiilerich <madski@unity3d.com>
parents:
18481
diff
changeset
|
30 |
It is usually 2 if the largefile is missing, but might be 1 the server |
9d33d6e0d442
largefiles: stat all largefiles in one batch before downloading
Mads Kiilerich <madski@unity3d.com>
parents:
18481
diff
changeset
|
31 |
has a corrupted copy.''' |
17127
9e1616307c4c
largefiles: batch statlfile requests when pushing a largefiles repo (issue3386)
Na'Tosha Bard <natosha@unity3d.com>
parents:
16686
diff
changeset
|
32 |
batch = self.remote.batch() |
9e1616307c4c
largefiles: batch statlfile requests when pushing a largefiles repo (issue3386)
Na'Tosha Bard <natosha@unity3d.com>
parents:
16686
diff
changeset
|
33 |
futures = {} |
9e1616307c4c
largefiles: batch statlfile requests when pushing a largefiles repo (issue3386)
Na'Tosha Bard <natosha@unity3d.com>
parents:
16686
diff
changeset
|
34 |
for hash in hashes: |
9e1616307c4c
largefiles: batch statlfile requests when pushing a largefiles repo (issue3386)
Na'Tosha Bard <natosha@unity3d.com>
parents:
16686
diff
changeset
|
35 |
futures[hash] = batch.statlfile(hash) |
9e1616307c4c
largefiles: batch statlfile requests when pushing a largefiles repo (issue3386)
Na'Tosha Bard <natosha@unity3d.com>
parents:
16686
diff
changeset
|
36 |
batch.submit() |
9e1616307c4c
largefiles: batch statlfile requests when pushing a largefiles repo (issue3386)
Na'Tosha Bard <natosha@unity3d.com>
parents:
16686
diff
changeset
|
37 |
retval = {} |
9e1616307c4c
largefiles: batch statlfile requests when pushing a largefiles repo (issue3386)
Na'Tosha Bard <natosha@unity3d.com>
parents:
16686
diff
changeset
|
38 |
for hash in hashes: |
18481
ed647c59753b
largefiles: let wirestore._stat return stats as expected by remotestore verify
Mads Kiilerich <madski@unity3d.com>
parents:
17127
diff
changeset
|
39 |
retval[hash] = futures[hash].value |
17127
9e1616307c4c
largefiles: batch statlfile requests when pushing a largefiles repo (issue3386)
Na'Tosha Bard <natosha@unity3d.com>
parents:
16686
diff
changeset
|
40 |
return retval |