Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

ergo -d weird pager behavior #9

Open
calebzulawski opened this issue Mar 6, 2023 · 4 comments
Open

ergo -d weird pager behavior #9

calebzulawski opened this issue Mar 6, 2023 · 4 comments

Comments

@calebzulawski
Copy link
Collaborator

calebzulawski commented Mar 6, 2023

A few related issues:

  • With no pager available, ergo -d is missing a trailing newline
  • With just less installed, tested in debian:bullseye-slim, the output looks like this:
ergo -d std:String
Strings.

Functions
  <E2><80><A2> chars: Create an iterator over the characters of a string.
  <E2><80><A2> compare: Compare two strings lexicographically.
  <E2><80><A2> from: Convert a value into a String.
  <E2><80><A2> join: Join an array of strings.
  <E2><80><A2> match: Match and decompose a string.
  <E2><80><A2> split: Split a string on a substring.
  <E2><80><A2> trim: Trim whitespace from the beginning and end of a string.

Even with less installed, the output doesn't go through the pager (it's printed directly to stdout), but there is a trailing newline...

@calebzulawski calebzulawski changed the title ergo -d needs a trailing newline when a pager isn't available ergo -d weird pager behavior Mar 6, 2023
@calebzulawski
Copy link
Collaborator Author

This seems to be somewhat related to the locale set to POSIX, setting it to C.UTF-8 properly renders the unicode symbols, but still writes directly to stdout. Maybe less is configurable?

@afranchuk
Copy link
Collaborator

The paging uses less -F, which will not page if the content will fit in the terminal. I'm not sure whether less is just a pass-through at that point or whether it may alter the input.

There's definitely nothing right now to not use unicode (and there's no way to check whether the terminal rendering will result in correct unicode output, since that goes into complicated font rendering/fallback behaviors). It would not be hard to have a flag to change the characters sets used.

@calebzulawski
Copy link
Collaborator Author

Odd, on my machine (ubuntu 22.04) it always pages (which I don't really mind) but it might be beneficial to use minus or similar to make the paging a little more uniform.

@afranchuk
Copy link
Collaborator

afranchuk commented Mar 6, 2023

That is odd. Has ubuntu changed the default pager!? I know on mac their version of less is so incredibly old that it has a bug where -F doesn't work.

I'm not sure whether anyone uses PAGER in special ways or not (which the current approach respects), but an approach using minus would still allow a user to use their pager (they'd have to disable paging and pipe it themselves though). I suppose one of the larger advantages of PAGER is that it has familiar user keybindings and features. It's probably not a big loss to change though, I expect a huge portion of users simply only use arrow keys and maybe text search.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants