pager.py
113 lines
| 3.7 KiB
| text/x-python
|
PythonLexer
/ hgext / pager.py
David Soria Parra
|
r6323 | # pager.py - display output using a pager | ||
# | ||||
# Copyright 2008 David Soria Parra <dsp@php.net> | ||||
# | ||||
Martin Geisler
|
r8225 | # This software may be used and distributed according to the terms of the | ||
Matt Mackall
|
r10263 | # GNU General Public License version 2 or any later version. | ||
David Soria Parra
|
r6323 | # | ||
Brodie Rao
|
r12083 | # To load the extension, add it to your configuration file: | ||
David Soria Parra
|
r6323 | # | ||
# [extension] | ||||
Martin Geisler
|
r10112 | # pager = | ||
David Soria Parra
|
r6323 | # | ||
timeless
|
r29967 | # Run 'hg help pager' to get info on configuration. | ||
Christian Ebert
|
r6462 | |||
Cédric Duval
|
r8894 | '''browse command output with an external pager | ||
Christian Ebert
|
r6462 | |||
Martin Geisler
|
r9212 | To set the pager that should be used, set the application variable:: | ||
Christian Ebert
|
r6462 | |||
[pager] | ||||
Thomas Arendsen Hein
|
r17305 | pager = less -FRX | ||
Christian Ebert
|
r6462 | |||
Martin Geisler
|
r9267 | If no pager is set, the pager extensions uses the environment variable | ||
$PAGER. If neither pager.pager, nor $PAGER is set, no pager is used. | ||||
Christian Ebert
|
r6462 | |||
You can disable the pager for certain commands by adding them to the | ||||
Martin Geisler
|
r9212 | pager.ignore list:: | ||
Christian Ebert
|
r6462 | |||
[pager] | ||||
ignore = version, help, update | ||||
Martin Geisler
|
r9267 | You can also enable the pager only for certain commands using | ||
Brodie Rao
|
r9841 | pager.attend. Below is the default list of commands to be paged:: | ||
Christian Ebert
|
r6462 | |||
[pager] | ||||
Brodie Rao
|
r9841 | attend = annotate, cat, diff, export, glog, log, qdiff | ||
Setting pager.attend to an empty value will cause all commands to be | ||||
paged. | ||||
Christian Ebert
|
r6462 | |||
If pager.attend is present, pager.ignore will be ignored. | ||||
Matt Mackall
|
r21281 | Lastly, you can enable and disable paging for individual commands with | ||
the attend-<command> option. This setting takes precedence over | ||||
existing attend and ignore options and defaults:: | ||||
[pager] | ||||
attend-cat = false | ||||
Martin Geisler
|
r10973 | To ignore global commands like :hg:`version` or :hg:`help`, you have | ||
Brodie Rao
|
r12083 | to specify them in your user configuration file. | ||
Brodie Rao
|
r12694 | |||
timeless
|
r27128 | To control whether the pager is used at all for an individual command, | ||
you can use --pager=<value>:: | ||||
- use as needed: `auto`. | ||||
- require the pager: `yes` or `on`. | ||||
- suppress the pager: `no` or `off` (any unrecognized value | ||||
will also work). | ||||
Matt Mackall
|
r21281 | |||
Christian Ebert
|
r6462 | ''' | ||
Augie Fackler
|
r28320 | from __future__ import absolute_import | ||
David Soria Parra
|
r6323 | |||
Augie Fackler
|
r28320 | from mercurial import ( | ||
cmdutil, | ||||
commands, | ||||
dispatch, | ||||
extensions, | ||||
) | ||||
David Soria Parra
|
r6323 | |||
Augie Fackler
|
r29841 | # Note for extension authors: ONLY specify testedwith = 'ships-with-hg-core' for | ||
Augie Fackler
|
r25186 | # extensions which SHIP WITH MERCURIAL. Non-mainline extensions should | ||
# be specifying the version(s) of Mercurial they are tested with, or | ||||
# leave the attribute unspecified. | ||||
Augie Fackler
|
r29841 | testedwith = 'ships-with-hg-core' | ||
Augie Fackler
|
r16743 | |||
David Soria Parra
|
r6323 | def uisetup(ui): | ||
Jun Wu
|
r30722 | |||
Matt Mackall
|
r7216 | def pagecmd(orig, ui, options, cmd, cmdfunc): | ||
Matt Mackall
|
r21279 | auto = options['pager'] == 'auto' | ||
Augie Fackler
|
r30993 | if auto and not ui.pageractive: | ||
Matt Mackall
|
r21279 | usepager = False | ||
Brodie Rao
|
r9841 | attend = ui.configlist('pager', 'attend', attended) | ||
Matt Mackall
|
r21280 | ignore = ui.configlist('pager', 'ignore') | ||
David Soria Parra
|
r19940 | cmds, _ = cmdutil.findcmd(cmd, commands.table) | ||
for cmd in cmds: | ||||
Matt Mackall
|
r21281 | var = 'attend-%s' % cmd | ||
if ui.config('pager', var): | ||||
usepager = ui.configbool('pager', var) | ||||
break | ||||
Matt Mackall
|
r21279 | if (cmd in attend or | ||
(cmd not in ignore and not attend)): | ||||
Matt Mackall
|
r21277 | usepager = True | ||
David Soria Parra
|
r19940 | break | ||
Matt Mackall
|
r21277 | |||
Augie Fackler
|
r30993 | if usepager: | ||
Augie Fackler
|
r30995 | # Slight hack: the attend list is supposed to override | ||
# the ignore list for the pager extension, but the | ||||
# core code doesn't know about attend, so we have to | ||||
# lobotomize the ignore list so that the extension's | ||||
# behavior is preserved. | ||||
ui.setconfig('pager', 'ignore', '', 'pager') | ||||
Augie Fackler
|
r30993 | ui.pager('extension-via-attend-' + cmd) | ||
Matt Mackall
|
r7216 | return orig(ui, options, cmd, cmdfunc) | ||
David Soria Parra <dsp <at> php.net>
|
r6417 | |||
Gregory Szorc
|
r24067 | # Wrap dispatch._runcommand after color is loaded so color can see | ||
# ui.pageractive. Otherwise, if we loaded first, color's wrapped | ||||
# dispatch._runcommand would run without having access to ui.pageractive. | ||||
def afterloaded(loaded): | ||||
extensions.wrapfunction(dispatch, '_runcommand', pagecmd) | ||||
extensions.afterloaded('color', afterloaded) | ||||
Brodie Rao
|
r9841 | |||
Augie Fackler
|
r31031 | attended = ['glog', 'log', 'qdiff'] | ||