-
-
Notifications
You must be signed in to change notification settings - Fork 2.6k
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
It should be possible to tell there are unsaved changes to the buffer, even with long file paths. #4686
Comments
I want to try fixing this |
It might help to look at the code introduced by #2434. |
@kirawi After looking at the code it seems that the text isn't simply substringed to fit in the middle space but is put on a buffer and appended. When there isn't any more space on the line it just doesn't show. This is probably needed so that the editor can append as many elements on the line as needed without worrying about spacing. You can test this by adding multiple file name elements in the configuration and with a long enough file name it just doesn't show all of the elements. My suggestion to fix the original concern would be to either prepend the Some fun config options that works to illustrate my point better:
|
I added a PR #4731 that adds a new "file-dirty" element. |
If the file path for the current buffer is longer than will fit on the allotted space in the status line, it is truncated to fit. This makes perfect sense. However, the " [+]" that indicates the current buffer has unsaved changes is also lost in this truncation, making it impossible to tell whether the buffer requires saving until you try to close it or fully quit out.
This is particularly problematic for users who tend to open new tmux windows/panes for editing and exit out by simply killing said window/pane, in which case you don't see there are unsaved changes and Helix doesn't get a chance to warn you about the unsaved buffer at all.
The status line string truncation should take into account whether a " [+]" (or any other status indicator) is present, and truncate the buffer name alone, allowing space for the indicator to still be shown on-screen.
What I'm seeing:
NOR a_very_long_directory_name/some_other_directory/my_file_with_a_very_long_ 13:14 ruby
NOR a_very_long_directory_name/some_other_directory/my_file_with_a_very_long_ 13:14 ruby
What I would expect:
NOR a_very_long_directory_name/some_other_directory/my_file_with_a_very_long_ 13:14 ruby
NOR a_very_long_directory_name/some_other_directory/my_file_with_a_very_l [+] 13:14 ruby
Additionally, it would be nice if truncation was indicated with a
…
as opposed to the buffer name simply terminating weirdly, though I realize that's more of a nitpick than the legitimate issue above.helix: 22.08.1
(Wasn't quite sure if this should be reported as a bug or as an enhancement. Please do categorize accordingly if this should've been a bug report instead.)
The text was updated successfully, but these errors were encountered: