概要

工欲善其事必先利其器,虽然IntelliJ IDEA的功能已经足够的强大,但是也无法满足开发人员想要的一切功能。对于此,IDEA提供了API接口供开发者进行插件开发扩展,但目前来说,网上对于IDEA插件开发的文档大多讲的不是很清楚,自己最近也开发了一个IDEA插件,中间踩了不少坑,在此总结下。

一般来说,开发人员开发的IntelliJ平台插件主要分为如下几类:

自定义编程语言的支持:包括语法高亮、文件类型识别、代码格式化、代码查看和自动补全等等。这类插件包括.gitignore,.shell这些。框架继承:其实就是类似基于IntelliJ开发出另一个IDEA,比如AndroidStudio就是通过将Android SDK整合到了IntelliJ IDEA当中。比如还可以将Spring、Struts等框架集成到IDEA中,方便用户在IDEA使用使用特定的框架更加的方便工具集成:对于IDEA定制一些个性化或者是实用的工具,比如lombok和translation插附加UI:对于标准的UI界面进行修改,如在编辑框中加入一个背景图片等等。

IDEA中提供的用于进行插件开发的接口非常多,本文主要介绍几个开发时常见的接口和类。

创建plugin工程

目前来说,IDEA插件开发有两种模式,第一种是直接在IDEA中创建插件开发的项目,第二种是使用Gradle来构建Intellij插件。下面两种方式都会介绍下:

IDEA中新建plugin项目

创建plugin项目:

在创建项目时选择IntelliJ Platform PluginProject SDK需要选择插件开发特有的SDK(注意不是JDK),没有相应的SDK需要new一个可以根据自己需要开发的插件选择相应的库和框架

这时就完成了插件项目的创建,如下所示:

可以看到创建出的project非常的简单,仅在META-INF文件夹中有一个plugin.xml配置文件~plugin.xml配置文件会在后面具体介绍。

使用Gradle来构建Intellij插件

Gradle的好处就不多说了,已经完全占领了Android的构建编译。使用Gradle来构建Intellij插件需要添加官方的插件支持。

首选需要创建一个Gradle项目:

创建好的Gradle项目中会出现一堆与Gradle相关的文件夹和文件,这个时候只需要关注build.gradle即可。

这时我们需要在build.gradle中新增相关的依赖,让项目能够支持构建IDEA插件。步骤如下:

1.添加 IntelliJ build plugins仓库地址

plugins { id ‘org.jetbrains.intellij’ version ‘0.3.1’ }

2.使用IntelliJ IDEA的插件

apply plugin: “org.jetbrains.intellij” apply plugin: ‘java’ apply plugin: ‘idea’

3.设置运行插件的IntelliJ的版本以及沙箱地址

intellij { version = ‘2017.3’ //调试我们插件的版本 sandboxDirectory = project.rootDir.canonicalPath + “/.sandbox” //插件生成的临时文件的地址,可以省略}

设置好了后,登陆Gradle构建成功即可

4.需要在resources目录下新建META-INF/plugin.xml文件。即完成了插件项目的构建

两种创建方式的差异 项目本身的差异 SDK的差异:
使用IDEA创建的插件项目中SDK为 IDEA插件专用的SDK使用Gradle编译的插件项目SDK为 JDKIDEA.iml文件中type不同
使用IDEA创建的插件项目中xxx.iml中type为PLUGIN_MODULE使用Gradle编译的插件项目中xxx.iml中type为JAVA_MODULE 运行方式的差异

1.对于IDEA创建的插件项目在运行时需要创建一个plugin的运行方式,如下图所示:

创建好了后需要配置两个参数,如下所示:

Use classpath of module:选择当前的module即可,这里需要注意如果xxx.iml文件中type不为PLUGIN_MODULE那么这里将会找不到该MODULE,会报Run Configuration Error: No plugin module specified for configuration错误

2.对于使用Gradle编译的插件项目,需要创建gradle的运行方式,如下图所示:

创建好后参数配置为:

选择相应的project,Tasks为 :runIde

plugin.xml

IDEA插件的工程创建完毕后,都会在META目录下创建一个plugin.xml文件,对Android开发比较熟悉的同学可以将它理解为AndroidMainFest.xml,里面定义了一些组件、事件等需要注册的内容。

一个新创建好的项目中plugin.xml的内容为:

?xml version=”1.0″ encoding=”UTF-8″?> <idea-plugin> <id>com.your.company.unique.plugin.id</id> <name>Plugin display name here</name> <vendor email=”support@yourcompany.com” url=”http://www.yourcompany.com”>YourCompany</vendor> <version>1.0.0</version> <description><![CDATA[ Enter short description for your plugin here.<br> <em>most HTML tags may be used</em> ]]></description> <category>Tools Integration</category> <!– please see http://www.jetbrains.org/intellij/sdk/docs/basics/getting_started/plugin_compatibility.html on how to target different products –> <!– uncomment to enable plugin in all products <depends>com.intellij.modules.lang</depends> –> <!– please see http://www.jetbrains.org/intellij/sdk/docs/basics/getting_started/build_number_ranges.html for description –> <idea-version since-build=”162.00″/> <extensions defaultExtensionNs=”com.intellij”> <!– Add your extensions here –> </extensions> <actions> <!– Add your actions here –> </actions> <change-notes><![CDATA[ ]]> </change-notes> </idea-plugin>

在这里说明下上面的 plugin.xml 中出现的几个名词

id:表示当前插件的唯一id号name:插件的名称version:插件的版本号vendor:填写开发人的邮箱,公司名称description:插件的描述,如果将插件上传到IDEA的仓库后,在进行下载的时候就会显示该描述idea-version:表示当前插件所支持的所有Intellij Idea 的版本, 详细信息可以参照这个对应关系extensions:这里一般会放一些我们自己的扩展的东西,比如新增高亮显示,新增语言支持都是需要在这里进行扩展actions:新增的Action类需要在这里注册,用于菜单栏扩展 <application-components> <component> <implementation-class>com.test.Application</implementation-class> </component> </application-components> <project-components> <component> <implementation-class>com.test.Project</implementation-class> </component> </project-components> <module-components> <component> <implementation-class>com.test.Module</implementation-class> </component> </module-components>

插件里有三个可选的组建可以创建, 他们分别是Application level components,Project level components,Module level components.

这3个组件的相应实现类需要分别实现ApplicationComponent接口、ProjectComponent接口和ModuleComponent接口,分别需要实现相应的initComponent()和disposeComponent()方法

Application level components 是在 IDE 启动的时候被创建和初始化的.Project level components 对应的是 IDE 里的每个工程项目 (没有被打开的工程也是会可能会创建 Project 实例的).Module level components 对应的是 Project 里的每个 Module.

需要注意的是, Application 级别的 initComponent 只会执行一次, Project 和 Module 级别的 init 和 Dispose 函数会根据项目工程的变化而被多次调用