##// END OF EJS Templates
dirstate-item: point out that `merged` is set only with p1_tracked...
dirstate-item: point out that `merged` is set only with p1_tracked This is currently True, and we will use this fact to simplify the API in the next commit. However, we add this assertion first to validate that this is True in the whole test-suite.

File last commit:

r46554:89a2afe3 default
r48925:e2da3ec9 default
Show More
wirestore.py
52 lines | 1.6 KiB | text/x-python | PythonLexer
various
hgext: add largefiles extension...
r15168 # Copyright 2010-2011 Fog Creek Software
#
# This software may be used and distributed according to the terms of the
# GNU General Public License version 2 or any later version.
Greg Ward
largefiles: improve comments, internal docstrings...
r15252 '''largefile store working over Mercurial's wire protocol'''
liscju
py3: make largefiles/wirestore.py use absolute_import
r29316 from __future__ import absolute_import
various
hgext: add largefiles extension...
r15168
liscju
py3: make largefiles/wirestore.py use absolute_import
r29316 from . import (
lfutil,
remotestore,
)
various
hgext: add largefiles extension...
r15168
Augie Fackler
formatting: blacken the codebase...
r43346
various
hgext: add largefiles extension...
r15168 class wirestore(remotestore.remotestore):
def __init__(self, ui, repo, remote):
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 cap = remote.capable(b'largefiles')
various
hgext: add largefiles extension...
r15168 if not cap:
raise lfutil.storeprotonotcapable([])
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 storetypes = cap.split(b',')
if b'serve' not in storetypes:
various
hgext: add largefiles extension...
r15168 raise lfutil.storeprotonotcapable(storetypes)
self.remote = remote
super(wirestore, self).__init__(ui, repo, remote.url())
def _put(self, hash, fd):
return self.remote.putlfile(hash, fd)
def _get(self, hash):
return self.remote.getlfile(hash)
Na'Tosha Bard
largefiles: batch statlfile requests when pushing a largefiles repo (issue3386)...
r17127 def _stat(self, hashes):
Augie Fackler
formating: upgrade to black 20.8b1...
r46554 """For each hash, return 0 if it is available, other values if not.
Mads Kiilerich
largefiles: stat all largefiles in one batch before downloading...
r19008 It is usually 2 if the largefile is missing, but might be 1 the server
Augie Fackler
formating: upgrade to black 20.8b1...
r46554 has a corrupted copy."""
Gregory Szorc
largefiles: use command executor for batch operation...
r37650
with self.remote.commandexecutor() as e:
fs = []
for hash in hashes:
Augie Fackler
formating: upgrade to black 20.8b1...
r46554 fs.append(
(
hash,
e.callcommand(
b'statlfile',
{
b'sha': hash,
},
),
)
)
Gregory Szorc
largefiles: use command executor for batch operation...
r37650
return {hash: f.result() for hash, f in fs}