contrib/debugshell.py
author Matt Mackall <mpm@selenic.com>
Sat, 18 Jun 2011 17:03:01 -0500
branchstable
changeset 14687 15200b46165b
parent 11633 6b7b99867ada
child 19771 3bc675361206
permissions -rw-r--r--
merge default branch into stable to mark the start of the code freeze

# debugshell extension
"""a python shell with repo, changelog & manifest objects"""

import mercurial
import code

def debugshell(ui, repo, **opts):
    objects = {
        'mercurial': mercurial,
        'repo': repo,
        'cl': repo.changelog,
        'mf': repo.manifest,
    }
    bannermsg = "loaded repo : %s\n" \
                "using source: %s" % (repo.root,
                                      mercurial.__path__[0])
    code.interact(bannermsg, local=objects)

cmdtable = {
    "debugshell|dbsh": (debugshell, [])
}