IntelliJ Platform SDK DevGuide

Edit page

Dynamic Plugins

Starting with 2020.1 release, the ability to install, update and uninstall plugins without restarting the IDE is available in the IntelliJ Platform. During plugin development, this also allows avoiding restarts of the IDE Development Instance after every code change.

For a plugin to support this, all restrictions listed below must be met. To verify a plugin locally, run Plugin DevKit | Plugin descriptor | Plugin.xml dynamic plugin verification inspection on all plugin descriptor files (required plugin.xml as well as any additional files).

For plugins hosted on the JetBrains Plugins Repository the built-in Plugin Verifier will run these checks automatically. See Plugin Verifier for more information on how to run it locally.

During development, Enabling Auto-Reload will allow code changes to take effect immediately in the sandbox IDE instance.

No Use of Components

No Components must be used; existing ones must be migrated to services, extensions or listeners.

Action Group Requires ID

All <group>s must declare a unique id.

Use Only Dynamic Extensions

All extensions, whether defined in the platform itself or coming from other plugins, must be marked as dynamic (see next paragraph).

Mark Extension Points as Dynamic

All extension points provided by the plugin must adhere to specific usage rules and then be declared ready for dynamic use explicitly.

Configurables Depending on Extension Points

Any Configurable which depends on dynamic extension points must implement Configurable.WithEpDependencies.

No Use of Service Overrides

Application, project and module services declared with overrides="true" are not allowed.

Plugin Load/Unload Events

Register com.intellij.ide.plugins.DynamicPluginListener listener to receive updates on plugin load/unload events.

Last modified: 14 May 2020