##// END OF EJS Templates
match: match explicit file using a set...
match: match explicit file using a set The matcher as all the logic to do quick comparison against explicit patterns, however the pattern matcher was shadowing the code using that set and used the compiled regex pattern in all cases, which is quite slow. We restore the usage of the set based matching to boost performance. Building the regexp is still consuming a large amount of time (actually, the majority of the time), which is still silly. Maybe using re2 would help that, but this is a quest for another adventure. Another path to improve this is to have a pattern type dedicated to match the exact path to a file only (not a directory). This pattern could use the set matching only and be skipped in the regex all together. Benchmarks ========== In the following benchmark we are comparing the `hg cat` and `hg files` run time when matching against all files in the repository. They are run: - without the rust extensions - with the standard python engine (so without re2) Performance improvement in this series -------------------------------------- ###### hg files ############################################################### ### mercurial-2018-08-01-zstd-sparse-revlog ### sorted base-changeset: 0.230092 seconds prev-changeset: 0.230069 seconds this-changeset: 0.211425 seconds (-8.36%) ### mercurial-2018-08-01-zstd-sparse-revlog ### shuffled base-changeset: 0.234235 seconds prev-changeset: 0.231165 seconds (-1.38%) this-changeset: 0.212300 seconds (-9.43%) ### pypy-2018-08-01-zstd-sparse-revlog ### sorted base-changeset: 0.613567 seconds prev-changeset: 0.616799 seconds this-changeset: 0.510852 seconds (-16.82%) ### pypy-2018-08-01-zstd-sparse-revlog ### shuffled base-changeset: 0.801880 seconds prev-changeset: 0.616393 seconds (-23.22%) this-changeset: 0.511903 seconds (-36.23%) ### netbeans-2018-08-01-zstd-sparse-revlog ### sorted base-changeset: 21.541828 seconds prev-changeset: 21.586773 seconds this-changeset: 13.648347 seconds (-36.76%) ### netbeans-2018-08-01-zstd-sparse-revlog ### shuffled base-changeset: 172.759857 seconds prev-changeset: 21.908197 seconds (-87.32%) this-changeset: 13.945110 seconds (-91.93%) ### mozilla-central-2018-08-01-zstd-sparse-revlog ### sorted base-changeset: 62.474221 seconds prev-changeset: 61.279490 seconds (-1.22%) this-changeset: 29.529469 seconds (-52.40%) ### mozilla-central-2018-08-01-zstd-sparse-revlog ### shuffled base-changeset: 1364.180218 seconds prev-changeset: 62.473549 seconds (-95.40%) this-changeset: 30.625249 seconds (-97.75%) ###### hg cat ################################################################# ### mercurial-2018-08-01-zstd-sparse-revlog ### sorted base-changeset: 0.764407 seconds prev-changeset: 0.763883 seconds this-changeset: 0.737326 seconds (-3.68%) ### mercurial-2018-08-01-zstd-sparse-revlog ### shuffled base-changeset: 0.768924 seconds prev-changeset: 0.765848 seconds this-changeset: 0.174d0b seconds (-4.44%) ### pypy-2018-08-01-zstd-sparse-revlog ### sorted base-changeset: 2.065220 seconds prev-changeset: 2.070498 seconds this-changeset: 1.939482 seconds (-6.08%) ### pypy-2018-08-01-zstd-sparse-revlog ### shuffled base-changeset: 2.276388 seconds prev-changeset: 2.069197 seconds (-9.15%) this-changeset: 1.931746 seconds (-15.19%) ### netbeans-2018-08-01-zstd-sparse-revlog ### sorted base-changeset: 40.967983 seconds prev-changeset: 41.392423 seconds this-changeset: 32.181681 seconds (-22.20%) ### netbeans-2018-08-01-zstd-sparse-revlog ### shuffled base-changeset: 216.388709 seconds prev-changeset: 41.648689 seconds (-80.88%) this-changeset: 32.580817 seconds (-85.04%) ### mozilla-central-2018-08-01-zstd-sparse-revlog ### sorted base-changeset: 105.228510 seconds prev-changeset: 103.315670 seconds (-1.23%) this-changeset: 69.416118 seconds (-33.64%) ### mozilla-central-2018-08-01-zstd-sparse-revlog ### shuffled base-changeset: 1448.722784 seconds prev-changeset: 104.369358 seconds (-92.80%) this-changeset: 70.554789 seconds (-95.13%) Different way to list the same data with this revision ------------------------------------------------------ ###### hg files ############################################################### ### mercurial-2018-08-01-zstd-sparse-revlog root: 0.119182 seconds glob: 0.120697 seconds (+1.27%) sorted: 0.211425 seconds (+77.40%) shuffled: 0.212300 seconds (+78.13%) ### pypy-2018-08-01-zstd-sparse-revlog root: 0.121986 seconds glob: 0.124822 seconds (+2.32%) sorted: 0.510852 seconds (+318.78%) shuffled: 0.511903 seconds (+319.64%) ### netbeans-2018-08-01-zstd-sparse-revlog root: 0.173984 seconds glob: 0.227203 seconds (+30.59%) sorted: 13.648347 seconds (+7744.59%) shuffled: 13.945110 seconds (+7915.16%) ### mozilla-central-2018-08-01-zstd-sparse-revlog root: 0.366463 seconds glob: 0.491030 seconds (+33.99%) sorted: 29.529469 seconds (+7957.96%) shuffled: 30.625249 seconds (+8256.97%) ###### hg cat ################################################################# ### mercurial-2018-08-01-zstd-sparse-revlog glob: 0.647471 seconds root: 0.643120 seconds shuffled: 0.174d0b seconds (+13.92%) sorted: 0.737326 seconds (+13.88%) ### mozilla-central-2018-08-01-zstd-sparse-revlog glob: 40.596983 seconds root: 40.129136 seconds shuffled: 70.554789 seconds (+73.79%) sorted: 69.416118 seconds (+70.99%) ### netbeans-2018-08-01-zstd-sparse-revlog glob: 18.777924 seconds root: 18.613905 seconds shuffled: 32.580817 seconds (+73.51%) sorted: 32.181681 seconds (+71.38%) ### pypy-2018-08-01-zstd-sparse-revlog glob: 1.555319 seconds root: 1.536534 seconds shuffled: 1.931746 seconds (+24.20%) sorted: 1.939482 seconds (+24.70%)

File last commit:

r50698:55d45d0d default
r51286:81c7d04f stable
Show More
archival.py
367 lines | 10.4 KiB | text/x-python | PythonLexer
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112 # archival.py - revision archival for mercurial
#
# Copyright 2006 Vadim Gelfer <vadim.gelfer@gmail.com>
#
Martin Geisler
updated license to be explicit about GPL version 2
r8225 # This software may be used and distributed according to the terms of the
Matt Mackall
Update license to GPLv2+
r10263 # GNU General Public License version 2 or any later version.
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112
Gregory Szorc
archival: use absolute_import
r25916
import gzip
import os
FUJIWARA Katsunori
archival: add "extended-timestamp" extra block for zip archives (issue3600)...
r17628 import struct
Gregory Szorc
archival: use absolute_import
r25916 import tarfile
import time
import zipfile
import zlib
from .i18n import _
Augie Fackler
formatting: blacken the codebase...
r43346 from .node import nullrev
Gregory Szorc
py3: manually import pycompat.open into files that need it...
r43355 from .pycompat import open
Gregory Szorc
archival: use absolute_import
r25916
from . import (
error,
Matt Harbison
archive: use a templater to build the metadata file...
r33544 formatter,
Gregory Szorc
archival: use absolute_import
r25916 match as matchmod,
Augie Fackler
archival: fsdecode paths before passing to tar or zip objects...
r36724 pycompat,
Matt Harbison
archive: migrate to the fileprefetch callback mechanism
r36156 scmutil,
Gregory Szorc
archival: use absolute_import
r25916 util,
Pierre-Yves David
vfs: use 'vfs' module directly in 'mercurial.archival'...
r31235 vfs as vfsmod,
Gregory Szorc
archival: use absolute_import
r25916 )
Augie Fackler
formatting: blacken the codebase...
r43346
Matt Harbison
archival: force a `CompressionError` to bytes before passing to `error.Abort`...
r48825 from .utils import stringutil
timeless
pycompat: switch to util.stringio for py3 compat
r28861 stringio = util.stringio
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112
Mads Kiilerich
declare local constants instead of using magic values and comments
r17429 # from unzip source code:
_UNX_IFREG = 0x8000
Augie Fackler
formatting: blacken the codebase...
r43346 _UNX_IFLNK = 0xA000
Mads Kiilerich
declare local constants instead of using magic values and comments
r17429
Martin Geisler
archival: remove prefix argument from archivers...
r11558 def tidyprefix(dest, kind, prefix):
Augie Fackler
formating: upgrade to black 20.8b1...
r46554 """choose prefix to use for names in archive. make sure prefix is
safe for consumers."""
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112
if prefix:
Shun-ichi GOTO
Use util.normpath() instead of direct path string operation....
r5842 prefix = util.normpath(prefix)
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112 else:
Pulkit Goyal
py3: use bytes instead of str in isinstance...
r36455 if not isinstance(dest, bytes):
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 raise ValueError(b'dest must be string if no prefix')
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112 prefix = os.path.basename(dest)
lower = prefix.lower()
Martin Geisler
archival: remove prefix argument from archivers...
r11558 for sfx in exts.get(kind, []):
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112 if lower.endswith(sfx):
Augie Fackler
formatting: blacken the codebase...
r43346 prefix = prefix[: -len(sfx)]
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112 break
lpfx = os.path.normpath(util.localpath(prefix))
prefix = util.pconvert(lpfx)
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 if not prefix.endswith(b'/'):
prefix += b'/'
Matt Harbison
archive: drop the leading '.' path component from the prefix (issue4634)...
r24953 # Drop the leading '.' path component if present, so Windows can read the
# zip files (issue4634)
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 if prefix.startswith(b'./'):
Matt Harbison
archive: drop the leading '.' path component from the prefix (issue4634)...
r24953 prefix = prefix[2:]
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 if prefix.startswith(b'../') or os.path.isabs(lpfx) or b'/../' in prefix:
raise error.Abort(_(b'archive prefix contains illegal components'))
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112 return prefix
Augie Fackler
formatting: blacken the codebase...
r43346
Martin Geisler
archival: move commands.archive.guess_type to archival.guesskind...
r11557 exts = {
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 b'tar': [b'.tar'],
b'tbz2': [b'.tbz2', b'.tar.bz2'],
b'tgz': [b'.tgz', b'.tar.gz'],
b'zip': [b'.zip'],
b'txz': [b'.txz', b'.tar.xz'],
Augie Fackler
formatting: blacken the codebase...
r43346 }
Martin Geisler
archival: move commands.archive.guess_type to archival.guesskind...
r11557
def guesskind(dest):
Gregory Szorc
global: bulk replace simple pycompat.iteritems(x) with x.items()...
r49768 for kind, extensions in exts.items():
Augie Fackler
cleanup: use __builtins__.any instead of util.any...
r25149 if any(dest.endswith(ext) for ext in extensions):
Martin Geisler
archival: move commands.archive.guess_type to archival.guesskind...
r11557 return kind
return None
Augie Fackler
formatting: blacken the codebase...
r43346
Yuya Nishihara
archive: look for first visible revision to build repo identity (issue4591)...
r24681 def _rootctx(repo):
# repo[0] may be hidden
for rev in repo:
return repo[rev]
Martin von Zweigbergk
repo: look up nullrev context by revnum, not symbolic name...
r39930 return repo[nullrev]
Yuya Nishihara
archive: look for first visible revision to build repo identity (issue4591)...
r24681
Augie Fackler
formatting: blacken the codebase...
r43346
Yuya Nishihara
archive: rewrite default metadata template as a multi-line bytes literal...
r35923 # {tags} on ctx includes local tags and 'tip', with no current way to limit
# that to global tags. Therefore, use {latesttag} as a substitute when
# the distance is 0, since that will be the list of global tags on ctx.
_defaultmetatemplate = br'''
repo: {root}
node: {ifcontains(rev, revset("wdir()"), "{p1node}{dirty}", "{node}")}
branch: {branch|utf8}
{ifeq(latesttagdistance, 0, join(latesttag % "tag: {tag}", "\n"),
separate("\n",
join(latesttag % "latesttag: {tag}", "\n"),
"latesttagdistance: {latesttagdistance}",
"changessincelatesttag: {changessincelatesttag}"))}
Augie Fackler
formatting: blacken the codebase...
r43346 '''[
1:
] # drop leading '\n'
Yuya Nishihara
archive: rewrite default metadata template as a multi-line bytes literal...
r35923
Yuya Nishihara
archive: extract metadata() closure to module-level function...
r24678 def buildmetadata(ctx):
'''build content of .hg_archival.txt'''
repo = ctx.repo()
Matt Harbison
archive: use a templater to build the metadata file...
r33544
opts = {
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 b'template': repo.ui.config(
b'experimental', b'archivemetatemplate', _defaultmetatemplate
Augie Fackler
formatting: blacken the codebase...
r43346 )
Matt Harbison
archive: use a templater to build the metadata file...
r33544 }
out = util.stringio()
Yuya Nishihara
archive: extract metadata() closure to module-level function...
r24678
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 fm = formatter.formatter(repo.ui, out, b'archive', opts)
Matt Harbison
archive: use a templater to build the metadata file...
r33544 fm.startitem()
fm.context(ctx=ctx)
fm.data(root=_rootctx(repo).hex())
if ctx.rev() is None:
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 dirty = b''
Matt Harbison
archive: use a templater to build the metadata file...
r33544 if ctx.dirty(missing=True):
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 dirty = b'+'
Matt Harbison
archive: use a templater to build the metadata file...
r33544 fm.data(dirty=dirty)
fm.end()
return out.getvalue()
Martin Geisler
archival: move commands.archive.guess_type to archival.guesskind...
r11557
Augie Fackler
formatting: blacken the codebase...
r43346
Gregory Szorc
py3: use class X: instead of class X(object):...
r49801 class tarit:
Augie Fackler
formating: upgrade to black 20.8b1...
r46554 """write archive to tar file or stream. can write uncompressed,
or compress with gzip or bzip2."""
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 def __init__(self, dest, mtime, kind=b''):
Vadim Gelfer
use commit time as mtime for file archives....
r2477 self.mtime = mtime
Dan Villiom Podlaski Christiansen
explicitly close files...
r13400 self.fileobj = None
csaba.henk@creo.hu
timestamp of gzip archives taken from changeset context
r4652
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 def taropen(mode, name=b'', fileobj=None):
if kind == b'gz':
Pulkit Goyal
py3: slice over bytes or use .startswith() to prevent getting ascii values...
r36465 mode = mode[0:1]
csaba.henk@creo.hu
timestamp of gzip archives taken from changeset context
r4652 if not fileobj:
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 fileobj = open(name, mode + b'b')
Gregory Szorc
archival: remove GzipFileWithTime...
r49737 gzfileobj = gzip.GzipFile(
Augie Fackler
formatting: blacken the codebase...
r43346 name,
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 pycompat.sysstr(mode + b'b'),
Augie Fackler
formatting: blacken the codebase...
r43346 zlib.Z_BEST_COMPRESSION,
fileobj,
gzip: rename the argument to `mtime` to match upstream python...
r44980 mtime=mtime,
Augie Fackler
formatting: blacken the codebase...
r43346 )
Dan Villiom Podlaski Christiansen
explicitly close files...
r13400 self.fileobj = gzfileobj
Augie Fackler
formating: upgrade to black 20.8b1...
r46554 return (
Matt Harbison
typing: add type hints to pycompat.bytestr...
r50698 # taropen() wants Literal['a', 'r', 'w', 'x'] for the mode,
# but Literal[] is only available in 3.8+ without the
# typing_extensions backport.
# pytype: disable=wrong-arg-types
Augie Fackler
formating: upgrade to black 20.8b1...
r46554 tarfile.TarFile.taropen( # pytype: disable=attribute-error
name, pycompat.sysstr(mode), gzfileobj
)
Matt Harbison
typing: add type hints to pycompat.bytestr...
r50698 # pytype: enable=wrong-arg-types
Augie Fackler
formatting: blacken the codebase...
r43346 )
csaba.henk@creo.hu
timestamp of gzip archives taken from changeset context
r4652 else:
Manuel Jacob
archival: abort if compression method is unavailable...
r45601 try:
return tarfile.open(
name, pycompat.sysstr(mode + kind), fileobj
)
except tarfile.CompressionError as e:
Matt Harbison
archival: force a `CompressionError` to bytes before passing to `error.Abort`...
r48825 raise error.Abort(stringutil.forcebytestr(e))
csaba.henk@creo.hu
timestamp of gzip archives taken from changeset context
r4652
Augie Fackler
archival: our filenames are bytes, not strs...
r36726 if isinstance(dest, bytes):
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 self.z = taropen(b'w:', name=dest)
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112 else:
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 self.z = taropen(b'w|', fileobj=dest)
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112
Alexis S. L. Carvalho
archive: add symlink support
r4831 def addfile(self, name, mode, islink, data):
Augie Fackler
archival: fsdecode paths before passing to tar or zip objects...
r36724 name = pycompat.fsdecode(name)
Martin Geisler
archival: remove prefix argument from archivers...
r11558 i = tarfile.TarInfo(name)
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112 i.mtime = self.mtime
i.size = len(data)
Alexis S. L. Carvalho
archive: add symlink support
r4831 if islink:
i.type = tarfile.SYMTYPE
Gregory Szorc
global: mass rewrite to use modern octal syntax...
r25658 i.mode = 0o777
Augie Fackler
archival: fsdecode paths before passing to tar or zip objects...
r36724 i.linkname = pycompat.fsdecode(data)
Alexis S. L. Carvalho
archive: add symlink support
r4831 data = None
Peter van Dijk
fix disappearing symlinks [issue1509]
r7770 i.size = 0
Alexis S. L. Carvalho
archive: add symlink support
r4831 else:
i.mode = mode
timeless
pycompat: switch to util.stringio for py3 compat
r28861 data = stringio(data)
Alexis S. L. Carvalho
archive: add symlink support
r4831 self.z.addfile(i, data)
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112
def done(self):
self.z.close()
Dan Villiom Podlaski Christiansen
explicitly close files...
r13400 if self.fileobj:
self.fileobj.close()
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112
Augie Fackler
formatting: blacken the codebase...
r43346
Gregory Szorc
py3: use class X: instead of class X(object):...
r49801 class zipit:
Augie Fackler
formating: upgrade to black 20.8b1...
r46554 """write archive to zip file or stream. can write uncompressed,
or compressed with deflate."""
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112
Martin Geisler
archival: remove prefix argument from archivers...
r11558 def __init__(self, dest, mtime, compress=True):
Augie Fackler
archival: don't try and fsdecode non-{bytes,str} objects...
r40283 if isinstance(dest, bytes):
dest = pycompat.fsdecode(dest)
Augie Fackler
formatting: blacken the codebase...
r43346 self.z = zipfile.ZipFile(
Augie Fackler
cleanup: remove pointless r-prefixes on single-quoted strings...
r43906 dest, 'w', compress and zipfile.ZIP_DEFLATED or zipfile.ZIP_STORED
Augie Fackler
formatting: blacken the codebase...
r43346 )
Martin Geisler
archive: set date to 1980 for very old zip files...
r12319
# Python's zipfile module emits deprecation warnings if we try
# to store files with a date before 1980.
Augie Fackler
formatting: blacken the codebase...
r43346 epoch = 315532800 # calendar.timegm((1980, 1, 1, 0, 0, 0, 1, 1, 0))
Martin Geisler
archive: set date to 1980 for very old zip files...
r12319 if mtime < epoch:
mtime = epoch
FUJIWARA Katsunori
archival: add "extended-timestamp" extra block for zip archives (issue3600)...
r17628 self.mtime = mtime
Vadim Gelfer
use commit time as mtime for file archives....
r2477 self.date_time = time.gmtime(mtime)[:6]
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112
Alexis S. L. Carvalho
archive: add symlink support
r4831 def addfile(self, name, mode, islink, data):
Augie Fackler
archival: fsdecode paths before passing to tar or zip objects...
r36724 i = zipfile.ZipInfo(pycompat.fsdecode(name), self.date_time)
Augie Fackler
archival: suppress some incorrect pytype failures...
r43788 i.compress_type = self.z.compression # pytype: disable=attribute-error
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112 # unzip will not honor unix file modes unless file creator is
# set to unix (id 3).
i.create_system = 3
Mads Kiilerich
declare local constants instead of using magic values and comments
r17429 ftype = _UNX_IFREG
Alexis S. L. Carvalho
archive: add symlink support
r4831 if islink:
Gregory Szorc
global: mass rewrite to use modern octal syntax...
r25658 mode = 0o777
Mads Kiilerich
declare local constants instead of using magic values and comments
r17429 ftype = _UNX_IFLNK
Pulkit Goyal
py3: remove use of *L syntax...
r29890 i.external_attr = (mode | ftype) << 16
FUJIWARA Katsunori
archival: add "extended-timestamp" extra block for zip archives (issue3600)...
r17628 # add "extended-timestamp" extra block, because zip archives
# without this will be extracted with unexpected timestamp,
# if TZ is not configured as GMT
Augie Fackler
formatting: blacken the codebase...
r43346 i.extra += struct.pack(
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 b'<hhBl',
Augie Fackler
formatting: blacken the codebase...
r43346 0x5455, # block type: "extended-timestamp"
1 + 4, # size of this block
1, # "modification time is present"
int(self.mtime),
) # last modification (UTC)
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112 self.z.writestr(i, data)
def done(self):
self.z.close()
Augie Fackler
formatting: blacken the codebase...
r43346
Gregory Szorc
py3: use class X: instead of class X(object):...
r49801 class fileit:
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112 '''write archive as files in directory.'''
Martin Geisler
archival: remove prefix argument from archivers...
r11558 def __init__(self, name, mtime):
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112 self.basedir = name
Pierre-Yves David
vfs: use 'vfs' module directly in 'mercurial.archival'...
r31235 self.opener = vfsmod.vfs(self.basedir)
James May
archive: pass thru mtime for directory archives, like other archive types do...
r35203 self.mtime = mtime
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112
Alexis S. L. Carvalho
archive: add symlink support
r4831 def addfile(self, name, mode, islink, data):
if islink:
self.opener.symlink(data, name)
return
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 f = self.opener(name, b"w", atomictemp=False)
Alexis S. L. Carvalho
archive: use util.opener when archiving files....
r4830 f.write(data)
Greg Ward
atomictempfile: make close() consistent with other file-like objects....
r15057 f.close()
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112 destfile = os.path.join(self.basedir, name)
Alexis S. L. Carvalho
archive: use util.opener when archiving files....
r4830 os.chmod(destfile, mode)
James May
archive: pass thru mtime for directory archives, like other archive types do...
r35203 if self.mtime is not None:
os.utime(destfile, (self.mtime, self.mtime))
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112
def done(self):
pass
Augie Fackler
formatting: blacken the codebase...
r43346
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112 archivers = {
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 b'files': fileit,
b'tar': tarit,
b'tbz2': lambda name, mtime: tarit(name, mtime, b'bz2'),
b'tgz': lambda name, mtime: tarit(name, mtime, b'gz'),
b'txz': lambda name, mtime: tarit(name, mtime, b'xz'),
b'uzip': lambda name, mtime: zipit(name, mtime, False),
b'zip': zipit,
Augie Fackler
formatting: blacken the codebase...
r43346 }
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112
Augie Fackler
formatting: blacken the codebase...
r43346 def archive(
repo,
dest,
node,
kind,
decode=True,
match=None,
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 prefix=b'',
Augie Fackler
formatting: blacken the codebase...
r43346 mtime=None,
subrepos=False,
):
Augie Fackler
formating: upgrade to black 20.8b1...
r46554 """create archive of repo as it was at node.
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112
dest can be name of directory, name of archive file, or file
object to write archive to.
kind is type of archive to create.
decode tells whether to put files through decode filters from
hgrc.
Martin von Zweigbergk
archive: change "matcnfn" argument to a real matcher...
r40443 match is a matcher to filter names of files to write to archive.
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112
James May
archive: pass thru mtime for directory archives, like other archive types do...
r35203 prefix is name of path to put before every archive member.
mtime is the modified time, in seconds, or None to use the changeset time.
subrepos tells whether to include subrepos.
Augie Fackler
formating: upgrade to black 20.8b1...
r46554 """
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 if kind == b'files':
Martin Geisler
archival: remove prefix argument from archivers...
r11558 if prefix:
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 raise error.Abort(_(b'cannot give prefix when archiving to files'))
Martin Geisler
archival: remove prefix argument from archivers...
r11558 else:
prefix = tidyprefix(dest, kind, prefix)
Alexis S. L. Carvalho
archive: delay extraction of file revisions...
r4951 def write(name, mode, islink, getdata):
data = getdata()
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112 if decode:
Matt Mackall
replace filehandle version of wwrite with wwritedata
r4005 data = repo.wwritedata(name, data)
Martin Geisler
archival: remove prefix argument from archivers...
r11558 archiver.addfile(prefix + name, mode, islink, data)
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112
Dirkjan Ochtman
cleanly abort on unknown archive type (issue966)
r6019 if kind not in archivers:
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 raise error.Abort(_(b"unknown archive type '%s'") % kind)
Matt Mackall
manifest: remove execf/linkf methods
r6749
ctx = repo[node]
Martin Geisler
archival: remove prefix argument from archivers...
r11558 archiver = archivers[kind](dest, mtime or ctx.date()[0])
Matt Mackall
manifest: remove execf/linkf methods
r6749
Martin von Zweigbergk
archive: create alwaysmatcher when no matcher provided...
r40444 if not match:
match = scmutil.matchall(repo)
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 if repo.ui.configbool(b"ui", b"archivemeta"):
name = b'.hg_archival.txt'
Martin von Zweigbergk
archive: create alwaysmatcher when no matcher provided...
r40444 if match(name):
Gregory Szorc
global: mass rewrite to use modern octal syntax...
r25658 write(name, 0o644, False, lambda: buildmetadata(ctx))
Gilles Moris
archive: add branch and tag informations to the .hg_archival.txt file...
r9614
Augie Fackler
archival: use walk() instead of matches() on manifest...
r44766 files = list(ctx.manifest().walk(match))
Thomas Arendsen Hein
archive: make progress only show files that are actually archived...
r16919 total = len(files)
Angel Ezquerra
archive: raise error.Abort if the file pattern matches no files...
r18967 if total:
files.sort()
Augie Fackler
formatting: blacken the codebase...
r43346 scmutil.prefetchfiles(
Rodrigo Damazio Bovendorp
scmutil: allowing different files to be prefetched per revision...
r45632 repo, [(ctx.rev(), scmutil.matchfiles(repo, files))]
Augie Fackler
formatting: blacken the codebase...
r43346 )
progress = repo.ui.makeprogress(
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 _(b'archiving'), unit=_(b'files'), total=total
Augie Fackler
formatting: blacken the codebase...
r43346 )
Martin von Zweigbergk
archival: use progress helper...
r38400 progress.update(0)
for f in files:
Angel Ezquerra
archive: raise error.Abort if the file pattern matches no files...
r18967 ff = ctx.flags(f)
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 write(f, b'x' in ff and 0o755 or 0o644, b'l' in ff, ctx[f].data)
Martin von Zweigbergk
archival: use progress helper...
r38400 progress.increment(item=f)
progress.complete()
Martin Geisler
subrepo: add support for 'hg archive'
r12323
if subrepos:
Mads Kiilerich
subrepos: process subrepos in sorted order...
r18364 for subpath in sorted(ctx.substate):
Matt Harbison
archive: support 'wdir()'...
r25601 sub = ctx.workingsub(subpath)
Martin von Zweigbergk
archive: change "matcnfn" argument to a real matcher...
r40443 submatch = matchmod.subdirmatcher(subpath, match)
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 subprefix = prefix + subpath + b'/'
Martin von Zweigbergk
subrepo: adjust subrepo prefix before calling subrepo.archive() (API)...
r41780 total += sub.archive(archiver, subprefix, submatch, decode)
Angel Ezquerra
archive: raise error.Abort if the file pattern matches no files...
r18967
if total == 0:
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 raise error.Abort(_(b'no files match the archive pattern'))
Martin Geisler
subrepo: add support for 'hg archive'
r12323
Vadim Gelfer
add "archive" command, like "cvs export" only better....
r2112 archiver.done()
Angel Ezquerra
archive: raise error.Abort if the file pattern matches no files...
r18967 return total