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

Inadvertent bidi rendering of some terminal UIs (lazygit) #336

Open
Eryx5502 opened this issue Jul 10, 2023 · 15 comments
Open

Inadvertent bidi rendering of some terminal UIs (lazygit) #336

Eryx5502 opened this issue Jul 10, 2023 · 15 comments
Labels

Comments

@Eryx5502
Copy link

Eryx5502 commented Jul 10, 2023

Wsltty used to be my first choice for working with wsl and neovim, but it's been a while since I stopped using it because of some weird rendering when using some TUIs such as lazygit (see pics below). I couldn't figure out if is some configuration related issue, although I've tested with different fonts and tried out all configs on the configuration window but none seems to fix it. It looks like the line breaks are not rendered where they should.

Also, I don't know if it is related but the error happens for the first time when a glyph (pointed our with red arrows on the screenshots) should be rendered and, while Windows Term renders it correctly, Wsltty does not and then the line break errors start.

Please let me know if I need to provide any additional info.

With Wsltty:
imagen
imagen

With Windows Terminal:
imagen
imagen

@mintty
Copy link
Owner

mintty commented Jul 10, 2023

Please provide a reproducible test case.
You may try to produce a tty log with tee but that may not work well, so you may add an option -l C:\tmp\mintty-%d.log to your wsltty invocation shortcut, with an existing directory C:\tmp. The goal is to get a file that exhibits the issue when simply output with cat. Then upload that file here.

@Eryx5502
Copy link
Author

Here's the log: mintty-1020.log.

When cat the log file, the issue appears if I do it from wsltty but not if I do it from Windows Terminal, although for some reason it doesn't print the whole screen (see screenshots below).

Wsltty:
imagen

Windows Terminal:
imagen

@mintty
Copy link
Owner

mintty commented Jul 10, 2023

What's the size of your terminal?

@Eryx5502
Copy link
Author

Eryx5502 commented Jul 10, 2023

It's 235x62

@mintty
Copy link
Owner

mintty commented Jul 11, 2023

The output contains right-to-left characters which cause the output direction to be changed and output reordered.
This can be disabled with mintty options -o Bidi=0 or --nobidi, or dynamically disabled if you configure the user-definable function toggle-bidi into your context menu.
About why your tool uses bidi characters ask them. If it's intended for layout, that's not a good idea and should be reported to them as a bug.

@mintty
Copy link
Owner

mintty commented Jul 11, 2023

The issue title also mentions tmux. Do you have a tmux example please, as a log as before?

@mintty mintty changed the title Incorrect rendering of some terminal uis (lazygit) and tmux panes Inadvertent bidi rendering of some terminal UIs (lazygit) and tmux panes Jul 11, 2023
@Eryx5502
Copy link
Author

Alright, that must be it since you're suggestion does stop the rendering issues.

About tmux, it was long ago when I noticed. I remember it used to happen when using the neovim plugin Telescope and tmux, but either I don't recall correctly or those are solved already by their teams. Anyhow, I'm not able to reproduce the error without Lazygit right now.

Just a question: I'm not so familiar with the field so I'm not sure what are the implications of using wsltty always with --nobidi. Is it not advisable or I can just add the option to my shortcut and forget about it?

Also, is it normal the glyphs are not rendering in wsltty but they do in Windows Terminal (both using the same font, Nerdfont version of Fira Code)?

@mintty
Copy link
Owner

mintty commented Jul 11, 2023

If you don't need to use bidi, just keep the option in.
Which glyphs do not render for you? שׂ (the Hebrew glyph) renders for me, font DejaVu Sans Mono.
Is that character part of your contents or does it come from lazygit?

@mintty mintty changed the title Inadvertent bidi rendering of some terminal UIs (lazygit) and tmux panes Inadvertent bidi rendering of some terminal UIs (lazygit) Jul 11, 2023
@Eryx5502
Copy link
Author

Here there is a side by side comparison of wsltty (left) and windows terminal (right). Both have configured the same font and are attached to the same tmux session. On the WT (right) version there are icons on the branches section and also in the commits section, while on wsltty (left) there's either no icon or something different from the clear icons on the right.

imagen

@mintty
Copy link
Owner

mintty commented Jul 11, 2023

I see no mangled output here. If some glyphs do not display, it's most likely a font issue. Try DejaVu Sans Mono.
Also (see above), provide clear information what characters are not displayed so it can be analysed.

@mintty
Copy link
Owner

mintty commented Jul 11, 2023

Also, see my previous question. Are the Hebrew characters part of the contents you put into the panes or do they appear with empty panes already? In the latter case, I'd submit an issue to lazygit.

@Eryx5502
Copy link
Author

Sorry I'm not being clear. As said before, I don't really understand anything about terminal rendering or related stuff so it's kind of hard for me to explain.

I think lazygit uses some symbols (and probably some extra feature of some fonts such as FiraCode and/or some terminals) to render the git related icons on the screenshots from my last comment. In any case, I wouldn't say the issue is specifically related to lazygit: if I do echo "שׂ ﰖ שּׁ", the result rendered is diferent on wsltty and windows terminal, both using the same font FiraCode NerdFont:

  • Windows Terminal: imagen
  • Wsltty: imagen

Other fonts do behave differently on Windows Terminal also, which is what makes me think there's a font feature I'm not aware of having a role here (also, the rendered version by Windows Terminal does not look exactly as "שׂ ﰖ שּׁ").

@mintty
Copy link
Owner

mintty commented Jul 13, 2023

I'd still appreciate an answer to my previous question. If you start lazygit, I assume it still looks OK. Then you do something in one of the panes and the layout gets mangled, right? What do you run in there and is it part of lazygit or something else?

@mintty
Copy link
Owner

mintty commented Jul 13, 2023

Actually, sorry, you seem to have answered this just before, kind of, however leaving unclear some details.
Was echo "שׂ ﰖ שּׁ", part of your original test case? Why do you run it? What other program would output these characters?

@Eryx5502
Copy link
Author

Eryx5502 commented Jul 13, 2023

Sorry for the unclear details. I'll try to clarify.

If you start lazygit, I assume it still looks OK. Then you do something in one of the panes and the layout gets mangled, right?

No, it is Lazygit who uses those glyphs mentioned on previous messages as part of its ui: it adds some of those as icons for each branch / commit. So the moment I open lazygit, on an existing git repository, the render gets mangled and only closing lazygit finishes the weird rendering.

Was echo "שׂ ﰖ שּׁ", part of your original test case? Why do you run it? What other program would output these characters?

It was not part of my original test case since. I didn't understand what was causing the issue until your replies. I do not run echo "שׂ ﰖ שּׁ" on my own, and I don't know any other program which would output these characters. However, the icons rendered on Windows Terminal with FiraCode are quite common and seems likely they appear on some (neo)vim pluggins using icons for instance.

Moreover, I believe the original issue is indeed caused by the rendering of this glyphs: I know nothing about these things, but when I paste the characters apparently it makes my writing start going from right to left.

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

No branches or pull requests

2 participants