D4125: narrow: add '--extend' flag to tracked command
pulkit (Pulkit Goyal)
phabricator at mercurial-scm.org
Mon Aug 6 11:07:48 UTC 2018
pulkit created this revision.
Herald added a reviewer: durin42.
Herald added a subscriber: mercurial-devel.
Herald added a reviewer: hg-reviewers.
REVISION SUMMARY
This patch adds a `--extend` flag to tracked command provided by narrow
extension. Using the --extend flag, you can pass a filename from which
narrowspecs should be read and added to main narrowspec.
A lot of times, in automation or manually also, when you are working with big
repo, specifying each path name on commandline using '--addinclude' and
'--addexclude' is tedious and something which can scale. So we needed something
where we can pass a file to extend the narrowspecs.
Nice thing about this is that the automations which reads some file to change
the sparse profile, can now read the same file for changing narrowspecs too.
Tests are added for the new feature.
REPOSITORY
rHG Mercurial
REVISION DETAIL
https://phab.mercurial-scm.org/D4125
AFFECTED FILES
hgext/narrow/narrowcommands.py
tests/test-narrow-trackedcmd.t
CHANGE DETAILS
diff --git a/tests/test-narrow-trackedcmd.t b/tests/test-narrow-trackedcmd.t
new file mode 100644
--- /dev/null
+++ b/tests/test-narrow-trackedcmd.t
@@ -0,0 +1,197 @@
+ $ . "$TESTDIR/narrow-library.sh"
+
+ $ cat << EOF >> $HGRCPATH
+ > [experimental]
+ > treemanifest = 1
+ > EOF
+
+ $ hg init master
+ $ cd master
+ $ cat >> .hg/hgrc <<EOF
+ > [narrow]
+ > serveellipses=True
+ > EOF
+
+ $ mkdir inside
+ $ echo 'inside' > inside/f
+ $ hg add inside/f
+ $ hg commit -m 'add inside'
+
+ $ mkdir widest
+ $ echo 'widest' > widest/f
+ $ hg add widest/f
+ $ hg commit -m 'add widest'
+
+ $ mkdir outside
+ $ echo 'outside' > outside/f
+ $ hg add outside/f
+ $ hg commit -m 'add outside'
+
+ $ cd ..
+
+narrow clone the inside file
+
+ $ hg clone --narrow ssh://user@dummy/master narrow --include inside
+ requesting all changes
+ adding changesets
+ adding manifests
+ adding file changes
+ added 2 changesets with 1 changes to 1 files
+ new changesets *:* (glob)
+ updating to branch default
+ 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
+ $ cd narrow
+ $ hg tracked
+ I path:inside
+ $ ls
+ inside
+ $ cat inside/f
+ inside
+ $ cd ..
+
+add more upstream files which we will include in a wider narrow spec
+
+ $ cd master
+
+ $ mkdir wider
+ $ echo 'wider' > wider/f
+ $ hg add wider/f
+ $ echo 'widest v2' > widest/f
+ $ hg commit -m 'add wider, update widest'
+
+ $ echo 'widest v3' > widest/f
+ $ hg commit -m 'update widest v3'
+
+ $ echo 'inside v2' > inside/f
+ $ hg commit -m 'update inside'
+
+ $ mkdir outside2
+ $ echo 'outside2' > outside2/f
+ $ hg add outside2/f
+ $ hg commit -m 'add outside2'
+
+ $ echo 'widest v4' > widest/f
+ $ hg commit -m 'update widest v4'
+
+ $ hg log -T "{if(ellipsis, '...')}{node|short}: {desc}\n"
+ *: update widest v4 (glob)
+ *: add outside2 (glob)
+ *: update inside (glob)
+ *: update widest v3 (glob)
+ *: add wider, update widest (glob)
+ *: add outside (glob)
+ *: add widest (glob)
+ *: add inside (glob)
+
+ $ cd ..
+
+Testing the --extend flag of `hg tracked` command
+
+ $ cd narrow
+ $ hg tracked --extend
+ hg tracked: option --extend requires argument
+ hg tracked [OPTIONS]... [REMOTE]
+
+ show or change the current narrowspec
+
+ options ([+] can be repeated):
+
+ --addinclude VALUE [+] new paths to include
+ --removeinclude VALUE [+] old paths to no longer include
+ --addexclude VALUE [+] new paths to exclude
+ --extend VALUE file to read to extend the narrowspec
+ --removeexclude VALUE [+] old paths to no longer exclude
+ --clear whether to replace the existing narrowspec
+ --force-delete-local-changes forces deletion of local changes when
+ narrowing
+ -e --ssh CMD specify ssh command to use
+ --remotecmd CMD specify hg command to run on the remote side
+ --insecure do not verify server certificate (ignoring
+ web.cacerts config)
+
+ (use 'hg tracked -h' to show more help)
+ [255]
+ $ hg tracked --extend doesnotexist
+ abort: file 'doesnotexist' not found in current working directory
+ [255]
+
+ $ cat >> specs <<EOF
+ > %include foo
+ > [include]
+ > path:widest/
+ > [exclude]
+ > path:inside/
+ > EOF
+
+ $ hg tracked --extend specs
+ abort: including other spec files using '%include' is not supported in narrowspec
+ [255]
+
+ $ cat > specs <<EOF
+ > [include]
+ > outisde
+ > [exclude]
+ > inside
+ > EOF
+
+ $ hg tracked --extend specs
+ comparing with ssh://user@dummy/master
+ searching for changes
+ looking for local changes to affected paths
+ deleting data/inside/f.i
+ deleting meta/inside/00manifest.i
+ no changes found
+ saved backup bundle to $TESTTMP/narrow/.hg/strip-backup/*-widen.hg (glob)
+ adding changesets
+ adding manifests
+ adding file changes
+ added 2 changesets with 0 changes to 0 files
+ new changesets *:* (glob)
+ $ hg tracked
+ I path:outisde
+ X path:inside
+
+Testing the --extend flag with --addinclude and --addexclude
+
+ $ cat > specs <<EOF
+ > [include]
+ > widest
+ > EOF
+
+ $ hg tracked --extend specs --addinclude 'wider/'
+ comparing with ssh://user@dummy/master
+ searching for changes
+ no changes found
+ saved backup bundle to $TESTTMP/narrow/.hg/strip-backup/*-widen.hg (glob)
+ adding changesets
+ adding manifests
+ adding file changes
+ added 3 changesets with 1 changes to 1 files
+ new changesets *:* (glob)
+ $ hg tracked
+ I path:outisde
+ I path:wider
+ I path:widest
+ X path:inside
+
+ $ cat > specs <<EOF
+ > [exclude]
+ > outside2
+ > EOF
+
+ $ hg tracked --extend specs --addexclude 'widest'
+ comparing with ssh://user@dummy/master
+ searching for changes
+ looking for local changes to affected paths
+ deleting data/widest/f.i
+ deleting meta/widest/00manifest.i
+ $ hg tracked
+ I path:outisde
+ I path:wider
+ X path:inside
+ X path:outside2
+ X path:widest
+
+ $ hg tracked --extend specs --clear
+ The --clear option is not yet supported.
+ [1]
diff --git a/hgext/narrow/narrowcommands.py b/hgext/narrow/narrowcommands.py
--- a/hgext/narrow/narrowcommands.py
+++ b/hgext/narrow/narrowcommands.py
@@ -25,6 +25,7 @@
repair,
repository,
repoview,
+ sparse,
util,
)
@@ -299,6 +300,7 @@
[('', 'addinclude', [], _('new paths to include')),
('', 'removeinclude', [], _('old paths to no longer include')),
('', 'addexclude', [], _('new paths to exclude')),
+ ('', 'extend', '', _('file to read to extend the narrowspec')),
('', 'removeexclude', [], _('old paths to no longer exclude')),
('', 'clear', False, _('whether to replace the existing narrowspec')),
('', 'force-delete-local-changes', False,
@@ -342,6 +344,23 @@
ui.warn(_('The --clear option is not yet supported.\n'))
return 1
+ # extend the narrowspec by reading narrowspecs from a file in working
+ # directory
+ extend = opts.get('extend')
+ if extend:
+ try:
+ fdata = repo[None][extend].data()
+ except IOError:
+ raise error.Abort(_("file '%s' not found in current working"
+ " directory") % extend)
+ includepats, excludepats, profiles = sparse.parseconfig(ui, fdata,
+ 'narrow')
+ if profiles:
+ raise error.Abort(_("including other spec files using '%include' "
+ "is not supported in narrowspec"))
+ opts['addinclude'].extend(list(includepats))
+ opts['addexclude'].extend(list(excludepats))
+
if narrowspec.needsexpansion(opts['addinclude'] + opts['addexclude']):
raise error.Abort('Expansion not yet supported on widen/narrow')
To: pulkit, durin42, #hg-reviewers
Cc: mercurial-devel
More information about the Mercurial-devel
mailing list