Show More
@@ -105,4 +105,4 def extsetup(ui): | |||||
105 | ) |
|
105 | ) | |
106 | extensions.wrapfunction(webcommands, 'annotate', annotate_highlight) |
|
106 | extensions.wrapfunction(webcommands, 'annotate', annotate_highlight) | |
107 | webcommands.highlightcss = generate_css |
|
107 | webcommands.highlightcss = generate_css | |
108 |
webcommands.__all__.append( |
|
108 | webcommands.__all__.append('highlightcss') |
@@ -1716,7 +1716,7 def _chisteditmain(repo, rules, stdscr): | |||||
1716 | ch = encoding.strtolocal(stdscr.getkey()) |
|
1716 | ch = encoding.strtolocal(stdscr.getkey()) | |
1717 |
|
1717 | |||
1718 |
|
1718 | |||
1719 | def _chistedit(ui, repo, freeargs, opts): |
|
1719 | def _chistedit(ui, repo, state, freeargs, opts): | |
1720 | """interactively edit changeset history via a curses interface |
|
1720 | """interactively edit changeset history via a curses interface | |
1721 |
|
1721 | |||
1722 | Provides a ncurses interface to histedit. Press ? in chistedit mode |
|
1722 | Provides a ncurses interface to histedit. Press ? in chistedit mode | |
@@ -1776,7 +1776,7 def _chistedit(ui, repo, freeargs, opts) | |||||
1776 | for r in rules: |
|
1776 | for r in rules: | |
1777 | fp.write(r) |
|
1777 | fp.write(r) | |
1778 | opts[b'commands'] = fp.name |
|
1778 | opts[b'commands'] = fp.name | |
1779 | return _texthistedit(ui, repo, freeargs, opts) |
|
1779 | return _texthistedit(ui, repo, state, freeargs, opts) | |
1780 | except KeyboardInterrupt: |
|
1780 | except KeyboardInterrupt: | |
1781 | pass |
|
1781 | pass | |
1782 | return -1 |
|
1782 | return -1 | |
@@ -1915,19 +1915,19 def histedit(ui, repo, *freeargs, **opts | |||||
1915 | """ |
|
1915 | """ | |
1916 | opts = pycompat.byteskwargs(opts) |
|
1916 | opts = pycompat.byteskwargs(opts) | |
1917 |
|
1917 | |||
|
1918 | state = histeditstate(repo) | |||
|
1919 | with repo.wlock() as wlock, repo.lock() as lock: | |||
|
1920 | state.wlock = wlock | |||
|
1921 | state.lock = lock | |||
1918 | # kludge: _chistedit only works for starting an edit, not aborting |
|
1922 | # kludge: _chistedit only works for starting an edit, not aborting | |
1919 | # or continuing, so fall back to regular _texthistedit for those |
|
1923 | # or continuing, so fall back to regular _texthistedit for those | |
1920 | # operations. |
|
1924 | # operations. | |
1921 | if ui.interface(b'histedit') == b'curses' and _getgoal(opts) == goalnew: |
|
1925 | if ui.interface(b'histedit') == b'curses' and _getgoal(opts) == goalnew: | |
1922 | return _chistedit(ui, repo, freeargs, opts) |
|
1926 | return _chistedit(ui, repo, state, freeargs, opts) | |
1923 | return _texthistedit(ui, repo, freeargs, opts) |
|
1927 | return _texthistedit(ui, repo, state, freeargs, opts) | |
1924 |
|
1928 | |||
1925 |
|
1929 | |||
1926 | def _texthistedit(ui, repo, freeargs, opts): |
|
1930 | def _texthistedit(ui, repo, state, freeargs, opts): | |
1927 | state = histeditstate(repo) |
|
|||
1928 | with repo.wlock() as wlock, repo.lock() as lock: |
|
|||
1929 | state.wlock = wlock |
|
|||
1930 | state.lock = lock |
|
|||
1931 |
|
|
1931 | _histedit(ui, repo, state, freeargs, opts) | |
1932 |
|
1932 | |||
1933 |
|
1933 |
@@ -49,6 +49,8 from mercurial.upgrade_utils import ( | |||||
49 | actions as upgrade_actions, |
|
49 | actions as upgrade_actions, | |
50 | ) |
|
50 | ) | |
51 |
|
51 | |||
|
52 | from mercurial.utils import urlutil | |||
|
53 | ||||
52 | from . import ( |
|
54 | from . import ( | |
53 | lfcommands, |
|
55 | lfcommands, | |
54 | lfutil, |
|
56 | lfutil, | |
@@ -1139,7 +1141,10 def overrideclone(orig, ui, source, dest | |||||
1139 | d = dest |
|
1141 | d = dest | |
1140 | if d is None: |
|
1142 | if d is None: | |
1141 | d = hg.defaultdest(source) |
|
1143 | d = hg.defaultdest(source) | |
1142 |
if opts.get('all_largefiles') and |
|
1144 | if opts.get('all_largefiles') and urlutil.url(d).scheme not in ( | |
|
1145 | b'file', | |||
|
1146 | None, | |||
|
1147 | ): | |||
1143 | raise error.Abort( |
|
1148 | raise error.Abort( | |
1144 | _(b'--all-largefiles is incompatible with non-local destination %s') |
|
1149 | _(b'--all-largefiles is incompatible with non-local destination %s') | |
1145 | % d |
|
1150 | % d |
@@ -89,7 +89,7 import traceback | |||||
89 |
|
89 | |||
90 | from mercurial import pycompat |
|
90 | from mercurial import pycompat | |
91 |
|
91 | |||
92 |
__all__ = [ |
|
92 | __all__ = ["Zeroconf", "ServiceInfo", "ServiceBrowser"] | |
93 |
|
93 | |||
94 | # hook for threads |
|
94 | # hook for threads | |
95 |
|
95 |
@@ -21,11 +21,11 lib = _bdiff.lib | |||||
21 |
|
21 | |||
22 |
|
22 | |||
23 | def blocks(sa: bytes, sb: bytes) -> List[Tuple[int, int, int, int]]: |
|
23 | def blocks(sa: bytes, sb: bytes) -> List[Tuple[int, int, int, int]]: | |
24 |
a = ffi.new( |
|
24 | a = ffi.new("struct bdiff_line**") | |
25 |
b = ffi.new( |
|
25 | b = ffi.new("struct bdiff_line**") | |
26 |
ac = ffi.new( |
|
26 | ac = ffi.new("char[]", bytes(sa)) | |
27 |
bc = ffi.new( |
|
27 | bc = ffi.new("char[]", bytes(sb)) | |
28 |
l = ffi.new( |
|
28 | l = ffi.new("struct bdiff_hunk*") | |
29 | try: |
|
29 | try: | |
30 | an = lib.bdiff_splitlines(ac, len(sa), a) |
|
30 | an = lib.bdiff_splitlines(ac, len(sa), a) | |
31 | bn = lib.bdiff_splitlines(bc, len(sb), b) |
|
31 | bn = lib.bdiff_splitlines(bc, len(sb), b) | |
@@ -49,11 +49,11 def blocks(sa: bytes, sb: bytes) -> List | |||||
49 |
|
49 | |||
50 |
|
50 | |||
51 | def bdiff(sa: bytes, sb: bytes) -> bytes: |
|
51 | def bdiff(sa: bytes, sb: bytes) -> bytes: | |
52 |
a = ffi.new( |
|
52 | a = ffi.new("struct bdiff_line**") | |
53 |
b = ffi.new( |
|
53 | b = ffi.new("struct bdiff_line**") | |
54 |
ac = ffi.new( |
|
54 | ac = ffi.new("char[]", bytes(sa)) | |
55 |
bc = ffi.new( |
|
55 | bc = ffi.new("char[]", bytes(sb)) | |
56 |
l = ffi.new( |
|
56 | l = ffi.new("struct bdiff_hunk*") | |
57 | try: |
|
57 | try: | |
58 | an = lib.bdiff_splitlines(ac, len(sa), a) |
|
58 | an = lib.bdiff_splitlines(ac, len(sa), a) | |
59 | bn = lib.bdiff_splitlines(bc, len(sb), b) |
|
59 | bn = lib.bdiff_splitlines(bc, len(sb), b) | |
@@ -76,7 +76,7 def bdiff(sa: bytes, sb: bytes) -> bytes | |||||
76 | lgt, |
|
76 | lgt, | |
77 | ) |
|
77 | ) | |
78 | ) |
|
78 | ) | |
79 |
rl.append( |
|
79 | rl.append(bytes(ffi.buffer((b[0] + lb).l, lgt))) | |
80 | la = h.a2 |
|
80 | la = h.a2 | |
81 | lb = h.b2 |
|
81 | lb = h.b2 | |
82 | h = h.next |
|
82 | h = h.next |
@@ -19,8 +19,8 lib = _mpatch.lib | |||||
19 | @ffi.def_extern() |
|
19 | @ffi.def_extern() | |
20 | def cffi_get_next_item(arg, pos): |
|
20 | def cffi_get_next_item(arg, pos): | |
21 | all, bins = ffi.from_handle(arg) |
|
21 | all, bins = ffi.from_handle(arg) | |
22 |
container = ffi.new( |
|
22 | container = ffi.new("struct mpatch_flist*[1]") | |
23 |
to_pass = ffi.new( |
|
23 | to_pass = ffi.new("char[]", bytes(bins[pos])) | |
24 | all.append(to_pass) |
|
24 | all.append(to_pass) | |
25 | r = lib.mpatch_decode(to_pass, len(to_pass) - 1, container) |
|
25 | r = lib.mpatch_decode(to_pass, len(to_pass) - 1, container) | |
26 | if r < 0: |
|
26 | if r < 0: | |
@@ -41,7 +41,7 def patches(text: bytes, bins: List[byte | |||||
41 | if outlen < 0: |
|
41 | if outlen < 0: | |
42 | lib.mpatch_lfree(patch) |
|
42 | lib.mpatch_lfree(patch) | |
43 | raise mpatchError(b"inconsistency detected") |
|
43 | raise mpatchError(b"inconsistency detected") | |
44 |
buf = ffi.new( |
|
44 | buf = ffi.new("char[]", outlen) | |
45 | if lib.mpatch_apply(buf, text, len(text), patch) < 0: |
|
45 | if lib.mpatch_apply(buf, text, len(text), patch) < 0: | |
46 | lib.mpatch_lfree(patch) |
|
46 | lib.mpatch_lfree(patch) | |
47 | raise mpatchError(b"error applying patches") |
|
47 | raise mpatchError(b"error applying patches") |
@@ -39,8 +39,8 if pycompat.isdarwin: | |||||
39 | self.st_mtime = st_mtime |
|
39 | self.st_mtime = st_mtime | |
40 | self.st_size = st_size |
|
40 | self.st_size = st_size | |
41 |
|
41 | |||
42 |
tv_sec_ofs = ffi.offsetof( |
|
42 | tv_sec_ofs = ffi.offsetof("struct timespec", "tv_sec") | |
43 |
buf = ffi.new( |
|
43 | buf = ffi.new("char[]", listdir_batch_size) | |
44 |
|
44 | |||
45 | def listdirinternal(dfd, req, stat, skip): |
|
45 | def listdirinternal(dfd, req, stat, skip): | |
46 | ret = [] |
|
46 | ret = [] | |
@@ -50,16 +50,16 if pycompat.isdarwin: | |||||
50 | break |
|
50 | break | |
51 | if r == -1: |
|
51 | if r == -1: | |
52 | raise OSError(ffi.errno, os.strerror(ffi.errno)) |
|
52 | raise OSError(ffi.errno, os.strerror(ffi.errno)) | |
53 |
cur = ffi.cast( |
|
53 | cur = ffi.cast("val_attrs_t*", buf) | |
54 | for i in range(r): |
|
54 | for i in range(r): | |
55 | lgt = cur.length |
|
55 | lgt = cur.length | |
56 |
assert lgt == ffi.cast( |
|
56 | assert lgt == ffi.cast('uint32_t*', cur)[0] | |
57 | ofs = cur.name_info.attr_dataoffset |
|
57 | ofs = cur.name_info.attr_dataoffset | |
58 | str_lgt = cur.name_info.attr_length |
|
58 | str_lgt = cur.name_info.attr_length | |
59 |
base_ofs = ffi.offsetof( |
|
59 | base_ofs = ffi.offsetof('val_attrs_t', 'name_info') | |
60 | name = bytes( |
|
60 | name = bytes( | |
61 | ffi.buffer( |
|
61 | ffi.buffer( | |
62 |
ffi.cast( |
|
62 | ffi.cast("char*", cur) + base_ofs + ofs, str_lgt - 1 | |
63 | ) |
|
63 | ) | |
64 | ) |
|
64 | ) | |
65 | tp = attrkinds[cur.obj_type] |
|
65 | tp = attrkinds[cur.obj_type] | |
@@ -84,12 +84,12 if pycompat.isdarwin: | |||||
84 | else: |
|
84 | else: | |
85 | ret.append((name, tp)) |
|
85 | ret.append((name, tp)) | |
86 | cur = ffi.cast( |
|
86 | cur = ffi.cast( | |
87 |
|
|
87 | "val_attrs_t*", int(ffi.cast("intptr_t", cur)) + lgt | |
88 | ) |
|
88 | ) | |
89 | return ret |
|
89 | return ret | |
90 |
|
90 | |||
91 | def listdir(path, stat=False, skip=None): |
|
91 | def listdir(path, stat=False, skip=None): | |
92 |
req = ffi.new( |
|
92 | req = ffi.new("struct attrlist*") | |
93 | req.bitmapcount = lib.ATTR_BIT_MAP_COUNT |
|
93 | req.bitmapcount = lib.ATTR_BIT_MAP_COUNT | |
94 | req.commonattr = ( |
|
94 | req.commonattr = ( | |
95 | lib.ATTR_CMN_RETURNED_ATTRS |
|
95 | lib.ATTR_CMN_RETURNED_ATTRS |
@@ -464,7 +464,7 class hgweb: | |||||
464 |
|
464 | |||
465 | res.headers[b'ETag'] = tag |
|
465 | res.headers[b'ETag'] = tag | |
466 |
|
466 | |||
467 | if cmd not in webcommands.__all__: |
|
467 | if pycompat.sysstr(cmd) not in webcommands.__all__: | |
468 | msg = b'no such method: %s' % cmd |
|
468 | msg = b'no such method: %s' % cmd | |
469 | raise ErrorResponse(HTTP_BAD_REQUEST, msg) |
|
469 | raise ErrorResponse(HTTP_BAD_REQUEST, msg) | |
470 | else: |
|
470 | else: |
@@ -72,7 +72,7 class webcommand: | |||||
72 | self.name = name |
|
72 | self.name = name | |
73 |
|
73 | |||
74 | def __call__(self, func): |
|
74 | def __call__(self, func): | |
75 | __all__.append(self.name) |
|
75 | __all__.append(pycompat.sysstr(self.name)) | |
76 | commands[self.name] = func |
|
76 | commands[self.name] = func | |
77 | return func |
|
77 | return func | |
78 |
|
78 |
@@ -687,6 +687,6 if __name__ == '__main__': | |||||
687 | N = int(sys.argv[1]) |
|
687 | N = int(sys.argv[1]) | |
688 | url = sys.argv[2] |
|
688 | url = sys.argv[2] | |
689 | except (IndexError, ValueError): |
|
689 | except (IndexError, ValueError): | |
690 |
print( |
|
690 | print("%s <integer> <url>" % sys.argv[0]) | |
691 | else: |
|
691 | else: | |
692 | test(url, N) |
|
692 | test(url, N) |
@@ -6,7 +6,7 Profiler = _lsprof.Profiler | |||||
6 | # PyPy doesn't expose profiler_entry from the module. |
|
6 | # PyPy doesn't expose profiler_entry from the module. | |
7 | profiler_entry = getattr(_lsprof, 'profiler_entry', None) |
|
7 | profiler_entry = getattr(_lsprof, 'profiler_entry', None) | |
8 |
|
8 | |||
9 |
__all__ = [ |
|
9 | __all__ = ['profile', 'Stats'] | |
10 |
|
10 | |||
11 |
|
11 | |||
12 | def profile(f, *args, **kwds): |
|
12 | def profile(f, *args, **kwds): |
@@ -528,7 +528,7 def _filternarrowactions(narrowmatch, br | |||||
528 | """ |
|
528 | """ | |
529 | # We mutate the items in the dict during iteration, so iterate |
|
529 | # We mutate the items in the dict during iteration, so iterate | |
530 | # over a copy. |
|
530 | # over a copy. | |
531 | for f, action in mresult.filemap(): |
|
531 | for f, action in list(mresult.filemap()): | |
532 | if narrowmatch(f): |
|
532 | if narrowmatch(f): | |
533 | pass |
|
533 | pass | |
534 | elif not branchmerge: |
|
534 | elif not branchmerge: | |
@@ -669,7 +669,7 class mergeresult: | |||||
669 | return sum(len(self._actionmapping[a]) for a in actions) |
|
669 | return sum(len(self._actionmapping[a]) for a in actions) | |
670 |
|
670 | |||
671 | def filemap(self, sort=False): |
|
671 | def filemap(self, sort=False): | |
672 |
if sort |
|
672 | if sort: | |
673 | for key, val in sorted(self._filemapping.items()): |
|
673 | for key, val in sorted(self._filemapping.items()): | |
674 | yield key, val |
|
674 | yield key, val | |
675 | else: |
|
675 | else: |
@@ -243,7 +243,7 def compute_all_files_changes(ctx): | |||||
243 | return _process_linear(p1, ctx) |
|
243 | return _process_linear(p1, ctx) | |
244 | elif p1.rev() == nullrev and p2.rev() != nullrev: |
|
244 | elif p1.rev() == nullrev and p2.rev() != nullrev: | |
245 | # In the wild, one can encounter changeset where p1 is null but p2 is not |
|
245 | # In the wild, one can encounter changeset where p1 is null but p2 is not | |
246 |
return _process_linear(p |
|
246 | return _process_linear(p2, ctx, parent=2) | |
247 | elif p1.rev() == p2.rev(): |
|
247 | elif p1.rev() == p2.rev(): | |
248 | # In the wild, one can encounter such "non-merge" |
|
248 | # In the wild, one can encounter such "non-merge" | |
249 | return _process_linear(p1, ctx) |
|
249 | return _process_linear(p1, ctx) |
@@ -122,7 +122,7 def split(stream): | |||||
122 | if not m.is_multipart(): |
|
122 | if not m.is_multipart(): | |
123 | yield msgfp(m) |
|
123 | yield msgfp(m) | |
124 | else: |
|
124 | else: | |
125 |
ok_types = ( |
|
125 | ok_types = ('text/plain', 'text/x-diff', 'text/x-patch') | |
126 | for part in m.walk(): |
|
126 | for part in m.walk(): | |
127 | ct = part.get_content_type() |
|
127 | ct = part.get_content_type() | |
128 | if ct not in ok_types: |
|
128 | if ct not in ok_types: |
@@ -23,6 +23,7 import unicodedata | |||||
23 | from typing import ( |
|
23 | from typing import ( | |
24 | Any, |
|
24 | Any, | |
25 | AnyStr, |
|
25 | AnyStr, | |
|
26 | Callable, | |||
26 | Iterable, |
|
27 | Iterable, | |
27 | Iterator, |
|
28 | Iterator, | |
28 | List, |
|
29 | List, | |
@@ -552,7 +553,7 if pycompat.sysplatform == b'OpenVMS': | |||||
552 | return False |
|
553 | return False | |
553 |
|
554 | |||
554 |
|
555 | |||
555 | _needsshellquote: Optional[Match[bytes]] = None |
|
556 | _needsshellquote: Optional[Callable[[bytes], Optional[Match[bytes]]]] = None | |
556 |
|
557 | |||
557 |
|
558 | |||
558 | def shellquote(s: bytes) -> bytes: |
|
559 | def shellquote(s: bytes) -> bytes: |
@@ -126,7 +126,7 from . import ( | |||||
126 | defaultdict = collections.defaultdict |
|
126 | defaultdict = collections.defaultdict | |
127 | contextmanager = contextlib.contextmanager |
|
127 | contextmanager = contextlib.contextmanager | |
128 |
|
128 | |||
129 |
__all__ = [ |
|
129 | __all__ = ['start', 'stop', 'reset', 'display', 'profile'] | |
130 |
|
130 | |||
131 | skips = { |
|
131 | skips = { | |
132 | "util.py:check", |
|
132 | "util.py:check", |
@@ -734,9 +734,9 checksum = "e2abad23fbc42b3700f2f279844d | |||||
734 |
|
734 | |||
735 | [[package]] |
|
735 | [[package]] | |
736 | name = "libc" |
|
736 | name = "libc" | |
737 |
version = "0.2.1 |
|
737 | version = "0.2.155" | |
738 | source = "registry+https://github.com/rust-lang/crates.io-index" |
|
738 | source = "registry+https://github.com/rust-lang/crates.io-index" | |
739 | checksum = "fc7fcc620a3bff7cdd7a365be3376c97191aeaccc2a603e600951e452615bf89" |
|
739 | checksum = "97b3888a4aecf77e811145cadf6eef5901f4782c53886191b2f693f24761847c" | |
740 |
|
740 | |||
741 | [[package]] |
|
741 | [[package]] | |
742 | name = "libm" |
|
742 | name = "libm" | |
@@ -1178,6 +1178,7 dependencies = [ | |||||
1178 | "hg-core", |
|
1178 | "hg-core", | |
1179 | "home", |
|
1179 | "home", | |
1180 | "lazy_static", |
|
1180 | "lazy_static", | |
|
1181 | "libc", | |||
1181 | "log", |
|
1182 | "log", | |
1182 | "logging_timer", |
|
1183 | "logging_timer", | |
1183 | "rayon", |
|
1184 | "rayon", |
@@ -24,3 +24,4 shellexpand = { version = "3.1", feature | |||||
24 | whoami = "1.4" |
|
24 | whoami = "1.4" | |
25 | which = "4.3.0" |
|
25 | which = "4.3.0" | |
26 | rayon = "1.7.0" |
|
26 | rayon = "1.7.0" | |
|
27 | libc = "0.2.155" |
@@ -611,7 +611,11 pub fn run(invocation: &crate::CliInvoca | |||||
611 | log::info!("not writing dirstate from `status`: lock is held") |
|
611 | log::info!("not writing dirstate from `status`: lock is held") | |
612 | } |
|
612 | } | |
613 | Err(LockError::Other(HgError::IoError { error, .. })) |
|
613 | Err(LockError::Other(HgError::IoError { error, .. })) | |
614 |
if error.kind() == io::ErrorKind::PermissionDenied |
|
614 | if error.kind() == io::ErrorKind::PermissionDenied | |
|
615 | || match error.raw_os_error() { | |||
|
616 | None => false, | |||
|
617 | Some(errno) => libc::EROFS == errno, | |||
|
618 | } => | |||
615 | { |
|
619 | { | |
616 | // `hg status` on a read-only repository is fine |
|
620 | // `hg status` on a read-only repository is fine | |
617 | } |
|
621 | } |
@@ -1660,7 +1660,11 if os.name == 'nt': | |||||
1660 | # Allow compiler/linker flags to be added to Visual Studio builds. Passing |
|
1660 | # Allow compiler/linker flags to be added to Visual Studio builds. Passing | |
1661 | # extra_link_args to distutils.extensions.Extension() doesn't have any |
|
1661 | # extra_link_args to distutils.extensions.Extension() doesn't have any | |
1662 | # effect. |
|
1662 | # effect. | |
|
1663 | try: | |||
|
1664 | # setuptools < 65.0 | |||
1663 | from distutils import msvccompiler |
|
1665 | from distutils import msvccompiler | |
|
1666 | except ImportError: | |||
|
1667 | from distutils import _msvccompiler as msvccompiler | |||
1664 |
|
1668 | |||
1665 | msvccompilerclass = msvccompiler.MSVCCompiler |
|
1669 | msvccompilerclass = msvccompiler.MSVCCompiler | |
1666 |
|
1670 |
@@ -20,4 +20,4 def raiseerror(web): | |||||
20 |
|
20 | |||
21 | def extsetup(ui): |
|
21 | def extsetup(ui): | |
22 | setattr(webcommands, 'raiseerror', raiseerror) |
|
22 | setattr(webcommands, 'raiseerror', raiseerror) | |
23 |
webcommands.__all__.append( |
|
23 | webcommands.__all__.append('raiseerror') |
@@ -1076,6 +1076,11 Ensure base clone command argument valid | |||||
1076 | abort: --all-largefiles is incompatible with non-local destination ssh://localhost/a |
|
1076 | abort: --all-largefiles is incompatible with non-local destination ssh://localhost/a | |
1077 | [255] |
|
1077 | [255] | |
1078 |
|
1078 | |||
|
1079 | $ touch existing_destination | |||
|
1080 | $ hg clone --all-largefiles a existing_destination | |||
|
1081 | abort: destination 'existing_destination' already exists | |||
|
1082 | [10] | |||
|
1083 | ||||
1079 | Test pulling with --all-largefiles flag. Also test that the largefiles are |
|
1084 | Test pulling with --all-largefiles flag. Also test that the largefiles are | |
1080 | downloaded from 'default' instead of 'default-push' when no source is specified |
|
1085 | downloaded from 'default' instead of 'default-push' when no source is specified | |
1081 | (issue3584) |
|
1086 | (issue3584) |
General Comments 0
You need to be logged in to leave comments.
Login now