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

Dart Analyzer very slow/stuck #55281

Open
JonasJW opened this issue Mar 22, 2024 · 208 comments
Open

Dart Analyzer very slow/stuck #55281

JonasJW opened this issue Mar 22, 2024 · 208 comments
Labels
analyzer-stability area-dart-model For issues related to conformance to the language spec in the parser, compilers or the CLI analyzer. model-performance Performance/memory issues in analyzer/cfe P2 A bug or feature request we're likely to work on type-performance Issue relates to performance or code size

Comments

@JonasJW
Copy link

JonasJW commented Mar 22, 2024

Dart & Flutter has suddenly become unusable slow in VSCode. Intellisense won't load within 30+ seconds, syntax highlighting won't update, jumping to code definitions loads infinitely, etc.

This seems to be especially the case on bigger projects, on a newly created project it works fine. I tried switching to Android Studio which seems to behave similarly (maybe a little better).

I tried uninstalling all extensions, even completely removing VSCode with any data stored and reinstalling it. As soon as I install the Dart extension, it is unusable. I also tried setting the following settings:

"dart.previewLsp": true,
"dart.useLegacyAnalyzerProtocol": true,
"dart.useLsp": false,
"dart.autoImportCompletions": false,

I'm on macOS 14.4, VSCode Version 1.87.2 (Universal),

In the Activity Monitor, there is the dart:analysis_server.dart.snapshot process running with around 1 GB of used memory. I'm not sure if this is normal.

Here is a screenshot from the Dart Analyzer (which I'm also having trouble opening)

Screenshot 2024-03-22 at 20 47 42

dart info output:

General info

  • Dart 3.3.2 (stable) (Tue Mar 19 20:44:48 2024 +0000) on "macos_arm64"
  • on macos / Version 14.4 (Build 23E214)

Project info

  • sdk constraint: '>=2.17.0 <3.0.0'

Process info

Memory CPU Elapsed time Command line
6 MB 0.0% 11:53 dart devtools --machine --allow-embedding
393 MB 100.6% 11:53 dart language-server --protocol=lsp --client-id=VS-Code --client-version=3.85.20240318
29 MB 0.0% 11:53 flutter_tools.snapshot daemon
35 MB 0.1% 00:23 flutter_tools.snapshot debug_adapter
121 MB 10.8% 00:23 flutter_tools.snapshot run --machine --start-paused -d B95DD896-131D-4163-A83C-1AC8A70E8560 --devtools-server-address http:/ --target /main.dart --web-renderer canvaskit --web-port 5000

Any recommendations on how I could possible fix this would be very welcome!

@JonasJW JonasJW changed the title Dart Dart Analyzer very slow/stuck Mar 22, 2024
@lrhn lrhn added the area-analyzer Use area-analyzer for Dart analyzer issues, including the analysis server and code completion. label Mar 24, 2024
@keertip keertip added type-performance Issue relates to performance or code size P1 A high priority bug; for example, a single project is unusable or has many test failures labels Mar 26, 2024
@keertip
Copy link
Contributor

keertip commented Mar 26, 2024

@DanTup , do you see this? Have there been more reports of this kind?

@keertip
Copy link
Contributor

keertip commented Mar 26, 2024

/ cc @bwilkerson

@DanTup
Copy link
Collaborator

DanTup commented Mar 26, 2024

I've not seen any other reports like this. 100% CPU certainly does not look healthy if it's persisting for a long period after initial analysis.

@JonasJW a few questions:

  • How big is the open workspace (code --status I think should give a summary of the number of each file type)
  • Might it contain any symlinks (that could result in analyzing more than just this folder, or even cycles?)
  • You noted that this issue started recently - are there any things that you updated around the time it started (VS Code, the VS Code extensions, the Dart/Flutter SDKs)?
  • Are you able to get a screenshot of the servers Timing page (the one you gave above was the Completion page) which will include timings for a larger set of requests

@MaximeRougieux
Copy link

We were having the same issue and using the custom_lint package (v0.5.7).

Removing it completely seems to have solved the issue for us, are you using it too, and can you try to remove it to confirm it comes from there if you are ?

@keertip
Copy link
Contributor

keertip commented Mar 27, 2024

/cc @scheglov

@keertip keertip added P2 A bug or feature request we're likely to work on and removed P1 A high priority bug; for example, a single project is unusable or has many test failures labels Mar 27, 2024
@JonasJW
Copy link
Author

JonasJW commented Mar 29, 2024

@DanTup Thanks for the response and sorry for the late reply.

code --status output:

Version:          Code 1.87.2 (863d2581ecda6849923a2118d93a088b0745d9d6, 2024-03-08T15:21:31.043Z)
OS Version:       Darwin arm64 23.4.0
CPUs:             Apple M1 Pro (8 x 24)
Memory (System):  16.00GB (0.06GB free)
Load (avg):       5, 5, 6
VM:               0%
Screen Reader:    no
Process Argv:     --crash-reporter-id 0c0cb32f-913b-418e-b987-7370929419d6
GPU Status:       2d_canvas:                              enabled
                  canvas_oop_rasterization:               enabled_on
                  direct_rendering_display_compositor:    disabled_off_ok
                  gpu_compositing:                        enabled
                  multiple_raster_threads:                enabled_on
                  opengl:                                 enabled_on
                  rasterization:                          enabled
                  raw_draw:                               disabled_off_ok
                  skia_graphite:                          disabled_off
                  video_decode:                           enabled
                  video_encode:                           enabled
                  webgl:                                  enabled
                  webgl2:                                 enabled
                  webgpu:                                 enabled

CPU %   Mem MB     PID  Process
    0      115   38907  code main
    7       66   38910     gpu-process
    0       16   38911     utility-network-service
    0       33   38923  shared-process
    0       33   82195  ptyHost
    0        0   83841       /bin/zsh -il
    0        0   90120         bash /usr/local/bin/code --status
    9       66   90129           electron-nodejs (cli.js )
    5      246   83837  window [5] (auto_router.gr.dart — exercisable_flutter)
    0       98   83839  extensionHost [5]
    0       33   83879       electron-nodejs (config.js )
    0        0   83961         /usr/bin/script -t 0 /dev/null /usr/bin/arch -arm64e xcrun xcdevice observe --usb
    0       16   83962           /Applications/Xcode.app/Contents/Developer/usr/bin/xcdevice observe --usb
    0        0   83963         /usr/bin/script -t 0 /dev/null /usr/bin/arch -arm64e xcrun xcdevice observe --wifi
    0       16   83964           /Applications/Xcode.app/Contents/Developer/usr/bin/xcdevice observe --wifi
    0      426   83884       /Users/jonas/Documents/flutter/bin/cache/dart-sdk/bin/dart language-server --protocol=lsp --client-id=VS-Code --client-version=3.85.20240327
    0        0   83886       /Users/jonas/Documents/flutter/bin/cache/dart-sdk/bin/dart devtools --machine --allow-embedding
    0       33   89935       electron-nodejs (config.js )
    0       33   89961         electron-nodejs (config.js )
  170     1081   90000           electron-nodejs (config.js )
    0       33   83840  fileWatcher [5]

Workspace Stats: 
|  Window (auto_router.gr.dart — exercisable_flutter)
|    Folder (exercisable_flutter): more than 20346 files
|      File types: transitive_digest(3856) json(1582) png(1354) flat(1004)
|                  jar(976) xml(843) webp(646) ttf(344) stamp(334)
|                  len(275)
|      Conf files: launch.json(1)
|      Launch Configs: dart(13)

To be honest, I'm not quite sure what you mean by your question about symlinks or how I can find out.

Yes, this issue seems to have started just recently without making any noticeable changes such as updating SDKs, installing extensions, etc.

Here are further screenshots, I hope this is the server timing page you meant.

Screenshot 2024-03-29 at 09 58 32

Screenshot 2024-03-29 at 09 59 31

If you have any recommendations what I can try to fix this issue, I'm happy to try that. As mentioned, I have already tried uninstalling Flutter/Dart, VSCode, etc. at the moment I don't know what else I could try.

@lulupointu
Copy link

For us updating custom_lint to 0.6.4 fixed the issue 🎉

@DanTup
Copy link
Collaborator

DanTup commented Mar 29, 2024

@JonasJW thanks - the page I meant was the one marked "Timing" on the left.

Can you also confirm whether you're using any analyzer plugins? A few comments above suggest custom_lint might have have issues (that may be fixed in 0.6.4).

You should be able to check for symlinks by running find . -type l -ls in your project folder.

@JonasJW
Copy link
Author

JonasJW commented Mar 29, 2024

@DanTup thanks for the clarification!

I don't use custom_linter or any analyzer plugins.

When I run find . -type l -ls I get a long list of I suppose symlinks that probably just belong the the packages I use, for example:

111156169        0 lrwxr-xr-x    1 jonas            staff                  29 Mar  8 17:37 ./build/macos/Build/Products/Debug-platform/exercisable_flutter.app/Contents/Frameworks/FirebaseCore.framework/FirebaseCore -> Versions/Current/FirebaseCore

Is that anything out of the ordinary?

Here the screenshots of the "Timing" page:

Screenshot 2024-03-29 at 19 47 54

Screenshot 2024-03-29 at 19 48 15

@DanTup
Copy link
Collaborator

DanTup commented Apr 4, 2024

When I run find . -type l -ls I get a long list of I suppose symlinks that probably just belong the the packages I use, for example:

111156169        0 lrwxr-xr-x    1 jonas            staff                  29 Mar  8 17:37 ./build/macos/Build/Products/Debug-platform/exercisable_flutter.app/Contents/Frameworks/FirebaseCore.framework/FirebaseCore -> Versions/Current/FirebaseCore

Is that anything out of the ordinary?

That one doesn't look like a problem, but are there any that point back up the tree (eg. creating cycles or including other large parts of the disk in the the path)?

It may be useful to enable the analyzer instrumentation log (this file can get very large - be sure to turn it off afterwards) and reproduce the issue, and see if there is anything in the log file that looks out of place while this happens (for example exceptions, or paths you would not expect to be analyzed with this project open being analyzed).

You mentioned this only happens on large projects - are any of them public projects that I could test with (or that sharing logs from would not include anything sensitive)?

@JonasJW
Copy link
Author

JonasJW commented May 8, 2024

Hi @DanTup,

I apologize for taking so long to respond. I still have this issue and it's really slowing down my development process.

are there any that point back up the tree (eg. creating cycles or including other large parts of the disk in the the path)?

Here are a few symlinks, some point up but it doesn't appear to me that they would create a cycle

./windows/flutter/ephemeral/.plugin_symlinks/firebase_auth -> /Users/jonas/.pub-cache/hosted/pub.dev/firebase_auth-4.19.1/

./build/macos/Build/Intermediates.noindex/EagerLinkingTBDs/Debug/just_audio.framework/just_audio.tbd -> /Users/jonas/Documents/project_name/build/macos/Build/Intermediates.noindex/EagerLinkingTBDs/Debug/just_audio.framework/Versions/A/just_audio.tbd

./macos/Pods/Headers/Public/Firebase/Firebase.h -> ../../../Firebase/CoreOnly/Sources/Firebase.h

./ios/.symlinks/plugins/path_provider_foundation -> /Users/jonas/.pub-cache/hosted/pub.dev/path_provider_foundation-2.3.1/

./build/macos/Build/Products/Debug/FirebaseSharedSwift/FirebaseSharedSwift.framework/FirebaseSharedSwift -> Versions/Current/FirebaseSharedSwift

In total there are over 550 symlinks. Does any of this sound problematic?

I also tried the analyzer instrumentation logs but I can't really find anything that appears out of place. However, this document seems to log all kinds of stuff and I'm not sure how to analyze it or what to look for.

Yes, unfortunately, this project is private and can't be shared. I could probably share the analyzer instrumentation logs privately with you, if that would help.

I recently tested this project on a windows laptop and the issue occurs as well. (Thus, I think completely reinstalling my mac won't even help fix it).

These issues don't appear on new Flutter projects. Maybe I could try to download a big public project and see if I have problems with other bigger projects as well? If not it must be something specific with my project but I'm clueless about where the issue could be.

@DanTup
Copy link
Collaborator

DanTup commented May 8, 2024

In total there are over 550 symlinks. Does any of this sound problematic?

Nothing above looks like an issue to me - the issue would be if the link points further up the tree so that walking the tree could cause endless cycles.

I also tried the analyzer instrumentation logs but I can't really find anything that appears out of place

The most useful thing would be knowing what's being logged during the periods where performance is bad. So if the bad performance is during startup, it would be the start of the logs (until the first progress event with "kind": "end"). If it's during completion, it would be what occurs between the textDocument/completion request and the corresponding response.

Yes, unfortunately, this project is private and can't be shared. I could probably share the analyzer instrumentation logs privately with you, if that would help.

I can't accept anything confidential (instrumentation logs can contain contents of opened files and paths/errors for other files in the workspace), but if you're able to reproduce this on a copy of the project with anything confidential removed (and perhaps only a single test file open), you might be able to get a log that doesn't contain anything confidential you can share.

Something I forgot to ask earlier - can you confirm whether you have this option ticked in the VS Code (User or Workspace) settings?

image

@JonasJW
Copy link
Author

JonasJW commented May 8, 2024

Understood, I will go back to the logs and look for these progress events. If I have something to share I will follow up on it here.

The Dart: Only Analyze Projets With Open Files was disabled. I'm trying to enable it to see it that improves it, I will update you on this.

@DanTup
Copy link
Collaborator

DanTup commented May 8, 2024

The Dart: Only Analyze Projets With Open Files was disabled. I'm trying to enable it to see it that improves it, I will update you on this.

FWIW, my recommendation would be to not use that setting (and I should update the text). Although it sounds better for large projects, it was really added for a fairly specific case (command line editors that would provide the current working directory - which may be the user home dir - as the workspace folder). While the server will start up faster for very large workspaces, opening and closing files from different projects will trigger re-creating the analysis roots which can trigger "initial" analysis for those projects.

It's beneficial if you're opening a folder that contains 100 projects and maybe only opening files from a handful, but if you're jumping between a large portion of the projects in the workspace, it's probably worse overall.

@mraleph
Copy link
Member

mraleph commented Oct 3, 2024

@JonasJW what is your current experience with analysis performance? Are you still experiencing this weird behavior?

@JonasJW
Copy link
Author

JonasJW commented Oct 3, 2024

@mraleph yes, I'm still experiencing performance issues

@DanTup
Copy link
Collaborator

DanTup commented Oct 3, 2024

@JonasJW are you able to reproduce this issue with any public projects? It might be easier to narrow down with an instrumentation log, but that log will contain parts of source code from the open projects.

If it only occurs with this one specific internal project, is it possible to make a copy of it and see if you can narrow down what causes it (for example if it's made up of many packages, can you remove some of them to narrow down if it's caused by a specific package/set of packages)?

Do you also know if this issue occurs when typing in any file, or just some subset? This issue could be similar to #56307 which may be caused by the number of files that need to be reanalyzed as you modify a file (see #56307 (comment) and #56307 (comment)).

@amrgetment
Copy link

amrgetment commented Oct 3, 2024

Maybe a related issue
Memory Leaks in the custom_lint library
invertase/dart_custom_lint#248

@larssn
Copy link

larssn commented Oct 30, 2024

We have a pretty large project (internal, 200k lines), and this issue is pretty hard on productivity.

The worst of it comes from typing new class properties. The analyzer will get stuck on these for up to 20-30 seconds.

Here's my code --status and a screenshot of top memory in Activity Monitor.

Version:          Code 1.95.0 (912bb683695358a54ae0c670461738984cbb5b95, 2024-10-28T20:16:24.561Z)
OS Version:       Darwin arm64 24.0.0
CPUs:             Apple M1 Max (10 x 2400)
Memory (System):  32.00GB (0.28GB free)
Load (avg):       4, 5, 6
VM:               0%
Screen Reader:    no
Process Argv:     --crash-reporter-id 4e581022-c36a-4fd6-8d5e-12c2b8c113c3
GPU Status:       2d_canvas:                              enabled
                  canvas_oop_rasterization:               enabled_on
                  direct_rendering_display_compositor:    disabled_off_ok
                  gpu_compositing:                        enabled
                  multiple_raster_threads:                enabled_on
                  opengl:                                 enabled_on
                  rasterization:                          enabled
                  raw_draw:                               disabled_off_ok
                  skia_graphite:                          disabled_off
                  video_decode:                           enabled
                  video_encode:                           enabled
                  webgl:                                  enabled
                  webgl2:                                 enabled
                  webgpu:                                 enabled
                  webnn:                                  disabled_off

CPU %	Mem MB	   PID	Process
    0	   197	 47912	code main
    0	    98	 47915	   gpu-process
    0	    33	 47916	   utility-network-service
    0	   623	 47918	window [1] (sales_page.dart — tillty_pos)
    0	   492	 48349	extensionHost [1]
    1	    66	 48582	     electron-nodejs (config.js )
    0	     0	 48894	       /usr/bin/script -t 0 /dev/null /usr/bin/arch -arm64e xcrun xcdevice observe --usb
    0	    33	 48896	         /Applications/Xcode.app/Contents/Developer/usr/bin/xcdevice observe --usb
    0	     0	 48895	       /usr/bin/script -t 0 /dev/null /usr/bin/arch -arm64e xcrun xcdevice observe --wifi
    0	    33	 48897	         /Applications/Xcode.app/Contents/Developer/usr/bin/xcdevice observe --wifi
    6	  3736	 77823	       /Users/lars/Library/Android/sdk/emulator/qemu/darwin-aarch64/qemu-system-aarch64 -avd Pixel_Tablet_API_35
    1	    33	 77829	         /Users/lars/Library/Android/sdk/emulator/netsimd --host-dns=8.8.8.8,8.8.4.4
    0	    33	 48584	     /Users/lars/workspace/flutter/bin/cache/dart-sdk/bin/dart tooling-daemon --machine
    0	  1147	 48593	     /Users/lars/workspace/flutter/bin/cache/dart-sdk/bin/dart language-server --protocol=lsp --client-id=VS-Code --client-version=3.98.1
    0	    33	 48836	     electron-nodejs (languageserver.js )
    0	    33	 48880	     /Applications/Visual Studio Code.app/Contents/Frameworks/Code Helper (Plugin).app/Contents/MacOS/Code Helper (Plugin) /Applications/Visual Studio Code.app/Contents/Resources/app/extensions/json-language-features/server/dist/node/jsonServerMain --node-ipc --clientProcessId=48349
    0	    98	 48350	shared-process
    0	    33	 48351	fileWatcher [1]
    0	    66	 59875	ptyHost

Workspace Stats: 
|  Window (sales_page.dart — tillty_pos)
|    Folder (tillty_pos): more than 20467 files
|      File types: transitive_digest(3880) class(1518) dex(782) xml(648)
|                  h(635) len(597) grpc_back(510) json(440)
|                  jar(368) c(325)
|      Conf files: launch.json(1) tasks.json(1)
|      Launch Configs: dart(5)
image

(The top consumer seems to be the Android Emulator, which is probably fine)

Here's the Dart process (if relevant):
image

Anything else I can do to help debug this issue?

@bwilkerson
Copy link
Member

Does it benefits performance if the project is separated into different packages and organize them using dart workspace?

If the alternative is to have all of features/modules be separate packages but not part of a workspace, then yes. The benefit of a workspace is that there is a single version solve for all of the packages in the workspace, which means that it's safe for the analyzer to build the element model for each third-party package once and share them across all of the packages. Without that guarantee of a single version solve the analyzer has to build the element model for each third-party package once for every package that has a dependency on it.

If the alternative is to have a single large package with all of the code in each of the separate packages, then no, splitting it into separate packages in a workspace won't change the performance of the analyzer. On the other hand, if splitting the code into multiple packages would help to reduce the number of circular dependencies between pieces of the code, then the reduction in circularities would improve the performance of the analyzer.

@eli1stark
Copy link

@mraleph

We've been experiencing this problem for a while now. We are currently on v3.24.4, so I don't think this is a regression in Flutter 3.29 / Dart 3.7 release. At least for us, it's not. I wanted to share this to add more evidence to the case. Currently, we have refactored a bunch of circular dependencies in our project involving barrel files, we had around 250 individual cases of circular dependency, but as you pointed out, this is very easy to get even without barrel files, as demonstrated by the routing example. I wonder how the analyzer is not stuck completely when circular dependency happens but is still able to recover from this state, even if it takes longer.

@bwilkerson
Copy link
Member

I wonder how the analyzer is not stuck completely when circular dependency happens ...

It effectively analyses everything in the cycle as if it were in a single library.

@nietsmmar
Copy link

I have this problem since upgrading to Flutter 3.29.0. I have no barrel file but I use freezed, json serialization and auto route.

@therybrian
Copy link

Same issue for me. After upgrading from Flutter version 3.27.4 to 3.29.2. Android Studio has been consistently experiencing slow 'analyzing'.

@mraleph
Copy link
Member

mraleph commented Mar 24, 2025

Everybody reporting perceived regression in 3.29 please add as much information as you can to #60335 (comment)

@Sarawut-keng
Copy link

I have the same issue. Previously, I had a few barrel files, but after removing them, the performance is still just as slow. In my opinion, could this be related to the generated files? In my project, I’m only using riverpod, which creates generated files. It seems that as the number of generated files increases, the project becomes slower.

Flutter: 3.22.1
Dart: 3.4.1

@luis901101

This comment has been minimized.

@luis901101
Copy link

I see an update available on the Dart plugin in Android Studio, and it indicates some fix On-the-fly problem detection with suggestions I hope this is the fix we all need. Image

After updating the plugin I still experience the same slowness.

@mraleph
Copy link
Member

mraleph commented Mar 25, 2025

@luis901101 not surprising because I don't think we know anything about what "slowness" is nor did we actually fix anything anywhere.

If you can attach information described here. Then at least we can try to categorize the issue you are experiencing.

@luis901101
Copy link

@mraleph I already did it 3 weeks ago: #55281 (comment)

@jensjoha
Copy link
Contributor

Maybe an update is in order.

Based on the reports received so far I've identifier:

  • Many of the same requests being fired quickly, each taking longer to process than the wait until the next one is fired (more details in Dart Analyzer very slow/stuck #55281 (comment)). In 0309919 and 3873af2 some of these requests (the ones observed with this pattern) are "filtered out" which should remedy that problem.
  • I should probably also add that many of the (as I recall) getAssist calls that take ~500 ms is taking that long because of a plugin (I think it's custom_lint in all the cases I've seen) - which takes that long to respond (actually there is a timeout on 500 ms so it probably doesn't respond at all, but I haven't looked into it further).
  • From one of the videos uploaded here (thanks!) I noticed an IntelliJ behavior related to curly braces that has the potential to be bad. In 5ba5934 I've added better recovery in such a case, although - as with all recovery - it can't be perfect.

I also discovered a bug in the flutter intellij plugin (flutter/flutter-intellij#7980) which can make the analyzer become unresponsive for a while when opening a file.

None of the fixes have been released in stable yet, and I can't claim that they will definitely fix the issues you're seeing - but at least it's something.

And again: If you are experiencing issues please upload reports as described in #55281 (comment) - it actually helps :)
And if the project you are experiencing it on is open source please provide a link and some sort of description of what you are experiencing when.

@shinhyo
Copy link

shinhyo commented Mar 26, 2025

Same issue for me. After upgrading from Flutter version 3.27.4 to 3.29.2. Android Studio has been consistently experiencing slow 'analyzing'.

You are right. I downgraded to version 3.27.4 and the slowness went away.

@mraleph
Copy link
Member

mraleph commented Apr 1, 2025

For folks experiencing issues with 3.29, please see this comment. TLDR: if you are experiencing issues with Flutter 3.29 / Dart 3.7 (which you did not experience with earlier versions) and you are willing to test a fix for us leave a comment on the linked issue with your platform e.g. (Windows, Mac (X64), Mac (Apple Silicon), etc) and I will provide a custom Dart 3.7 SDK build which you can test and see if it resolves 3.29 issues.

@luis901101
Copy link

For folks experiencing issues with 3.29, please see this comment. TLDR: if you are experiencing issues with Flutter 3.29 / Dart 3.7 (which you did not experience with earlier versions) and you are willing to test a fix for us leave a comment on the linked issue with your platform e.g. (Windows, Mac (X64), Mac (Apple Silicon), etc) and I will provide a custom Dart 3.7 SDK build which you can test and see if it resolves 3.29 issues.

I'll like to test, Mac Apple Silicon over here.

@mraleph
Copy link
Member

mraleph commented Apr 1, 2025

I'll like to test, Mac Apple Silicon over here.

Instructions here. Notice this is not supposed to help with some random slowness. We are only looking to validate if this fixes regression in Flutter 3.29 / Dart 3.7. If you just experience generic slowness, which is the same in 3.29 and previous releases - then it makes no sense for you to test it. Only test it if your experience has regressed in 3.29 and you have better performance with previous stable releases.

@gisborne
Copy link

gisborne commented Apr 1, 2025

I've got this problem in spades.

It's not just that it's slow; it's that it's broken, too. If I see a red underline and hover over it, it takes 5–10 seconds for a popup to appear if one does (only works about half the time). Usually, it says nothing. When it does appear, it's often wrong.

Image

I have previously relied on the popup that appears when hovering to add import statements. That's just entirely stopped working.

The plugin has always seemed like the red-headed stepchild of Flutter efforts. It's always been slow and a bit flakey. But why is it getting worse?

@pq
Copy link
Member

pq commented Apr 1, 2025

@gisborne: are you on Flutter 3.29? If so, would you be willing to try the custom SDK @mraleph rolled? (See instructions in #60335 (comment).)

@gisborne
Copy link

gisborne commented Apr 1, 2025

Installed the custom SDK.

It's still not working properly. Time was when this would have offered to make the function for me.

Image

Time also was when:

Unnecessary use of a block function body. (Documentation)

Try using an expression function body.

would also offer to change things to an expression body.

@pq
Copy link
Member

pq commented Apr 1, 2025

Thanks for checking! The lack of an assist offering to create the function could be a different issue, but I wonder, is the popup still taking a long time to appear?

@gisborne
Copy link

gisborne commented Apr 1, 2025

The popup is still taking a long time to appear.

But then, it always did take a long time. It's about as slow now on my M4 Pro as it was on my M1.

@luis901101
Copy link

In my case after using the dart-sdk with the fix from here it has worked as expected, syntax highlighting, formatting, auto completion, auto imports all very good.

This is a test just right now:

Analysis Driver Timings:

(name: <scheduler>, count: 0, elapsed: 0:00:00.000000, elapsedSelf: -0:00:12.004791)
  (name: getUnitElement, count: 284754, elapsed: 0:00:03.113551, elapsedSelf: 0:00:01.157006)
    (name: libraryContext, count: 284754, elapsed: 0:00:01.956545, elapsedSelf: 0:00:01.501911)(bytesGet: 24121433, bytesPut: 186090, cycleCount: 1727, libraryCount: 10678, libraryLoadCount: 10597)
      (name: libraryCycle, count: 284754, elapsed: 0:00:00.116997, elapsedSelf: 0:00:00.116997)
      (name: link, count: 76, elapsed: 0:00:00.337637, elapsedSelf: 0:00:00.001427)
        (name: LibraryBuilder.build, count: 76, elapsed: 0:00:00.031726, elapsedSelf: 0:00:00.001067)
          (name: libraryFile, count: 81, elapsed: 0:00:00.030659, elapsedSelf: 0:00:00.000253)
            (name: parseCode, count: 81, elapsed: 0:00:00.030406, elapsedSelf: 0:00:00.030406)(length: 224984)
        (name: buildOutlines, count: 76, elapsed: 0:00:00.273136, elapsedSelf: 0:00:00.248209)
          (name: computeLibraryScopes, count: 76, elapsed: 0:00:00.023050, elapsedSelf: 0:00:00.015749)
            (name: buildMacroApplier, count: 76, elapsed: 0:00:00.007007, elapsedSelf: 0:00:00.007007)
            (name: executeMacroTypesPhase, count: 76, elapsed: 0:00:00.000294, elapsedSelf: 0:00:00.000294)
          (name: executeMacroDeclarationsPhase, count: 76, elapsed: 0:00:00.000685, elapsedSelf: 0:00:00.000685)
          (name: executeMacroDefinitionsPhase, count: 76, elapsed: 0:00:00.000699, elapsedSelf: 0:00:00.000699)
          (name: mergeMacroAugmentations, count: 76, elapsed: 0:00:00.000493, elapsedSelf: 0:00:00.000357)
            (name: buildAugmentationLibraryCode, count: 81, elapsed: 0:00:00.000136, elapsedSelf: 0:00:00.000136)
        (name: writeLibraries, count: 76, elapsed: 0:00:00.031348, elapsedSelf: 0:00:00.031348)(length: 186090)
  (name: analyzeFile, count: 322, elapsed: 0:00:08.891240, elapsedSelf: 0:00:04.271575)
    (name: libraryContext, count: 322, elapsed: 0:00:04.619665, elapsedSelf: 0:00:00.209948)(bytesGet: 64626977, bytesPut: 6333038, cycleCount: 59, libraryCount: 30749, libraryLoadCount: 28004)
      (name: libraryCycle, count: 322, elapsed: 0:00:00.241002, elapsedSelf: 0:00:00.241002)
      (name: link, count: 17, elapsed: 0:00:04.168715, elapsedSelf: 0:00:00.000987)
        (name: LibraryBuilder.build, count: 17, elapsed: 0:00:00.782481, elapsedSelf: 0:00:00.021290)
          (name: libraryFile, count: 2745, elapsed: 0:00:00.761191, elapsedSelf: 0:00:00.001325)
            (name: parseCode, count: 2745, elapsed: 0:00:00.759866, elapsedSelf: 0:00:00.759866)(length: 11701506)
        (name: buildOutlines, count: 17, elapsed: 0:00:03.264415, elapsedSelf: 0:00:02.666760)
          (name: computeLibraryScopes, count: 17, elapsed: 0:00:00.593127, elapsedSelf: 0:00:00.486603)
            (name: buildMacroApplier, count: 17, elapsed: 0:00:00.104714, elapsedSelf: 0:00:00.104714)
            (name: executeMacroTypesPhase, count: 17, elapsed: 0:00:00.001810, elapsedSelf: 0:00:00.001810)
          (name: executeMacroDeclarationsPhase, count: 17, elapsed: 0:00:00.001487, elapsedSelf: 0:00:00.001487)
          (name: executeMacroDefinitionsPhase, count: 17, elapsed: 0:00:00.001338, elapsedSelf: 0:00:00.001338)
          (name: mergeMacroAugmentations, count: 17, elapsed: 0:00:00.001703, elapsedSelf: 0:00:00.001103)
            (name: buildAugmentationLibraryCode, count: 2745, elapsed: 0:00:00.000600, elapsedSelf: 0:00:00.000600)
        (name: writeLibraries, count: 17, elapsed: 0:00:00.120832, elapsedSelf: 0:00:00.120832)(length: 6333038)

Video demo from Android Studio

Screen.Recording.2025-04-02.at.12.01.06.mov

Analysis Report

dart_analyzer_diagnostics_report.json


And compare with this previous test I shared before: #55281 (comment)

@mraleph
Copy link
Member

mraleph commented Apr 2, 2025

One request (to @luis901101 specifically but also to everybody else): please keep any Flutter 3.29 / Dart 3.7 related content in the 3.29 issue. If you are relatively happy with analyzer performance but experienced problem with Flutter 3.29 / Dart 3.7 - go to #60335. We are already piling too many things into this issue and it is becoming a kitchen sink.

Everything that has clear root cause - we fork discussion into a specific issue and keep it there. Only generic reports (which have not been triaged to a specific root cause) should remain here.

Thank you for understanding.

@luis901101
Copy link

@mraleph should I move my last comment to the other issue?

@mraleph
Copy link
Member

mraleph commented Apr 2, 2025

@luis901101 I think it is okay to keep it here.

@gisborne
Copy link

gisborne commented Apr 3, 2025

I've been using the test version and if anything, it's slower.

I fixed a minor type issue over a minute ago, and I'm still seeing the red squiggle shrapnel and the Dart Analysis window is still showing the error. Sometimes, it gets stuck and never notices that I've fixed something. I find myself restarting analysis every five minutes or so.

Image

@gisborne
Copy link

gisborne commented Apr 3, 2025

I'm really tired of having to work out relative paths for writing manual imports. Automatic imports does not, afaict, work at all, ever for me.

@bwilkerson
Copy link
Member

@gisborne Is the problem you're experience a regression in Flutter 3.29, or is this an issue you've been seeing since before 3.29? Just trying to establish how many performance issues we might have.

Also, could you open the server diagnostics pages, select the "Collect Report" tab, generate a report and send it to us (after reviewing the data to ensure that we didn't accidentally include any personal or confidential information in it)? Thanks.

@gisborne
Copy link

gisborne commented Apr 3, 2025

I've been having such problems for some time. A year, maybe?

Happy to do a screen share or something while we do diagnostic things, if that would help. hmu

To be clear: it has gotten significantly worse now. The analyzer is slowing me down significantly — particularly when it doesn't offer to write import statements for me.

@marcov-dart
Copy link

Are you using workspace resolution by any chance?

I thought it was neat and decided to use it. But things got unusably slow. It would analyse for minutes and then after every small change it would analyse again. I press 2 keys and there it goes again. Memory usage was at 13.8 Gb. I just reverted back and now it is at 3.4Gb when I load my big workspace. It still needs time (a minute or so) to analyse after I open my workspace but not nearly as long and it stopped needing to analyse again and again after ever small change.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
analyzer-stability area-dart-model For issues related to conformance to the language spec in the parser, compilers or the CLI analyzer. model-performance Performance/memory issues in analyzer/cfe P2 A bug or feature request we're likely to work on type-performance Issue relates to performance or code size
Projects
None yet
Development

No branches or pull requests