Plugin Aspect¶ ⧉
Plugins are a way to integrate your code with the MPS IDE functionality.
— MPS documentation
This aspect is deprecated, use plugin solutions ⧉ instead. This page still describes the content of this aspect because its languages are also used in the solution. The name of the solutions ususally end in .pluginSolution or .plugin.
General¶
How do facets work?
Red rectangles: marker facets
- Do not define dependencies on other facets.
- They are known to the MPS make process and are available for users.
- You can define where your facet should fit in and decide if you require some facet.
Usage:
- Targets act as filters working on a stream of data delivered to them.
- The data flowing along targets is called resources.
- Resources are represented as Java interfaces and tuples.
How do I move a solution?
Given I have a project with a test solution open and the solution is stored in
code/com.my/solutions/com.my.solution.to.move
, which is the wrong place. It should becode/com.my/test/com.my.solution.to.move
instead.I want to move the solution in the filesystem to its correct place. How can I move the solution without breaking the project?
- Move
code/com.my/solutions/com.my.solution.to.move
tocode/com.my.project/test/com.my.project.solution.to.move
. - Close the MPS project and reopen it (no need to restart MPS).
- Add back the .msd files as follows:
- Right-click on the workspace root node and open Project Paths (Alt+Enter).
- Click on the red, old solution file, and on -.
- Click on + and select the new location of this .msd file.
- Open your build script for CI tests and update the solution path in the project structure.
contributed by: @abstraktor
How do you guide the user through cleaning up after deleting a referenced node?
Given I have a concept
Ball
and I have a referenceBallRef
. When I have aBall
node, and I haveBallRef
s to it all over my model. When I delete the ball, then I have a lot of dangling references. How may I get guidance in cleaning up these dangling references?
You can show a balloon that says, for example:
When clicking show, it will open a usage search for the deleted node using ConsoleUtil.show
. This functionality is implemented with a model listener in a quite generic fashion.
Here are a few insights:
- Ensure not to show the node in the searched for part of the window. VCS will try to highlight it and run into an NPE (MPS 2019.3)
- Consider cut and paste or moving elements: these operations also yield a removal event. Hide the balloon again once the node gets added again.
contributed by: @abstraktor
How can you ensure that the IDE loads a JAR exactly once and never again?
I have a JAR file that depends on a native library (.dll/.so). To use it in an MPS plugin, I have a stubs solution for it. Unfortunately, without further ado, MPS sometimes tries to reload the jar (e.g., after a rebuild) and it will fail because the JVM does not allow reloading of native libraries.
How can I avoid this problem?
To prevent that MPS will ever (re-)load .jars / stubs of a solution, you can check the facet "IDEA Plugin" in the "Facets" tab of the solution properties. This facet will show another tab where you must set the Plugin ID com.intellij
.
We must ensure that the JARs can be found at runtime (i.e., they must be on the classpath). The most straightforward approach would be to put them into the application's lib directory (e.g., MPS installation / your product RCP).
contributed by: @till-f
How can you use an IntelliJ icon for an action?
I want to use one of the icons shipped with IntelliJ for my action (
jetbrains.mps.lang.plugin.structure.ActionDeclaration
). How can I reference the icon? (note: this question might be deprecated for modern MPS versions)
You can use IconLoader#getIcon
in the reflective editor. Right-click the editor for the icon, use show reflective editor
, and enter the expression as shown in the screenshot:
contributed by: @till-f
How to use a projection mode switcher to alter an editor component?
I have a concept editor in which I use an EditorComponent \(A\). Using the projection menu entry, I would like to switch to another editor component \(B\) upon activation.
First \(B\) must override \(A\), and the applicable concept
also must not differ. Then for \(B\) in applicable in context
, we must provide a concept editor context hint.
This hint must also be referenced from a Projection Mode Switcher.
Afterwards, you will find a new entry in the Projection menu.
Hint when used with Grammar Cells: you have to disable component inlining, which can be activated by an intention at the position where the include of \(A\) happens. Also, in any editor component that inherits from \(A\) and \(A\) itself, we cannot use Grammar Cells.
contributed by: @dbinkele
Languages/Features¶
Most additional plugins are contributed by languages in MPS Extensions ⧉, and mbeddr platform ⧉.
I want to merge models.
Use the language de.itemis.mps.modelmerger from MPS Extensions ⧉.
I want to verify the structure of a node.
Use the language de.slisson.mps.structurecheck from MPS Extensions ⧉.
I want to store different states/versions of a node inside the model.
Use the language de.itemis.mps.nodeversioning from MPS Extensions ⧉.
Open API¶
This section contains code-related questions and answers.
How do you create a new SContainmentLink for a non-existent role?
Create it through MetaAdapterFactory ⧉.
How do you check if a model is a generator or a test model?
Call the corresponding method in SModelStereotype ⧉.
How do you add imports to a model?
Use the class ModelImportHelper ⧉ and call addImport
.
How can you open an MPS Editor Tab programmatically?
Is it possible to associate an MPS-Aspect with more than one node?
Troubleshooting¶
Plugin troubleshooting topics often overlap with IntelliJ topics. The reason for this is that the languages that deal with plugins often compile down to IntelliJ platform features such as MPS actions that generate into IntelliJ actions ⧉.
A reference to a key in an action context parameter is out of the search scope.
You need to add a dependency to MPSCommonDataKeys ⧉. This class extends PlatformDataKeys ⧉ , and this class extends CommonDataKeys ⧉.
The action isn't visible.
You have to add it to an ActionGroup
that can be attached to different places, such as the context or build menu.
All action context parameters marked as required must be available isApplicable
block must
return true for an action to be visible. For debugging purposes, you can set always visible to true to check if your
action is registered.
You must have a standalone descriptor in your model. Set the solution kind to Other in the Java tab of the solution properties (Plugin | MPS ⧉).