-
-
Notifications
You must be signed in to change notification settings - Fork 1.3k
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
Choose Theme Based on The Terminal's Color Scheme #2896
Conversation
I think there was a typo (the second one should probably be |
@patbl Yep that's a typo, thanks :) Lucky me, it's only in the PR description and not in the actual PR changes. |
This seems to work well! I do need to specify What is the downside of not always doing colour scheme detection? The code briefly mentions a race condition with pagers; am I just lucky to have not hit that myself? What would be the symptoms of this happening? |
@sersorrel That's great to hear! I'm not familiar with lesspipe, how exactly do you combine bat with lesspipe? Do you pipe bat's output to less?
Yes, exactly :) You can observe the race condition when piping bat's output to less. In that case both processes are started (mostly) simultaneously and try to access the terminal at the same time (both color detection and less read from the terminal and enable / disable "raw mode"). Here's how I witness the race condition: |
Honestly, I can't figure out exactly how lesspipe.sh invokes bat... The general mechanism is that less examines $LESSOPEN and pipes the file to it before displaying whatever it prints (whether for syntax highlighting or for e.g. displaying a list of files inside a .zip). lesspipe.sh is a generic script that, when invoked as $LESSOPEN, will look at the filename and apply syntax highlighting or whatever other filtering as appropriate. I can't reproduce the race condition with that command, interestingly. |
From a quick (and not thorough) peek at less' source code I think there's indeed no race condition in that case. Less waits for |
01981dc
to
4409c56
Compare
I have been thinking about the
The main advantage is that to disable auto-detection one can choose between dark or light instead of being stuck on dark. It also opens the door to more keywords such as Thoughts? |
I finally got around to rebasing this and generalizing Another, maybe better idea to consider is to remove the separate flag completely and overload the meaning of
I quite like this for a few reasons:
|
This unfortunately needs another rebase – I think it's just imports and the changelog that conflict. Overloading |
Resolves #1746
This PR is an alternative to #2797. The most notable difference is that this PR uses my own library
terminal-colorsaurus
instead oftermbg
.Among other things, this solves (or at least softens) concerns around timeout / latency.
For additional background, see also my PR to delta: dandavison/delta#1615
Usage
As suggested in #1746, there are two new options with accompanying environment variables:
--theme-dark
/BAT_THEME_DARK
--theme-light
/BAT_THEME_LIGHT
By default,
bat
detects if the terminal is dark or light and uses--theme-<mode>
or falls back to the default dark or light theme respectively.If the detection fails, the terminal is treated as having a dark background.
The
--theme
option andBAT_THEME
env var always overrides these new options for backwards compatibility and to have an easy way to disable color detection. As a consequence--theme=default
always uses the default dark theme.I also decided to add an option for controlling the color detection--detect-color-scheme
. I don't think this is strictly necessary and I'm leaning on removing this. The only value that is not achievable through a combination of other options is--detect-color-scheme=always
.Detection can be controlled via--color-scheme
:auto
- detect from terminalauto:always
- always detect from terminal, even if output is redirecteddark
light
system
- detect from OS (macOS only)--theme
/BAT_THEME
takes some special values to control detection:auto
(default) - detect from terminalauto:always
- always detect from terminal, even if output is redirectedauto:system
- detect from OS (macOS only)dark
- Always use the theme configured in--theme-dark
light
- Always use the theme configured in--theme-light
I thought it might be useful to include
dark
andlight
as special values as a user may have configured dark and light themes via the env var / config but wants to override.Latency and Terminal Support
terminal-colorsaurus includes Measurements for a couple of terminals, both terminals that support
OSC 10
/OSC 11
and some that don't.For terminals that don't support
OSC 10
/OSC 11
querying for the color scheme usually takes well below 100 µs.How does this work?
Colorsaurus sends two escape sequences:
OSC 11
(the actual color querying sequence) followed byDA1
(which is supported by almost all terminals out there). Since terminals answer in the same order as the sequences were received we know that if we receive the answer toDA1
then the terminal does not supportOSC 11
and can bail out early and avoid a long timeout.For terminals that support
OSC 10
/OSC 11
there's a wide range of latency: Some terminals take less than 100 µs while others usually take around 30 ms.Windows
Windows is not supported. Calling terminal-colorsaurus on windows is a no-op, so there's no added latency there.
macOS
I have completely removed the current detection via macOS system preferences asterminal-colorsaurus
is correctly able to detect whether the terminal is dark or light. I saw dalance/termbg#8 referenced somewhere in the discussion, but I am unable to reproduce the issue. I am running macOS Ventura 13.6.4.The color scheme is detected from the terminal by default, but can be detected from the OS instead by passing
--color-scheme=system
--theme=auto:system
.Open Questions
* [ ] Should I keep--detect-color-scheme
or remove it?