-
-
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
Completion-Replacement removes punctuation #12335
Comments
This was something I discovered a while ago, and then made a temp fix for and forgot about (😆) My fix involved changing how the range is calculated: fn completion_range(
text: RopeSlice,
edit_offset: Option<(i128, i128)>,
replace_mode: bool,
cursor: usize,
) -> Option<(usize, usize)> {
- let res = match edit_offset {
- Some((start_offset, end_offset)) => {
- let start_offset = cursor as i128 + start_offset;
- if start_offset < 0 {
- return None;
- }
- let end_offset = cursor as i128 + end_offset;
- if end_offset > text.len_chars() as i128 {
- return None;
+ let res = if replace_mode {
+ find_completion_range(text, replace_mode, cursor)
+ } else {
+ match edit_offset {
+ Some((start_offset, end_offset)) => {
+ let start_offset = cursor as i128 + start_offset;
+ if start_offset < 0 {
+ return None;
+ }
+ let end_offset = cursor as i128 + end_offset;
+ if end_offset > text.len_chars() as i128 {
+ return None;
+ }
+
+ (start_offset as usize, end_offset as usize)
}
- (start_offset as usize, end_offset as usize)
+ None => find_completion_range(text, replace_mode, cursor),
}
- None => find_completion_range(text, replace_mode, cursor),
};
+
Some(res)
} It checks if its in replace mode and then always calculates the range, ignoring what the lsp or anything else would have sent it. I wasnt able to figure out if the lsp was sending the incorrect range or if helix was doing something with it, so stopped here with it. I dont know if the maintainers would take this "fix" as its really more of a band-aid. |
We will not accept the change above that is not spec compliant and causes issues in other situations. This seems like a RA bug but you can try #12214 to see if it helps since tgat is the only thing we are missing. You could also try if the same thing reproduces in VSCode (with completion replace enabled) |
I just tried out #12214 and it works correctly (both with and without I'll be daily-driving that PR 'till it gets merged from now on. |
Summary
Autocompletion with
completion-replacement
results in the deletion of punctuation after cursor sometimes.Reproduction Steps
pub fn make_splits(world: &World) -> Vec<Vec<usize>> {}
as an example. Make sure to let RA load fully.World
,cWor<Tab><Enter>
to accept autocomplete.I expected this to happen:
The line in the end remains as described above.
Instead, this happened:
I get the following:
With my cursor positioned after
).
d
inWorld
(i.e. betweend
andOf interest is that typing
Wo
(as opposed toWor
) doesn't cause it, and typingWorl
causes the space afterd
to be eaten up too, and my cursor to be placed _before thed
(i.e. betweenl
andd
). Similarly, fully typingWorld
and then accepting theWorld
suggestion causes...&World> Vec<...
to be produced, andWo
to be highlighted with the anchor between&
andW
.Helix log
~/.cache/helix/helix.log
(Log cleared before running reproduction steps, steps then run and saved, log opened and entire contents pasted below) ``` 2024-12-24T21:34:36.644 helix_view::document [ERROR] Failed to copy metadata on write: The operation completed successfully. (os error 0) ```Platform
Windows
Terminal Emulator
wezterm 20240203-110809-5046fc22
Installation Method
source
Helix Version
helix 24.7 (0fd4a4a)
The text was updated successfully, but these errors were encountered: