purge.py
127 lines
| 4.1 KiB
| text/x-python
|
PythonLexer
/ hgext / purge.py
Emanuele Aina
|
r4311 | # Copyright (C) 2006 - Marco Barisione <marco@barisione.org> | ||
# | ||||
Matt Mackall
|
r26421 | # This is a small extension for Mercurial (https://mercurial-scm.org/) | ||
Emanuele Aina
|
r4311 | # that removes files not known to mercurial | ||
# | ||||
Martin Geisler
|
r9270 | # This program was inspired by the "cvspurge" script contained in CVS | ||
# utilities (http://www.red-bean.com/cvsutils/). | ||||
Emanuele Aina
|
r4311 | # | ||
# For help on the usage of "hg purge" use: | ||||
# hg help purge | ||||
# | ||||
# This program is free software; you can redistribute it and/or modify | ||||
# it under the terms of the GNU General Public License as published by | ||||
# the Free Software Foundation; either version 2 of the License, or | ||||
# (at your option) any later version. | ||||
# | ||||
# This program is distributed in the hope that it will be useful, | ||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||||
# GNU General Public License for more details. | ||||
# | ||||
# You should have received a copy of the GNU General Public License | ||||
Martin Geisler
|
r15782 | # along with this program; if not, see <http://www.gnu.org/licenses/>. | ||
Emanuele Aina
|
r4311 | |||
Dirkjan Ochtman
|
r8934 | '''command to delete untracked files from the working directory''' | ||
timeless
|
r28382 | from __future__ import absolute_import | ||
Dirkjan Ochtman
|
r8873 | |||
Yuya Nishihara
|
r29205 | from mercurial.i18n import _ | ||
timeless
|
r28382 | from mercurial import ( | ||
Yuya Nishihara
|
r32375 | cmdutil, | ||
Gregory Szorc
|
r39499 | merge as mergemod, | ||
Augie Fackler
|
r36589 | pycompat, | ||
Yuya Nishihara
|
r32337 | registrar, | ||
timeless
|
r28382 | scmutil, | ||
) | ||||
Emanuele Aina
|
r4311 | |||
Adrian Buehlmann
|
r14310 | cmdtable = {} | ||
Yuya Nishihara
|
r32337 | command = registrar.command(cmdtable) | ||
Augie Fackler
|
r29841 | # Note for extension authors: ONLY specify testedwith = 'ships-with-hg-core' for | ||
Augie Fackler
|
r25186 | # extensions which SHIP WITH MERCURIAL. Non-mainline extensions should | ||
# be specifying the version(s) of Mercurial they are tested with, or | ||||
# leave the attribute unspecified. | ||||
Augie Fackler
|
r43347 | testedwith = b'ships-with-hg-core' | ||
Adrian Buehlmann
|
r14310 | |||
Augie Fackler
|
r43346 | |||
@command( | ||||
Augie Fackler
|
r43347 | b'purge|clean', | ||
Augie Fackler
|
r43346 | [ | ||
Augie Fackler
|
r43347 | (b'a', b'abort-on-err', None, _(b'abort if an error occurs')), | ||
(b'', b'all', None, _(b'purge ignored files too')), | ||||
(b'', b'dirs', None, _(b'purge empty directories')), | ||||
(b'', b'files', None, _(b'purge files')), | ||||
(b'p', b'print', None, _(b'print filenames instead of deleting them')), | ||||
Augie Fackler
|
r43346 | ( | ||
Augie Fackler
|
r43347 | b'0', | ||
b'print0', | ||||
Augie Fackler
|
r43346 | None, | ||
_( | ||||
Augie Fackler
|
r43347 | b'end filenames with NUL, for use with xargs' | ||
b' (implies -p/--print)' | ||||
Augie Fackler
|
r43346 | ), | ||
), | ||||
] | ||||
+ cmdutil.walkopts, | ||||
Augie Fackler
|
r43347 | _(b'hg purge [OPTION]... [DIR]...'), | ||
Augie Fackler
|
r43346 | helpcategory=command.CATEGORY_MAINTENANCE, | ||
) | ||||
Matt Mackall
|
r6573 | def purge(ui, repo, *dirs, **opts): | ||
Benjamin Pollack
|
r7605 | '''removes files not tracked by Mercurial | ||
Matt Mackall
|
r6573 | |||
Martin Geisler
|
r9270 | Delete files not known to Mercurial. This is useful to test local | ||
and uncommitted changes in an otherwise-clean source tree. | ||||
Matt Mackall
|
r6573 | |||
Ben Kehoe
|
r21853 | This means that purge will delete the following by default: | ||
Martin Geisler
|
r9215 | |||
Martin Geisler
|
r10973 | - Unknown files: files marked with "?" by :hg:`status` | ||
Martin Geisler
|
r9270 | - Empty directories: in fact Mercurial ignores directories unless | ||
they contain files under source control management | ||||
Martin Geisler
|
r9215 | |||
Matt Mackall
|
r6573 | But it will leave untouched: | ||
Martin Geisler
|
r9215 | |||
- Modified and unmodified tracked files | ||||
- Ignored files (unless --all is specified) | ||||
Martin Geisler
|
r10973 | - New files added to the repository (with :hg:`add`) | ||
Matt Mackall
|
r6573 | |||
Ben Kehoe
|
r21853 | The --files and --dirs options can be used to direct purge to delete | ||
only files, only directories, or both. If neither option is given, | ||||
both will be deleted. | ||||
Matt Mackall
|
r6573 | If directories are given on the command line, only files in these | ||
directories are considered. | ||||
Martin Geisler
|
r9270 | Be careful with purge, as you could irreversibly delete some files | ||
you forgot to add to the repository. If you only want to print the | ||||
list of files that this program would delete, use the --print | ||||
option. | ||||
Matt Mackall
|
r6573 | ''' | ||
Augie Fackler
|
r36589 | opts = pycompat.byteskwargs(opts) | ||
Gregory Szorc
|
r39499 | |||
Augie Fackler
|
r43347 | act = not opts.get(b'print') | ||
eol = b'\n' | ||||
if opts.get(b'print0'): | ||||
eol = b'\0' | ||||
Augie Fackler
|
r43346 | act = False # --print0 implies --print | ||
Gregory Szorc
|
r39499 | |||
Augie Fackler
|
r43347 | removefiles = opts.get(b'files') | ||
removedirs = opts.get(b'dirs') | ||||
Gregory Szorc
|
r39499 | |||
Ben Kehoe
|
r21853 | if not removefiles and not removedirs: | ||
removefiles = True | ||||
removedirs = True | ||||
Emanuele Aina
|
r4311 | |||
Gregory Szorc
|
r39499 | match = scmutil.match(repo[None], dirs, opts) | ||
Emanuele Aina
|
r4311 | |||
Gregory Szorc
|
r39499 | paths = mergemod.purge( | ||
Augie Fackler
|
r43346 | repo, | ||
match, | ||||
Augie Fackler
|
r43347 | ignored=opts.get(b'all', False), | ||
Augie Fackler
|
r43346 | removeemptydirs=removedirs, | ||
removefiles=removefiles, | ||||
Augie Fackler
|
r43347 | abortonerror=opts.get(b'abort_on_err'), | ||
Augie Fackler
|
r43346 | noop=not act, | ||
) | ||||
Emanuele Aina
|
r4311 | |||
Gregory Szorc
|
r39499 | for path in paths: | ||
if not act: | ||||
Augie Fackler
|
r43347 | ui.write(b'%s%s' % (path, eol)) | ||