Merging Graphlog in Core

1. Done

With these submitted patches, graphlog supports the same options as log command, and we can consider merging boths:

1.1. http://selenic.com/pipermail/mercurial-devel/2012-February/038269.html

http://selenic.com/pipermail/mercurial-devel/2012-February/038269.html

1.2. http://selenic.com/pipermail/mercurial-devel/2012-March/038869.html

http://selenic.com/pipermail/mercurial-devel/2012-March/038869.html

* Improve --only-branch * Support old-style --rev

1.3. http://selenic.com/pipermail/mercurial-devel/2012-April/039148.html

http://selenic.com/pipermail/mercurial-devel/2012-April/039148.html

* Refactor graphlog.revset() to return revisions * Fix --follow/--follow-first again * Fix --branch lookup * Fix calls in subdirectories * Fix performance regression related to the order of evaluation of changesets in revsets

2. To Do

2.1. log command

  1. Implement --hidden. At this point, the revset version is feature complete and pass all tests.
  2. Turn revset.match() into a generator. Otherwise the time to first byte with --limit queries is too large.
  3. Maybe invent something to handle multiple predicated like "--user foo --user bar" without scanning the changelog multiple times.
  4. Think a bit about killing hgext/graphlog.py, compatibility and perhaps leaving stubs here.
  5. Profit!

2.2. incoming/outgoing commands

  1. Decide what to do about --newest-first
  2. ? Look at hg._incoming()/_outgoing() (recurse in subrepos ?)

2.3. random improvements

  1. Improve the error message on --follow FILE --removed, issue2139

  2. Document that "hg log 'set:added()'" is not the same than "hg log -r 'file("set:added()")'"
  3. Mention filesets in "hg help patterns" before the last line
  4. Display renames correctly with "hg log --follow file", see the second part of this changelog for details


CategoryAudit