Performance tuning tips
This article gives a summary of helpful techniques that you can use to improve RustRover performance on large-scale projects.
To check whether performance slowdowns are caused by low heap memory, enable the memory indicator:
Navigate to View | Appearance | Status Bar Widgets and select Memory Indicator.
The memory indicator will appear in the bottom right corner:
data:image/s3,"s3://crabby-images/0139b/0139b2e0ebdd3655ba776d15d639e5b8eac5da69" alt="Memory indicator Memory indicator"
Select Help | Change Memory Settings from the main menu.
In the dialog that opens, set a higher memory heap value in the Maximum Heap Size field.
Click Save and Restart.
data:image/s3,"s3://crabby-images/dd3ae/dd3ae9180930c4824af54fffd4f201afb2bf7f87" alt="Increasing heap in the Change Memory Settings dialog Increasing heap in the Change Memory Settings dialog"
RustRover also warns you if the amount of the free heap memory is less than 5% of the maximum heap size:
data:image/s3,"s3://crabby-images/0fe36/0fe36ea37a972d47afb4c6da790affc0786e1733" alt="Low memory warning Low memory warning"
Click Configure and enter a new heap size value in the dialog that opens.
On-the-fly code analysis is one of the most performance-consuming processes in RustRover. Here's what you can do to lighten it up.
By default, external linters do not run on the fly. However, if you have configured them to do so, RustRover may experience performance slowdowns. In this case, you will see a notification:
data:image/s3,"s3://crabby-images/ab771/ab7715e12ecc4d3a13e54dec81f6f00c8354f0aa" alt="External linters performance External linters performance"
If you see the notification, click Disbale.
Alternatively, navigate to Settings | Rust | External Linters and clear the Run external linter on the fly checkbox:
data:image/s3,"s3://crabby-images/e630a/e630a39a6d5c72b902388ba2a5470689bc5a8d0d" alt="External linter settings: on-the-fly analysis off External linter settings: on-the-fly analysis off"
By default, many RustRover inspections are set to run on the fly. To lighten up the process, you can reduce the list of these inspections: navigate to Settings | Editor | Inspections and browse through the list of inspections, clearing the checkboxes for those you prefer not to run on the fly.
data:image/s3,"s3://crabby-images/2ca29/2ca29e4452574ba67639606edb7b8d69c2d63799" alt="Disable performance-consuming inspections Disable performance-consuming inspections"
You will always be able to run inspections on demand using the Code | Running Code Cleanup with profile ''{0}'' command and explore the results in a separate tool window without affecting the editor. Also, you can postpone code analysis (and on-the-fly refactoring) until commit by setting up the Before Commit options.
You can configure the highlighting level for the currently opened file: none, syntax, or all problems. Use the inspection widget in the upper-right corner of the editor:
data:image/s3,"s3://crabby-images/bb553/bb55377a40f13aa6d0289c4393028921504701f6" alt="Inspection widget Inspection widget"
As an alternative to configuring individual checks or files one by one, try Power Save Mode. It disables all inspections and other highly-consuming background tasks for the entire IDE.
To enable Power Save Mode call File | Power Save Mode.
data:image/s3,"s3://crabby-images/aef0d/aef0daa3ab9f85dc23219759da104e1115ef4c3c" alt="Power save mode ON Power save mode ON"
Your project may contain folders with binaries, logs, or build artifacts, which do not affect RustRover code insight. Also, indexing some folders can be too expensive due to their size or location. So it is reasonable to exclude such folders manually: right-click the directory in the project tree and select Mark Directory as | Excluded.
data:image/s3,"s3://crabby-images/44ffc/44ffc59885bcab4c316d7ece653d64277d46c059" alt="Mark directory as excluded Mark directory as excluded"
Since the symbols from the excluded files remain uncompleted for RustRover, the following features are not available for such files: code completion and auto-import, code generation, Find in Files (except for the scope of the currently opened files), navigation, and refactorings.
tip
If you are working in remote development mode, the directories you mark as excluded will not be synchronized with the remote machine.
Another way to eliminate files like logs or generated data from indexing is to exclude them by file type in Settings | Editor | File Types:
data:image/s3,"s3://crabby-images/def7d/def7d7b7506140d1fa7bb38f69f2fa1e340ccdeb" alt="Ignored files types Ignored files types"
To increase the IDE performance, try disabling the plugins you don't need. You will always be able to turn them on again later.
Go to Settings | Plugins.
Browse the Installed tab and disable the unnecessary plugins:
You can also disable all manually installed plugins at once (the non-bundled ones) from the menu under
:
If you experience an IDE freeze or high CPU/memory usage, and the tips listed above do not help, please provide us with the IDE logs, thread dumps, and snapshots. For more information about retrieving and sending them, refer to this instruction.
Thanks for your feedback!