On 30Apr2016 13:23, Steven D'Aprano <st...@pearwood.info> wrote:
On Sat, 30 Apr 2016 12:49 pm, Ben Finney wrote:
Random832 <random...@fastmail.com> writes:
On Fri, Apr 29, 2016, at 22:27, Rustom Mody wrote:
> Instead it does some ½-assed fall-between-the-stools of both

That doesn't answer the question of why, if you (Well, Ethan, but
you're taking the same position here) hate pagers so much

That's not a question relevant here; nobody inthe discussion has a
position fairly characterised as “hate pagers so much”. So you're
arguing against a straw man.

Rather, the position being argued is that they *do* like pagers; they
like pagers enough that they want the existing ‘PAGER’ environment
variable setting to remain untouched.

So they want the PAGER environment variable to specify what pager they
want...

_When_ they want a pager.

And, simulatenously, they want
Python's help to not use a pager at the interactive prompt.

...so long as applications don't actually make use of that PAGER environment
variable to determine the pager they want to use.

_When_ it is asked to use a pager.

What they (and, very often, me) want is that most things, including pydoc, to _NOT_ invoke a pager automatically, _unasked_.

So tools which page without asking are unwelcome, because that requires a mode switch when everything else (sed/grep/print/write/ls) do straight up unpaged output.

(1) If you want man, and nothing else in the universe, to automatically use
a pager, then set MANPAGER="less" (or whatever you wish to use), and unset
PAGER.

(2) If you don't want *anything* to use a pager, then unset both MANPAGER
and PAGER. You may have to report a feature request / bug report for
applications which force their own pager.

(3) In Python specifically, you can trivially and easily tell help() to
output directly to stdout. (At least on Linux, I haven't tested it
elsewhere.) Simply use PAGER=cat on the command line you use to launch the
interactive environment. This will affect no other running or future
processes (apart from subprocesses launched from your interactive Python
session), allowing you to keep your PAGER for everything else.

(4) If you want more than that, then patches are welcome :-)

This requires terrible domain specific knowledge. What about programs other than man?

And setting PAGER=cat before invoking interactive python is no better, because it will screw with $PAGER in any subprocess spawned from that environment.

What those of use in the "my terminal emulator scrolls nicely thank you" camp want is that most command line things, when asked to simply print some help text, _print_ it and do not page it. And often would like a way to tell pydoc to not page, such as a pydoc specific switch (possibly an environment variable).

Seriously, I'm thinking that a keyword argument to help might be useful:

help(object, pager=None)

where:
- pager=None gives the current behaviour;
- pager="foo" calls out to the external program "foo";
- pager=callable passes the help text to callable().

I'd be asking for pager=None to look at help.default_pager, which itself might obey your rules above. That way help.default_pager can be a callable which consults $PAGER or falls back to some inbuilt pager (presumably as now), but which a user can sumply go:

 help.default_pager=None

at the Python prompt and have unpaged output from there on.

I think that would make it easier to test help(). Thoughts?

Yes it would. I'm +1 _provided_ the user can set a global to tune the default mode, as otherwise it burdens the user with saying:

 help(foo, stdout.write)   # or "print" ?

whenever they want help. Not helpful!

Let me recite one of my favourite rules of thumb:

 If it can't be turned off, it's not a feature. - Karl Heuer

Cheers,
Cameron Simpson <c...@zip.com.au>
--
https://mail.python.org/mailman/listinfo/python-list

Reply via email to