- 
                Notifications
    You must be signed in to change notification settings 
- Fork 44
fix snippet completion incorrect filtering #801
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
base: main
Are you sure you want to change the base?
Conversation
| @marijnh fixed the codemirror/autocomplete issue and made a release of it. I spent a couple hours this morning on this PR's branch attempting to upgrade our codemirror/autocomplete version. I was not successful (facing Quarto monorepo problems that I don't understand). I feel that this PR is blocked on getting this autocomplete fix in. If we are going to fix it so that snippet completions show up properly, snippets should work. I will have to get help figuring out how to upgrade the package. | 
| Here's a description of the issues I was running into while upgrading: I used  I tried deleting the root level  I do not understand why the root  | 
| Stop using yarn. It's a broken tool that will duplicate dependencies all over the place when you upgrade something. You can blow away your package lock on every update to work around that, or switch back to npm, which is a more reliable tool. | 
| I imagine part of what's happening here is that this is a https://turborepo.com/ monorepo, and yarn might be getting extra confused in the process? (I would happily switch us all away to better tooling if the benefits are there, but I would really like to not to have to switch again in a year. So I think adding some friction here and thinking half a dozen times before pulling the trigger is worthwhile.) | 
| I hadn't considered that yarn has problems, I thought I was doing something wrong. Here's a yarn issue that seems to describe a related, if not the same, problem as the problem I was running into. I am running an old yarn version. I suppose the smallest thing to try for now is to upgrade yarn (two major versions, I'm on 1.22.22 and that thread ends in a claim that this problem is fixed in 3.1.1) and see if that works and helps. | 
52d3eda    to
    df7129d      
    Compare
  
    df7129d    to
    36c940e      
    Compare
  
    | I attempted to update yarn to the latest version. There were many many new warnings during the yarn install. Unfortunately, things break in a similar way to when I deleted the  After I hackily sidestepped these errors, I ran into another: There are red underlines in every file I looked at. Underlines on the return types of async functions. Underlines on so many import paths. Underlines. | 
| @cscheid It seems that we would have to embark on a proper migration of our monorepo to a new version of yarn to deal with these issues. It scares me though. I have little sense for how much work that would be and I can't think of a way to make incremental progress. | 
| Also, the yarn upgrade causes the number of changes in this PR to be wild. It should be really be in its own PR... Though, I'm hesitant to start such a PR until we decide we actually want to invest into a proper migration. | 
| I checked out the Positron repo to see how they are managing their dependencies and they are also using an old version of yarn... An alternative to thing to look into rather than upgrading yarn: I heard there is something we can maybe do with the old version of yarn to do with "no hoisting" that could possibly help. | 
Problem
Snippets were being filtered from completions because of a position miscalculation.
The
itemFromfunction was not correct, it was doing something clever that it is not quite right.itemFromshould calculate how many characters into the document the start of a completion is. It did this by calculating the length of the completion and subtracting that from the text cursor's position. The way it was calculating the length of the completion was not correct. The completion gives its positions in the context of thecvContext.code, which is different from the positions in the actual document; For one thing, the line containing the language string (like{r}) is removed fromcvContext.code. So, we can't use the positions the completion gives us directly. That is whyitemFromwas cleverly not using the positions, but instead using the positions to calculate the length of the completion.But, for example, if you are typing
libr, a completion for thelibrarysnippet will say that its insertion character position is from 0 to 7. What's up with that? For whatever reason, since your cursor is at the end of a line with 4 characters, the completion pretends that it can replace 3 more non-existent characters in the rest of the line. If there were any characters in the line afterlibr, even just whitespace likelibr, then the completion would instead say that its insertion character position is from 0 to 4.This PR fixes the issue by snapping the ending position of a completion to the end of its line in
cvContext.code.After I fixed this issue, I was able to easily insert the
librarysnippet in R code, and this uncovered a bug in snippets in codemirror autocomplete that I reported here codemirror/dev#1607.