Font size can be quickly adjusted in the currently open editor window by holding Control and rolling the mouse wheel. Font size is not persistent so when the file is re-opened the text size is reset to the default value. You can enable/disable the feature in settings in the Editor / General section: Change font size with Ctrl+Mouse Wheel.
It is now possible to refer to the input node of a LOOP macro using LOOP.inputNode expression, removing the need to use a VAR macro. The index of the LOOP can also be accessed under the same namespace, using LOOP.index , replacing the previous user defined context variable.
It is now possible to switch off the scrolling synchronization of the editors in the Diff dialog using the dedicated button.
The MPS model viewer is enabled for the merge commits. The viewer shows three panels - the center panel for the merged model and left and right panels for the models of two merged branches.
The root annotation and root/node history algorithm was based on the iteration over the ordered list of file revisions. The changes for the root were calculated between two adjacent revisions. It could happen that these revisions were from two different branches. In this case the obtained changes make no sense. Merge revisions were not handled correctly as well. The changes from the older revisions could be erroneously displayed as changes from the newer merge revision. Therefore, the revisions graph should be considered for calculating the correct history of the changes rather than a simple list.
The lang.text language has been enhanced with several new capabilities, which directly enhances the single and multi-line comments in BaseLanguage.
The method signature refactoring dialog now includes a way to specify default values for new arguments or arguments whose type has changed. When a parameter is removed but is still used in the method, a new local variable is introduced so the reference is not lost. In addition, vararg typed parameters are now handled.
When the call of a method does not match its signature, an intention allows to change the method signature according to the call. This intention has been improved to map the existing parameters in a smart way, so a maximum amount of existing parameters are reused and their references kept.
model.nodesIncludingImported() now support #expression to specify concepts, much like
.nodes() did for quite a while. https://youtrack.jetbrains.com/issue/MPS-32743
For Generators, there's an option to check whether nodes template produce fit into proper role of a parent node. The option if available in Generator Preferences in IDE as well as through build project settings. Generator may issue a warning, which usually indicates there's some inconsistency in templates, e.g. improperly placed
COPY-SRC annotation. Compiled templates, however, didn't perform the check, rendering the option useless. With 2021.1, compiled templated go an extra mile to check proper child placement into a parent if the option is active.
SNode.setReference(SReferenceLink, SNodeReference) to avoid going through
SReference.create() factory method
Now, when MPS creates a new project, we write indicator of actual version into project descriptor so that Migration Assistant doesn't try to apply older project migration than the one indicated with baseline. Project Migration implementation indicate which minimum baseline version they need to run.
No longer JUnit3 and its
junit.framework.TestCase superclass limitation.
The indent layout implementation has been made incremental in some key cases, which will reduce the rendering time for big models in languages using mainly indent layout (such as baseLanguage). This feature can be disabled with the vm option mps.indent_layout.disable_incremental in case of trouble.
A lot has been changed in approach to Java compilation of MPS modules. We started this change to address one of our top-voted issues, Annotation Processing support (https://youtrack.jetbrains.com/issue/MPS-27653). We switched MPS Java Compiler infrastructure to utilise
javax.tools.JavaCompiler set of APIs. Now, MPS can use any compiler that implements this standard API, as of MPS 2021.1 we run with a default compiler configured for the API, with an option to use Eclipse Java Compiler, if present. When ECJ libraries are in classpath, you may switch MPS to use Eclipse Java Compiler with '
mps.compiler.java=ecj' as the system property (e.g. by editing 'mps.vmpoptions'). In case you experience unrecoverable issues using new compiler infrastructure, there's also an option to switch back to legacy mechanism of direct ECJ API use, put 'ecjlegacy' as the value for '
mps.compiler.java' system property.
Beside, now we run compiler with '
-release' option, with version specified in project preferences (Preferences -> Java Compiler). This option is a bit more strict than combination of
-target options MPS relied on in previous releases, as it controls uses of library APIs that were available in certain releases. You may need to bump up Java version in your project in case you encounter compilation issues due to use of APIs not available in certain release.
To evolve GenPlan extensibility story, there's a new mechanism to include languages/generators that are unknown to the plan designer. Now, with `
transform` statement, language designer may include a language that targets or extends a given one. Language B 'targets' Language A means B language's generator produces constructs of Language A.
For a long time, MPS assumed all modules coming from language plugins were visible to end user. With number of languages growing, as well as complexity of plugins, there are cases when Language Designer want to hide certain modules not to confuse/overwhelm end user with huge number of unrelated languages or solutions. Plugins tell MPS about modules they contribute by means of `
com.intellij.mps.LanguageLibrary` extension point. Now, extensions to the point may provide optional `
hide="true"` attribute, that makes modules of the plugin eligible to filtering by pattern specified with `
com.intellij.mps.VisibleModuleMask` (MPS-26427). Most MPS plugins now bear the flag, facilitating filtering of MPS own languages in case Language Designer needs to hide them. MPS provides masks for its own modules as part of `jetbrains.mps.ide.devkit` plugin, authors of a custom IDE generally don't include this plugin into a distribution, and have full control over visible modules in their product.