2010-07-20 21:59:49 +04:00
|
|
|
# debugshell extension
|
|
|
|
"""a python shell with repo, changelog & manifest objects"""
|
|
|
|
|
2016-03-06 00:49:08 +03:00
|
|
|
from __future__ import absolute_import
|
2010-07-20 21:59:49 +04:00
|
|
|
import code
|
2016-03-06 00:49:08 +03:00
|
|
|
import sys
|
2018-01-17 23:54:24 +03:00
|
|
|
import mercurial
|
2018-05-23 09:25:25 +03:00
|
|
|
|
|
|
|
from mercurial.i18n import _
|
2016-01-12 05:16:38 +03:00
|
|
|
from mercurial import (
|
|
|
|
demandimport,
|
2016-01-09 17:07:20 +03:00
|
|
|
registrar,
|
2016-01-12 05:16:38 +03:00
|
|
|
)
|
2014-05-05 08:19:31 +04:00
|
|
|
|
|
|
|
cmdtable = {}
|
2016-01-09 17:07:20 +03:00
|
|
|
command = registrar.command(cmdtable)
|
2010-07-20 21:59:49 +04:00
|
|
|
|
2018-04-18 02:21:19 +03:00
|
|
|
def _assignobjects(objects, repo):
|
|
|
|
objects.update({
|
2018-04-18 02:21:22 +03:00
|
|
|
'm': mercurial,
|
2010-07-20 21:59:49 +04:00
|
|
|
'mercurial': mercurial,
|
2018-04-18 02:21:19 +03:00
|
|
|
})
|
2018-04-18 02:21:16 +03:00
|
|
|
if repo:
|
|
|
|
objects.update({
|
|
|
|
'repo': repo,
|
|
|
|
'cl': repo.changelog,
|
|
|
|
'mf': repo.manifestlog,
|
|
|
|
})
|
2013-07-14 21:10:52 +04:00
|
|
|
|
2018-04-18 02:21:19 +03:00
|
|
|
def pdb(ui, repo, msg, **opts):
|
|
|
|
objects = {}
|
|
|
|
_assignobjects(objects, repo)
|
2013-07-14 21:10:52 +04:00
|
|
|
code.interact(msg, local=objects)
|
|
|
|
|
2013-07-14 21:02:36 +04:00
|
|
|
def ipdb(ui, repo, msg, **opts):
|
|
|
|
import IPython
|
2018-04-18 02:21:19 +03:00
|
|
|
_assignobjects(locals(), repo)
|
2013-07-14 21:02:36 +04:00
|
|
|
IPython.embed()
|
|
|
|
|
2018-05-23 09:25:25 +03:00
|
|
|
@command('debugshell|dbsh', [
|
|
|
|
('c', 'command', '', _('program passed in as string'), _('CMD'))
|
|
|
|
], optionalrepo=True)
|
2013-07-14 21:10:52 +04:00
|
|
|
def debugshell(ui, repo, **opts):
|
2018-05-23 09:25:25 +03:00
|
|
|
command = opts.get('command')
|
|
|
|
if command:
|
|
|
|
_assignobjects(locals(), repo)
|
|
|
|
exec(command)
|
|
|
|
return 0
|
|
|
|
|
2010-07-20 21:59:49 +04:00
|
|
|
bannermsg = "loaded repo : %s\n" \
|
2018-04-18 02:21:16 +03:00
|
|
|
"using source: %s" % (repo and repo.root or '(none)',
|
2010-07-20 21:59:49 +04:00
|
|
|
mercurial.__path__[0])
|
2013-07-14 21:10:52 +04:00
|
|
|
|
2013-07-14 21:16:40 +04:00
|
|
|
pdbmap = {
|
|
|
|
'pdb' : 'code',
|
|
|
|
'ipdb' : 'IPython'
|
|
|
|
}
|
|
|
|
|
|
|
|
debugger = ui.config("ui", "debugger")
|
|
|
|
if not debugger:
|
|
|
|
debugger = 'pdb'
|
|
|
|
|
|
|
|
# if IPython doesn't exist, fallback to code.interact
|
|
|
|
try:
|
2016-01-12 05:16:38 +03:00
|
|
|
with demandimport.deactivated():
|
|
|
|
__import__(pdbmap[debugger])
|
2013-07-14 21:16:40 +04:00
|
|
|
except ImportError:
|
check-code: detect "missing _() in ui message" more exactly
Before this patch, "missing _() in ui message" rule overlooks
translatable message, which starts with other than alphabet.
To detect "missing _() in ui message" more exactly, this patch
improves the regexp with assumptions below.
- sequence consisting of below might precede "translatable message"
in same string token
- formatting string, which starts with '%'
- escaped character, which starts with 'b' (as replacement of '\\'), or
- characters other than '%', 'b' and 'x' (as replacement of alphabet)
- any string tokens might precede a string token, which contains
"translatable message"
This patch builds an input file, which is used to examine "missing _()
in ui message" detection, before '"$check_code" stringjoin.py' in
test-contrib-check-code.t, because this reduces amount of change churn
in subsequent patch.
This patch also applies "()" instead of "_()" on messages below to
hide false-positives:
- messages for ui.debug() or debug commands/tools
- contrib/debugshell.py
- hgext/win32mbcs.py (ui.write() is used, though)
- mercurial/commands.py
- _debugchangegroup
- debugindex
- debuglocks
- debugrevlog
- debugrevspec
- debugtemplate
- untranslatable messages
- doc/gendoc.py (ReST specific text)
- hgext/hgk.py (permission string)
- hgext/keyword.py (text written into configuration file)
- mercurial/cmdutil.py (formatting strings for JSON)
2016-06-20 18:50:39 +03:00
|
|
|
ui.warn(("%s debugger specified but %s module was not found\n")
|
2013-07-14 21:16:40 +04:00
|
|
|
% (debugger, pdbmap[debugger]))
|
|
|
|
debugger = 'pdb'
|
|
|
|
|
|
|
|
getattr(sys.modules[__name__], debugger)(ui, repo, bannermsg, **opts)
|