Troubleshoot common Scala issues
Check the following answers on most common scala/sbt questions that can help you solve compiler, performance or code highlighting issues you might come across while working with your project.
The Scala plugin uses its own type checker and performs its own type inference in real time, while you type your code. The type checking is optimized for editing rather than compiling code. Its logic is independent of the Scala compiler so that it can work with incomplete code and doesn't require prior compilation. However, it also means that sometimes the results of the Scala plugin type checking differ from the Scala compiler – and that's a bug.
Typically this happens when the code is complex, and you just made an important modification. The type checker might need time to catch up, and occasionally it might fail.
Try to update IntelliJ IDEA & the Scala plugin. It is possible that you experience an issue that was already reported and fixed.
You may also look through our list of open and fixed tickets on our YouTrack. If you find a ticket describing an issue similar to yours, and it's fixed, but not yet released on the Public update channel, you may consider switching to the Nightly update channel.
If the above doesn't work then, first, create a ticket for us.
If the type-aware highlighting highlights the correct code, and it's an error that happens rarely, try to disable the highlighting locally.
Highlight the code and from the main menu select Code | Surround With.
Select the / * _ * /.../ * _ * / option from the list.
The error is not highlighted anymore.
note
The type-aware highlighting is enabled in your project by default. To disable it, press Ctrl+Alt+Shift+E. If the highlighting level is set to None, then the type-aware highlighting will also be disabled. Use the same shortcut to enable the highlighting.
If a lot of code is highlighted incorrectly, consider enabling Compiler-based highlighting. Go to Settings | Languages & Frameworks | Scala and on the Editor tab switch the error highlighting to Compiler.
note
However, before that, think about possible drawbacks. Compiler-based highlighting is slower, it requires more resources (type checking is done twice, .class files are generated), the highlighted code does not come with quick-fixes proposals, it is not optimized for on-the-fly editing, and requires full compilation of the project, which means it might not work for incomplete code.
Change the Scala version to 2.12 and later. We also recommend that you use unique names for private methods in value classes.
In most cases your project JDK is not compatible with Scala or sbt version, try to change the Scala Compile Server SDK.
Press CtrlAlt0S to open Settings dialog.
From the options on the left, select Build, Execution, Deployment | Compiler | Scala | Scala Compiler Server.
In JVM SDK field specify the appropriate SDK.
We recommend that you switch to Java 8 SDK since the Scala version 2.12, and sbt versions 1.10 and later are not compatible with older Java SDK versions.
To fix Out Of Memory
issues with the Scala compiler, increase the heap size in the JVM maximum heap size field of the Scala compiler server settings located in File | Settings | Languages & Frameworks.
You would need to add the build.sbt file to your project, describe your whole project inside build.sbt and then re-import the project.
We recommend that you choose the sbt-based project right from the start.
When you build sbt projects, keep in mind that the IDEA project model doesn't really have the same concept of configurations as sbt does, so only compile and test are fully supported. For other cases we recommend that you run the build from the integrated sbt shell.
When your sbt process doesn't have enough memory, increase maximum heap size in the sbt settings (click the located in the sbt projects tool window).
Figuring out if an import is used or not is complex and costly, and sometimes - for example in some cases of implicit conversions imported from another package – the Scala plugin may wrongly mark your import as unused. And then, when you call the "Optimize Imports" action, that import will be removed.
Consider this example:
Notice that import Mappers._
in HelloWorld
is marked as unused. You can make IntelliJ IDEA and the Scala plugin aware that this import is actually used by opening the quick-fix popup menu and choosing Mark import as always used in this project.
The import will be added to the list of imports always considered to be used. You can modify the list in Settings | Editor | CodeStyle | Scala | Imports.
It might also happen that your import is marked as unused and removed immediately, preventing you from using the quick-fix. It means that you have enabled the Optimize imports on the fly mode. Go to Settings | Editor | General | Auto Import and turn it off.
In most cases, the Scala version of your project will be specified in the build script of your project (e.g. SBT) and when you import the project, IntelliJ IDEA will pick it up. But it may happen that you create a Scala project from scratch in IntelliJ IDEA, or that you need to update the Scala version in the build script after the project is created, and IntelliJ IDEA does not register the change.
Go to File | Project Structure and from the list on the left choose Global Libraries. There you can download and add a new Scala SDK, set the Scala version, and remove the old SDK from your project.
Thanks for your feedback!