A Scalable, User-Friendly Source Control System.
Go to file
Durham Goode b804c11020 smartlog: hide public heads when remote bookmarks are enabled
Summary:
If the user is using remote bookmarks, let's hide the public heads from the
smartlog output. This allows the server to do a non-fastward bookmark move,
without having the old heads cluttering the user's smartlog output.

Test Plan: Added a test

Reviewers: mitrandir, rmcelroy, ericsumner, lcharignon

Reviewed By: lcharignon

Differential Revision: https://phabricator.fb.com/D2264878

Signature: t1:2264878:1437505970:664348ed91ba8d8b1018299e282ed4308bfbdbc0
2015-07-21 11:32:27 -07:00
crecord crecord: update to latest default 2015-03-06 12:59:11 -08:00
scripts add hg-new-workdir 2015-05-13 13:15:59 -07:00
tests smartlog: hide public heads when remote bookmarks are enabled 2015-07-21 11:32:27 -07:00
.hgignore Add gitrevset support. 2014-09-08 15:36:12 -07:00
b2xcompat.py add an extension to support the HG2Y format 2015-04-07 11:37:55 -07:00
backups.py backups: make hg backups evolve aware 2015-05-20 12:29:09 -07:00
chistedit.py chistedit: language improvements 2014-11-07 09:34:29 -08:00
commitextras.py extras: add commitextras extension 2015-04-27 20:20:48 -07:00
COPYING Initial commit with extensions and readme 2014-06-02 12:54:54 -07:00
dbg.py dbg: an extension for a quick hg REPL 2015-02-24 10:50:23 -08:00
fbamend.py fbamend: when inhibit is not enabled, don't mark obsolescence twice 2015-07-10 15:32:41 -07:00
fbconduit.py support for multiple backing repos. 2015-07-15 14:48:57 -07:00
fbhistedit.py fbhistedit: wrap the loaded histedit 2015-05-01 15:06:09 -07:00
githelp.py fix some failing tests 2015-07-06 19:17:17 -07:00
gitlookup.py gitlookup: change back to b2x 2015-04-22 14:49:20 -07:00
gitrevset.py gitrevset: fix broken test caused by core's commit 48d6be2f1632 2015-05-07 17:46:30 -07:00
inhibitwarn.py inhibitwarn: improve error message 2015-07-10 15:41:21 -07:00
Makefile Initial commit: fbamend, smartlog 2013-06-20 12:16:36 -07:00
phabdiff.py Added phabdiff template mapping 2014-10-16 17:43:58 -07:00
phrevset.py phrevset: fix because of changes in core 2015-05-12 11:14:44 -07:00
pushrebase.py pushrebase: support creating new bookmarks 2015-07-13 22:01:02 -07:00
pushvars.py pushvars: fix integration with remotenames 2015-07-06 17:01:25 -07:00
rage.py Merge fbonly into default 2015-03-08 12:22:25 -07:00
README.md Merge fbonly into default 2015-03-08 12:22:25 -07:00
reflog.py Merge fbonly into default 2015-03-08 12:22:25 -07:00
reset.py reset: fix resetting past remote bookmarks 2015-07-10 11:40:30 -07:00
setup.py pushrebase: add to setup.py 2015-07-07 19:10:17 -07:00
simplecache.py simplecache: move memcache prefix to mcget/set 2015-06-15 17:19:08 -07:00
smartlog.py smartlog: hide public heads when remote bookmarks are enabled 2015-07-21 11:32:27 -07:00
sparse.py sparse: using mtime is unreliable for checksumming 2015-07-13 23:11:10 -07:00
tweakdefaults.py tweakdefaults: stop accidental branch command usage 2015-07-02 11:11:56 -07:00
upgradegeneraldelta.py upgradegeneraldelta: only upgrade before pulls 2014-12-18 12:43:32 -08:00
writecg2.py Import correct changegroup fix from upstream 2015-07-13 11:21:33 -07:00

hg-experimental

This is a collection of proof-of-concept Mercurial extensions written at Facebook. While they are all in basic use, they are considered experimental, are unsupported, and may or may not receive updates in the future. We're making them open source as examples of some better workflows we've been experimenting with.

Note that there will be extensions included here that only work with Facebook's infrastructure; they are included to give you an idea of how we integrate mercurial with our workflows.

smartlog

An extension that adds the 'hg smartlog' command. It prints graph log output containing only the commits relevant to yourself. Shows your bookmarks, the @ or master bookmark, and any draft commits without bookmarks that you've made within the past 2 weeks. Any commits in the graph that are skipped are represented by '...'.

We recommend also having an 'hg sl' alias that gives more concise output:

alias.sl=smartlog --template "{shortest(node)}  {author|user}  {bookmarks % '{ifeq(bookmark, current, label(\"yellow\", \" {bookmark}*\"), label(\"green\", \" {bookmark}\"))}'} {ifeq(branch, 'default', '', label(\"bold\", branch))}\n{desc|firstline}\n\n"

githelp

An extension that adds the 'hg githelp' command. It translates Git commands into Mercurial commands. Example:

$ hg githelp -- git rebase origin/master
  hg rebase -d master

$ hg githelp -- reset --hard HEAD^
  hg strip -r .

So it acts as a useful cheat sheet tool for people moving from Git to Mercurial.

backups

An extension that adds the 'hg backups' command. 'hg backups' prints a list of recently deleted commits (by reading your .hg/strip-backups directory) and allows you to recover a commit by doing 'hg backups --recover '. It prints the missing commits in reverse chronological order, and acts as a pseudo-replacement for Git's reflog.

fbamend

An extension that adds the 'hg amend --rebase' command. When working with a stack of commits, it's currently impossible to amend a commit in the middle of the stack. This extension enables that ability, adds a 'hg amend' command that invokes 'hg commit --amend', and adds a --rebase flag to 'hg amend --rebase' that rebase all the children of the commit onto the newly amended version.

If 'hg amend' is run on a commit in the middle of a stack without using --rebase, the amend succeeds and the old version of the commit is left behind with a marker bookmark on it 'bookmarkname(preamend)'. The user can then run 'hg amend --fixup' to post-humously rebase the children onto the new version of the commit.

chistedit

An interactive ncurses interface to histedit.

NOTE: This requires python-curses installed and Mercurial's histedit extension enabled.

This extensions allows you to interactively move around changesets or change the action to perform while keeping track of possible conflicts.

upgradegeneraldelta

Upgrades manifests to generaldelta in-place, without needing to reclone.

Contributing

Patches are welcome as pull requests, though they will be collapsed and rebased to maintain a linear history.

We (Facebook) have to ask for a "Contributor License Agreement" from someone who sends in a patch or code that we want to include in the codebase. This is a legal requirement; a similar situation applies to Apache and other ASF projects.

If we ask you to fill out a CLA we'll direct you to our online CLA page where you can complete it easily. We use the same form as the Apache CLA so that friction is minimal.

License

These extensions are made available under the terms of the GNU General Public License version 2, or any later version. See the COPYING file that accompanies this distribution for the full text of the license.