Using MPS inside IntelliJ IDEA
We are going to show how to use MPS languages inside IntelliJ IDEA in this document. You may also like to check out the screencast covering this topic.
Note: Make sure you have IntelliJ installed. Both Community and Ultimate Edition would work.
Download the MPS IntelliJ IDEA plugin from the MPS download page (currently unavailable), download it from the JetBrains Marketplace or install it directly using IntelliJ IDEA's plugin manager. If installing manually, the downloaded plugin zip file must be unzipped into the IDEA's plugin folder. Also make sure, that you are downloading the MPS plugin with version number corresponsing to the IDEA version (the IDEA's plugin manager will take care of this automatically).
Windows and Linux: typically USER_HOME/IDEA_version/config/plugins or IDEA_HOME/plugins
MacOS: ~/Library/Application Support/Idea_version/ or IDEA_HOME/plugins
warning
Do not use the plugin manager to install the plugin from disk using the zip file downloaded from the MPS download page (does not apply to the JetBrains Marketplace downloads), since the zip file is not a valid plugin zip and it contains several plugins packaged together.
The zip file holds several MPS plugins, three of which are essential:
mps-core - holds the core MPS functionality
mps-java - enables BaseLanguage and its extensions
mps-vcs - allows VCS for MPS models in IntelliJ IDEA
tip
Please, bear in mind that each MPS plugin version is compatible only with a particular version of IntelliJ IDEA. Typically, the latest released MPS plugin is compatible with the IntelliJ IDEA version that was latest at the time of the MPS release and the following IDEA minor versions. The EAP versions of the MPS plugin are usually compatible with the current IntelliJ IDEA version.
The plugin manager in IntelliJ IDEA will only give you access to a compatible version of the MPS plugin, so this option is always a safe bet.
If you manually install an incompatible version of the plugin, IDEA will refuse to load it during start up, will log an error and mark the plugin in red in the plugin manager.
After installation, the plugin directory should look something like this:
data:image/s3,"s3://crabby-images/909ac/909ac22506b9a72039e59c1acdfe9d662f804488" alt="Plug1.png Plug1.png"
This will enable MPS and the core set of languages to be available inside IntelliJ IDEA once you restart it.
The Plugin Manager in IntelliJ IDEA should now list several MPS plugins, which you can turn on and off as needed:
data:image/s3,"s3://crabby-images/bd207/bd207af39dc3aba0b00228f86a8d64799eb40f7f" alt="Plug2.png Plug2.png"
You can now enable the MPS facet for your IntelliJ IDEA projects:
data:image/s3,"s3://crabby-images/ad252/ad2523a7dbe5156f065d7317dbc3e0e8d9b0ad23" alt="Iplug3.png Iplug3.png"
The facet offers several configuration points, but you most likely want to stick to the default settings for your first experiments.
data:image/s3,"s3://crabby-images/54169/541695530e29c6a64d98dd01314b0d88f3bbcb0d" alt="Plug3.png Plug3.png"
Adding the MPS facet to a project's module will create a models node in the Project View and allow you to create MPS models. If not, just create one on the Sources tab:
data:image/s3,"s3://crabby-images/8cc3e/8cc3e446d2c664e19f16ecff995ededcdc70c0f1" alt="Plug4.png Plug4.png"
You need to mark it as a Model Folder (the icon next to the models folder should turn blue):
data:image/s3,"s3://crabby-images/188e4/188e49c635d4088c4b7f5c5155544de5bca49f03" alt="Plug5.png Plug5.png"
The final step is to mark the models folder as a Sources directory of the module:
data:image/s3,"s3://crabby-images/2aa0b/2aa0b132b25c2f483a982c73b2999a8f58521db1" alt="Plug6.png Plug6.png"
Once the MPS facet is configured and has one or more Model Roots marked Model as well as Sources Folders, you can create models in them:
data:image/s3,"s3://crabby-images/3071f/3071f2b6aa9dc6522367b96d6811aa2821e2a95c" alt="plug7.png plug7.png"
When creating a new model, you have to specify its name and choose one of the available model Kinds through the Create New Model dialog:
data:image/s3,"s3://crabby-images/91e7d/91e7dd8625e9d364f751751db6d0bc62b46af495" alt="plug8.png plug8.png"
Each model Kind in this case represents a preconfigured set of used languages for the model. This is a convenient shorthand that still allows you to tune the list of used languages manually at any time through the Model Properties dialog by pressing F4 or AltEnter on the model node inside the Project View: The list of Kinds is currently set to contain only these two options (Empty and Java), but will be configurable in the future releases.
Right-clicking on a model will display the imported models and used languages:
data:image/s3,"s3://crabby-images/a6fb4/a6fb41f5a2262a0ee035779c7848e70cf6306e78" alt="plug9.png plug9.png"
The MPS models let you create new nodes from the imported languages the same way you would do it in MPS itself: Model Nodes in the Project View represent the content of MPS models and just like in MPS they are similar to java packages. You can create model elements (Roots) in them:
data:image/s3,"s3://crabby-images/4c5ca/4c5caea07d4e0889a44df49d39a82e8b45035ff5" alt="plug10.png plug10.png"
Similarly to when we were creating new MPS models, you give each root element a name and a kind, which now means its MPS Concept:
data:image/s3,"s3://crabby-images/618bb/618bb99661e964a37cc0391f35a9992b90d62a4b" alt="plug11.png plug11.png"
The root nodes are displayed in the Project View and look very similar to how other resources and files look in IntelliJ IDEA. The projectional editor for a root node can be opened by double-clicking on the root node or by pressing F4.
data:image/s3,"s3://crabby-images/4bc99/4bc99fa1953b22ea91204d4f4bb51393fc8c3dd9" alt="plug12.png plug12.png"
The code process of MPS models is tied to the IntelliJ IDEA's make/rebuild project actions and so will be triggerred automatically.
It's possible to configure where to store the generated source code. This is configured through the MPS facet settings dialog. There are three options you can choose from:
The generated code stays in memory only. It will be available during the compilation process only and never saved to disk at all
It can be saved into a configured source folder of this module
It can be saved into any other directory wherever on the disk
data:image/s3,"s3://crabby-images/7f52d/7f52da12c80ff1d36b1a8135ee7934c127cf1f12" alt="3-SetGeneratorOutputPath.png 3-SetGeneratorOutputPath.png"
Now you probably can't wait to try out your own language inside IntelliJ IDEA. All you need to do is to unpackage the plugin zip file into the same IntelliJ IDEA's plugins folder that we unzipped the core plugin into earlier:
data:image/s3,"s3://crabby-images/5db09/5db0922442f713bd3dfcf054139626d45f1fd681" alt="Iplug6.png Iplug6.png"
Additionally, many of the plugins have been shared through JetBrains Marketplace and so can be comfortably downloaded through the IDEA's plugin manager.
After you restart IntelliJ IDEA, you will be able to add your language(s) that came through the plugin to the list of used languages:
data:image/s3,"s3://crabby-images/44e05/44e053f0e255640d9db265098e6a737497de7c23" alt="plug14.png plug14.png"
This should be enough to enable your custom language(s) for use inside IntelliJ IDEA.
Your languages will typically come with runtime dependencies on other languages or solutions. Although they typically come bundled as jar files inside the plugin zip file, they need to be imported as module dependencies into IntelliJ IDEA.. The MPS facet does that automatically once you add a language with a runtime dependency.
data:image/s3,"s3://crabby-images/34318/34318e123112077b1105f132087de9d496c9b270" alt="plug15.png plug15.png"
tip
In case you needed to add run-time libraries manually, the real location of these dependencies (jar files) is under the particular language plugin folder in the IntelliJ IDEA's plugins location.
The MPS IDEA plugin integrates your MPS code tightly into the rest of the Java project. MPS code will seamlessly participate in IDEA's build and make, you can cross-navigate to usages or definitions between Java and BaseLanguage as well as refactorings will correctly include all the sources.
MPS gives you a convenient option to quickly convert Java code to BaseLanguage and migrate it into an MPS model. Just right-click the desired Java package and select Convert Java to MPS.
data:image/s3,"s3://crabby-images/27eb6/27eb60cc373b1c08479d4bca533a5454e125b7ad" alt="Convert.png Convert.png"
Just like MPS itself, the MPS plugin can be configured and customized using the Settings dialog, which you can invoke through the menu, a toolbar or using a keyboard shortcut CtrlAltShift0S. MPS has added a couple of configuration screens to the IntelliJ IDEA's Settings dialog, which allow you to configure several aspects of how MPS behaves.
data:image/s3,"s3://crabby-images/2492c/2492c17e697d4c700be6b0efd99c3d2239cc7a6e" alt="EditorConfig.png EditorConfig.png"
data:image/s3,"s3://crabby-images/48cb8/48cb8f599e3a49ba335dc31a1e441bd852774ec3" alt="StyleConfig.png StyleConfig.png"
Additionally, you need to make sure the Use external build flag in the IDEA Compiler settings is turned off, otherwise you won't be able to rebuild your project.
data:image/s3,"s3://crabby-images/0d0d2/0d0d24401fa08b1b97a3cbf8cba8a305a697dbb3" alt="genImg2.png genImg2.png"
Thanks for your feedback!