-
-
Notifications
You must be signed in to change notification settings - Fork 83
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
Missing features when compiling/indexing #792
Comments
Thanks for the detailed report! Supporting large projects such as yours is certainly one of Lexical's goals. There are a few axes it sounds like we can improve on:
I have some thoughts on these, but I expect @scohen will have more/better ones, so I'll let him share first. 🙂 As a baseline, how long does from-scratch compilation usually take when run outside of Lexical? i.e. removing |
I'm a little confused as to why lexical's compilation would take significantly longer than If a full index is happening often, then something else is wrong with lexical in your project, we can definitely help you get up and running if that's the case. For what it's worth, there's another project that has 1.5mm lines, which also uses lexical, they also had some problems with compilation that we helped them with, and this sounds somewhat familiar to the issues they had. |
Thanks @zachallaun and @scohen for the quick replies. @zachallaun I compiled the project from scratch as suggested (on the same machine used to produce the figures described in the issue) and it takes around 7 minutes. @scohen As far as I could see a full index only happens when at the beginning as you mentioned. Still, even a partial index triggered by switching to another branch takes more than 2 minutes. One thing that I noticed playing around is that after a while the Find References functionality has some hiccups (it returns no references for some module/function, while it works properly for most) and forcing a full index via the VSCode command fixes it. |
It's extremely surprising to me that a partial index would take 2 minutes, do you have an idea how many files are changing when you switch branches? I think what's actually happening is that the index isn't being corrupted, but lexical isn't getting a full list of files from the editor, and it only indexes what it sees. We can fix this.
Sadly, we're never going to be able to improve upon that speed for a full build. I'm actually wondering why lexical is adding overhead there. Is it the The hiccups you're seeing are kind of intentional; For some reason, when we index and compile at the same time, compilation slows to a crawl, so we have do disable indexing before we compile. I'd love to be able to do both at the same time, but maybe a fix would to be to not allow these features (and provide an error message) before the store is ready. |
I'd also think that, in the general case, compilation would be partial ever since #582. |
Yes, that's correct, @zachallaun |
I switched from Compilation took 24s, indexing 1m25s, 913 file changes (421 to compile) > git diff --name-only HEAD..master | wc -l
913
> git diff --name-only HEAD..master | awk '/.ex$/' | wc -l
421
Ok, I'll look into this and come back to you |
how big are the files? Indexing is linearly proportional to the size of the AST. That said, I'm very surprised that indexing 900 files takes over a minute. My current project has 2400 files and it indexes everything in ~10 seconds |
And to give you an idea, it has 560,000 total lines (including deps, which are indexed) |
Played around with the compilation steps within Lexical, these are the results I got:
Summing up to roughly 7.5 minutes. I ran it a few times and I get similar results (within 10 seconds). I also timed the compilation of each file within
Those 900+ files amount to 309k lines. I didn't check, though, if there are deps changes between the two branches. I guess it would index only new/updated deps, right? Although I was switching from |
Is this just from changing branches, or is it a fresh compile? |
@orlera , would it be possible for you to pop into our discord so we can help? |
At Remote we have been suffering from the lack of a performant LS that can cope with the size of our codebase (approaching 800k lines excluding deps, tests, comments, etc)
We were delighted at the beginning of the year when Lexical became the officially recommended LSP for Elixir within the company. It was a welcome change of pace compared to the tools we were using previously.
Our codebase has grown significantly since then and Lexical is struggling to keep up with the pace.
The main pain we identified is related to compilation & indexing times and the fact that several features are not available or extremely slow when those operations are undergoing.
To put it into numbers, Lexical compiles our project in around 11 minutes and indexes it in 5 minutes. That means that when doing a full compile+indexing, Lexical's most important functionalities are not available for 16 minutes.
Considering the 3 following scenarios, this happens with the features we rely on the most (Go to definition, Code completion, Find references):
When the project compilation is underway and the search store is not enabled:
[warn] ** (ErlangError) Erlang error: "CompileError during metadata build pre:\nnofile
;Completion for LxPos<<34, 20>>
) but there is no follow up to the request in the logs;search store isn't enabled yet
When compilation is underway and Search store is enabled:
Completion for LxPos<<34, 20>>
) but there is no follow up to the request in the logs;When project indexing is underway:
Go to definition: times out
Code completion: times out
Find References: when it is available, it can take up to 30s to output the code completions.
We tried to parallelise compilation and indexing in the hope that the issue fixed serialising their execution in #526 disappeared with the latest Elixir & Erlang versions. We can confirm that the issue is still present and that both compilation and indexing took twice the time.
The text was updated successfully, but these errors were encountered: