Added more to the README.
    
        | author | Steve Losh <steve@stevelosh.com> | 
    
        | date | Fri, 19 Jun 2009 22:09:21 -0400 | 
    
        | parents | c4ce712862c3 | 
    
        | children | 10cfd4478857 | 
-*- markdown -*-
hg-prompt
=========
hg-prompt is an extension for Mercurial which adds an 'hg prompt' command for putting repository information into a shell prompt efficiently.
Installing
----------
Clone the repository:
    $ hg clone hg clone https://sjl@bitbucket.org/sjl/hg-prompt/
Edit the `[extensions]` section in your `~/.hgrc` file:
    [extensions]
    prompt = (path to)/hg-prompt/prompt.py
Using the Command
-----------------
The `hg prompt` command takes a single string as an argument and outputs it.  A simple (and useless) example:
    $ hg prompt "test"
    test
Keywords in curly braces can be used to output repository information:
    $ hg prompt "currently on {branch}"
    currently on default
Keywords also have an extended form:
    {optional text{branch}more optional text}
This form will output the text and the expanded keyword **only** if the keyword successfully expands.  This can be useful for displaying extra text only if it's applicable:
    $ hg prompt "currently on {branch} and at {bookmark}"
    currently on branch default and at 
    
    $ hg prompt "currently on {branch} {and at {bookmark}}"
    currently on branch default 
    
    $ hg bookmark my-book
    
    $ hg prompt "currently on {branch} {and at {bookmark}}"
    currently on branch default and at my-book
Available Keywords
------------------
There are only a few keywords at the moment (mostly the ones I want for myself).  If you have any suggestions for more please let me know.
* bookmark: the current bookmark
* branch: the current branch
* status:
    * `!` if the repository has any changed, added, removed or deleted files, otherwise
    * `?` if the repository has any untracked (but not ignored) files, otherwise
    * nothing
Putting it in a Bash Prompt
---------------------------
To put it in your bash prompt, edit your `~/.bashrc` file to include something like this:
    hg_ps1() {
        hg prompt "{ on {branch}}{ at {bookmark}}{status}" 2> /dev/null
    }
    
    export PS1='\u at \h in \w$(hg_ps1) $ '
Putting the call in a separate function helps keep things readable if you start adding color codes:
    D=$'\e[37;40m'
    MAGENTA=$'\e[35;40m'
    GREEN=$'\e[32;40m'
    YELLOW=$'\e[33;40m'
    hg_ps1() {
        hg prompt "{${D} on ${MAGENTA}{branch}}{${D} at ${YELLOW}{bookmark}}{${GREEN}{status}}" 2> /dev/null
    }
    export PS1='\n${MAGENTA}\u ${D}at ${YELLOW}\h ${D}in ${GREEN}\w$(hg_ps1)\
    ${D}\n$ '