##// END OF EJS Templates
pager: make example of setting pager less silly
Kevin Bullock -
r12892:919c4408 stable
parent child Browse files
Show More
@@ -1,113 +1,113
1 # pager.py - display output using a pager
1 # pager.py - display output using a pager
2 #
2 #
3 # Copyright 2008 David Soria Parra <dsp@php.net>
3 # Copyright 2008 David Soria Parra <dsp@php.net>
4 #
4 #
5 # This software may be used and distributed according to the terms of the
5 # This software may be used and distributed according to the terms of the
6 # GNU General Public License version 2 or any later version.
6 # GNU General Public License version 2 or any later version.
7 #
7 #
8 # To load the extension, add it to your configuration file:
8 # To load the extension, add it to your configuration file:
9 #
9 #
10 # [extension]
10 # [extension]
11 # pager =
11 # pager =
12 #
12 #
13 # Run "hg help pager" to get info on configuration.
13 # Run "hg help pager" to get info on configuration.
14
14
15 '''browse command output with an external pager
15 '''browse command output with an external pager
16
16
17 To set the pager that should be used, set the application variable::
17 To set the pager that should be used, set the application variable::
18
18
19 [pager]
19 [pager]
20 pager = LESS='FSRX' less
20 pager = less -FRSX
21
21
22 If no pager is set, the pager extensions uses the environment variable
22 If no pager is set, the pager extensions uses the environment variable
23 $PAGER. If neither pager.pager, nor $PAGER is set, no pager is used.
23 $PAGER. If neither pager.pager, nor $PAGER is set, no pager is used.
24
24
25 If you notice "BROKEN PIPE" error messages, you can disable them by
25 If you notice "BROKEN PIPE" error messages, you can disable them by
26 setting::
26 setting::
27
27
28 [pager]
28 [pager]
29 quiet = True
29 quiet = True
30
30
31 You can disable the pager for certain commands by adding them to the
31 You can disable the pager for certain commands by adding them to the
32 pager.ignore list::
32 pager.ignore list::
33
33
34 [pager]
34 [pager]
35 ignore = version, help, update
35 ignore = version, help, update
36
36
37 You can also enable the pager only for certain commands using
37 You can also enable the pager only for certain commands using
38 pager.attend. Below is the default list of commands to be paged::
38 pager.attend. Below is the default list of commands to be paged::
39
39
40 [pager]
40 [pager]
41 attend = annotate, cat, diff, export, glog, log, qdiff
41 attend = annotate, cat, diff, export, glog, log, qdiff
42
42
43 Setting pager.attend to an empty value will cause all commands to be
43 Setting pager.attend to an empty value will cause all commands to be
44 paged.
44 paged.
45
45
46 If pager.attend is present, pager.ignore will be ignored.
46 If pager.attend is present, pager.ignore will be ignored.
47
47
48 To ignore global commands like :hg:`version` or :hg:`help`, you have
48 To ignore global commands like :hg:`version` or :hg:`help`, you have
49 to specify them in your user configuration file.
49 to specify them in your user configuration file.
50
50
51 The --pager=... option can also be used to control when the pager is
51 The --pager=... option can also be used to control when the pager is
52 used. Use a boolean value like yes, no, on, off, or use auto for
52 used. Use a boolean value like yes, no, on, off, or use auto for
53 normal behavior.
53 normal behavior.
54 '''
54 '''
55
55
56 import sys, os, signal, shlex, errno
56 import sys, os, signal, shlex, errno
57 from mercurial import commands, dispatch, util, extensions
57 from mercurial import commands, dispatch, util, extensions
58 from mercurial.i18n import _
58 from mercurial.i18n import _
59
59
60 def _runpager(p):
60 def _runpager(p):
61 if not hasattr(os, 'fork'):
61 if not hasattr(os, 'fork'):
62 sys.stderr = sys.stdout = util.popen(p, 'wb')
62 sys.stderr = sys.stdout = util.popen(p, 'wb')
63 return
63 return
64 fdin, fdout = os.pipe()
64 fdin, fdout = os.pipe()
65 pid = os.fork()
65 pid = os.fork()
66 if pid == 0:
66 if pid == 0:
67 os.close(fdin)
67 os.close(fdin)
68 os.dup2(fdout, sys.stdout.fileno())
68 os.dup2(fdout, sys.stdout.fileno())
69 os.dup2(fdout, sys.stderr.fileno())
69 os.dup2(fdout, sys.stderr.fileno())
70 os.close(fdout)
70 os.close(fdout)
71 return
71 return
72 os.dup2(fdin, sys.stdin.fileno())
72 os.dup2(fdin, sys.stdin.fileno())
73 os.close(fdin)
73 os.close(fdin)
74 os.close(fdout)
74 os.close(fdout)
75 try:
75 try:
76 os.execvp('/bin/sh', ['/bin/sh', '-c', p])
76 os.execvp('/bin/sh', ['/bin/sh', '-c', p])
77 except OSError, e:
77 except OSError, e:
78 if e.errno == errno.ENOENT:
78 if e.errno == errno.ENOENT:
79 # no /bin/sh, try executing the pager directly
79 # no /bin/sh, try executing the pager directly
80 args = shlex.split(p)
80 args = shlex.split(p)
81 os.execvp(args[0], args)
81 os.execvp(args[0], args)
82 else:
82 else:
83 raise
83 raise
84
84
85 def uisetup(ui):
85 def uisetup(ui):
86 if ui.plain():
86 if ui.plain():
87 return
87 return
88
88
89 def pagecmd(orig, ui, options, cmd, cmdfunc):
89 def pagecmd(orig, ui, options, cmd, cmdfunc):
90 p = ui.config("pager", "pager", os.environ.get("PAGER"))
90 p = ui.config("pager", "pager", os.environ.get("PAGER"))
91 if p and sys.stdout.isatty() and '--debugger' not in sys.argv:
91 if p and sys.stdout.isatty() and '--debugger' not in sys.argv:
92 attend = ui.configlist('pager', 'attend', attended)
92 attend = ui.configlist('pager', 'attend', attended)
93 auto = options['pager'] == 'auto'
93 auto = options['pager'] == 'auto'
94 always = util.parsebool(options['pager'])
94 always = util.parsebool(options['pager'])
95 if (always or auto and
95 if (always or auto and
96 (cmd in attend or
96 (cmd in attend or
97 (cmd not in ui.configlist('pager', 'ignore') and not attend))):
97 (cmd not in ui.configlist('pager', 'ignore') and not attend))):
98 ui.setconfig('ui', 'formatted', ui.formatted())
98 ui.setconfig('ui', 'formatted', ui.formatted())
99 ui.setconfig('ui', 'interactive', False)
99 ui.setconfig('ui', 'interactive', False)
100 _runpager(p)
100 _runpager(p)
101 if ui.configbool('pager', 'quiet'):
101 if ui.configbool('pager', 'quiet'):
102 signal.signal(signal.SIGPIPE, signal.SIG_DFL)
102 signal.signal(signal.SIGPIPE, signal.SIG_DFL)
103 return orig(ui, options, cmd, cmdfunc)
103 return orig(ui, options, cmd, cmdfunc)
104
104
105 extensions.wrapfunction(dispatch, '_runcommand', pagecmd)
105 extensions.wrapfunction(dispatch, '_runcommand', pagecmd)
106
106
107 def extsetup(ui):
107 def extsetup(ui):
108 commands.globalopts.append(
108 commands.globalopts.append(
109 ('', 'pager', 'auto',
109 ('', 'pager', 'auto',
110 _("when to paginate (boolean, always, auto, or never)"),
110 _("when to paginate (boolean, always, auto, or never)"),
111 _('TYPE')))
111 _('TYPE')))
112
112
113 attended = ['annotate', 'cat', 'diff', 'export', 'glog', 'log', 'qdiff']
113 attended = ['annotate', 'cat', 'diff', 'export', 'glog', 'log', 'qdiff']
General Comments 0
You need to be logged in to leave comments. Login now