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

More informative VI mode indicator #625

Closed
rbpatt2019 opened this issue Nov 4, 2019 · 11 comments · Fixed by #3839
Closed

More informative VI mode indicator #625

rbpatt2019 opened this issue Nov 4, 2019 · 11 comments · Fixed by #3839
Labels
✨ enhancement A new feature implementation.

Comments

@rbpatt2019
Copy link

Feature Request

Is your feature request related to a problem? Please describe.

Recognise this might be a Fish-specific problem. Delving onwards...

Migrating from SpaceFish, where the vi-mode indicator gave feed back on whether you were in replace, visual, insert or normal mode, as described here. I must admit, I'm a big fan of the character switching between insert and normal mode! But it gives me confusing information on visual or replace mode.

If you are in normal mode and then switch into either visual or replace mode, the prompt character switches back to insert mode. This is incredibly confusing, as there is now no clear indication of whether you are in insert, replace, or visual. When you then exit visual/replace mode, it switches back to the normal mode character, as expected.

Describe the solution you'd like

Solution A: Allow custom configuration of characters for each mode. Basically, the currently implementation expanded to have a character for visual and replace modes.

Solution B: Allow inclusion of the default fish_mode_prompt, though I suspect this would be more complicated.

Describe alternatives you've considered

I have manually configured fish_mode_prompt, but this is blocked/disabled by Starship.

@rbpatt2019 rbpatt2019 added the ✨ enhancement A new feature implementation. label Nov 4, 2019
@seanag0234
Copy link

seanag0234 commented Dec 18, 2019

@rbpatt2019 I was able to add an indicator by adding this to my starship.toml.

[character]
symbol = "[I] >"
vicmd_symbol = "[N] >"

@max-sixty
Copy link

Would be great to be able to chose colors as well as the character change

@rbpatt2019
Copy link
Author

@seanag0234 As was I! To clarify, what I'm looking for is an indicator not for Insert or command/normal mode (which I was able to achieve), but an indicator for visual mode and replace mode. Right now visual, replace, and insert mode are all indicated by the same symbol - " [I] >>>>" in my .toml - and there isn't an option to differentiate between the three.

@Adrian-Grimm
Copy link

@rbpatt2019 I was able to add an indicator by adding this to my starship.toml.

[character]
symbol = "[I] >"
vicmd_symbol = "[N] >"

I didn't get it to work ... Character stays the same in every VI-Mode...
My current config: https://raw.githubusercontent.com/Adrian-Grimm/DotFiles/master/.config/starship.toml
(Would be nice to have something like a config validation included... but that's another topic...)

@rbpatt2019
Copy link
Author

As an update, I'm now using zsh on my work laptop and cannot find a way to add a visual/replace mode indicator there either.

@pbnj
Copy link

pbnj commented May 5, 2020

@Adrian-Grimm & @rbpatt2019 - I was able to replicate the issue on bash and didn't see a bug filed for this, so I created one: #1171

Worth noting that vicmd_symbol seems to work just fine on Fish.
I haven't had a chance to test this behavior on Zsh.

@sagittarius-a
Copy link
Contributor

After an hour of fiddling it seems that zsh does not report clear information regarding it's mode.

When inspecting KEYMAP variable in the zle-keymap-select hook, the only two values observed are main & vicmd, while I was switching from Command, Replace, Visual, Insert and Normal modes.

Based on this code that is in charge to identify the current mode,

    let mode = match (&context.shell, keymap.as_str()) {
        (Shell::Fish, "default") | (Shell::Zsh, "vicmd") => ShellEditMode::Normal,
        _ => ASSUMED_MODE,
    };

it is not possible to know if the mode is different than Normal and Insert :(


As I was writing this message, I found a very informative comment on a SO thread which states:

Visual mode is not a single state in zsh: it's defined by the combination of the mark being set, region being active and vi command mode. You can change those states independently with a custom widget or with emacs widgets. viopp and visual are only ever used as local keymaps with vicmd remaining the selected keymap. This means you don't need to repeat many vi style bindings across three keymaps: bindings in vicmd are shared, Note how few bindings visual and viopp contain compared to vicmd. But it also means that they are never selected triggering the callback

@Adrian-Grimm
Copy link

My issue is solved: #1171 (comment)

rouge8 added a commit to rouge8/dotfiles that referenced this issue Dec 27, 2020
Unlike in fish, this didn't update in realtime, only when drawing a new
prompt. I can get most of the vi-mode behavior from
[starship's `character` settings](https://starship.rs/config/#character)
and there's some open PRs and issues about the rest:

- starship/starship#1679
- starship/starship#625
@lilyball
Copy link

lilyball commented Aug 7, 2021

I'm hitting this right now in fish. starship only has two modes: "normal" and "insert". It maps Fish's "default" mode or Zsh's "vicmd" mode to "normal", and everything else to "insert".

let mode = match (&context.shell, keymap) {
(Shell::Fish, "default") | (Shell::Zsh, "vicmd") => ShellEditMode::Normal,
_ => ASSUMED_MODE,
};

But fish has 6 different modes (default, insert, paste, replace, replace_one, and visual). "paste" can generally be ignored, it's just for bracketed paste mode (even fish_default_mode_prompt prints nothing for it). But the others should be configurable, both character and style.


FWIW anyone who wants to restore the original mode prompt can do so by just redefining it after sourcing the starship init. The simplest way is probably source $__fish_data_dir/functions/fish_mode_prompt.fish. The downside to this is having fish_mode_prompt defined means starship won't be rerun on mode changes, so you're giving up on having character reflect this. But it will sometimes get repainted in other modes, so you'll need to figure out workarounds for that.

@mrjones2014
Copy link
Contributor

I'd love to see a fix for this as well

@adelarsq
Copy link

It's there any way to add this behaviour on PowerShell at moment?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
✨ enhancement A new feature implementation.
Projects
None yet
Development

Successfully merging a pull request may close this issue.

9 participants