QtCreator插件开发(一)——QtCreator插件实例
版权声明:
本系列文章翻译自:Writing Qt Creator Plugins。如果任何人或机构对于版权有异议,请联系我。
本文将使用QtCreator-2.8.1版本进行插件开发,由于QtCreator-2.8.1的插件机制进行了部分更改,因此将根据QtCreator-2.8.1插件机制为基础撰写本文。
QtCreator工程的源码编译推荐在独立工作目录进行,避免源码被污染。在QtCreator工程的根目录下创建build目录。
2、生成工程MakeFile文件在build目录下使用命令行运行:
qmake ../qtcreator.pro -recursive
如果报错,错误信息如下:QMAKESPEC has not been set, so configuration cannot be deduced.
解决方法:
export QMAKESPEC=/usr/local/Trolltech/Qt-4.8.6/mkspecs/linux-g++
在build目录下使用命令行运行:
make
不同的操作系统可能为mingw32-make或nmake。
编译完成后,在build/bin目录下查看并运行qtcreator。
二、简单插件开发1、创建插件工程学习QtCreator插件开发的最好方式就是实际动手编写一个QtCreator插件。本文将编写一个什么也不做的QtCreator插件DoNothing,目的在于熟悉QtCreator基本的类,感受创建一个QtCreator插件的过程。
本文将不依赖于Qt Creator提供的项目向导,而是直接以.pro文件创建插件。
在$$QT_CREATOR_ROOT/src/plugins目录下创建一个目录DoNothing。插件的所有源码放在DoNothing目录中。
在qt-creator-2.8.1-src/src/plugins目录创建DoNothing目录,DoNothing.pro文件内容如下:
DoNothing.pro:
TEMPLATE = libTARGET = DoNothinginclude(../../qtcreatorplugin.pri)#DESTDIR = $$IDE_PLUGIN_PATH/ScorpioPROVIDER = Scorpioinclude(../../plugins/coreplugin/coreplugin.pri)HEADERS += DoNothingPlugin.hSOURCES += DoNothingPlugin.cppOTHER_FILES += DoNothing.pluginspec \ DoNothing_dependencies.pri
工程配置文件DoNothing.pro配置了插件的如下内容:
A、TEMPLATE声明DoNothing插件是一个库
B、TARGET声明目标文件名称,目标文件将是DoNothing.dll或是libDoNothing.so;
C、配置DoNothing使用qtcreatorplugin.pri中定义的设置;
D、DESTDIR指定目标输出目录为$$IDE_PLUGIN_PATH/Scorpio。默认情况下是$$IDE_PLUGIN_PATH/QtProject。如果指定了输出目录,需要将生成的插件拷贝到$$IDE_PLUGIN_PATH/QtProject目录,QtCreator才能加载成功。
E、PROVIDER为提供插件的公司或者组织名字;
F、配置DoNothing使用coreplugin.pri定义的设置;
G、HEADERS 提供组成插件的.h文件
H、SOURCES提供组成插件的.cpp文件
I、OTHER_FILES提供插件需要的其它文件,如依赖文件
在qt-creator-2.8.1-src/src/plugins/plugins.pro文件尾添加要编译的插件:
SUBDIRS += DoNothing
确保再次编译QtCreator的时候,DoNothing插件会与其它插件一起被编译。
在目录下创建DoNothing插件的实现文件。所有的插件都需要实现IPlugin接口。$$QT_CREATOR_ROOT/src/plugins/
DoNothing/DoNothingPlugin.h文件如下:
#ifndef DONOTHINGPLUGIN_H#define DONOTHINGPLUGIN_H#include <extensionsystem/iplugin.h>class DoNothingPlugin : public ExtensionSystem::IPlugin{public: DoNothingPlugin(); ~DoNothingPlugin(); void extensionsInitialized(); bool initialize(const QStringList & arguments, QString * errorString); void shutdown();};#endif // DONOTHINGPLUGIN_H
DoNothingPluigin.cpp文件如下:
#include "DoNothingPlugin.h"#include <QtPlugin>#include <QStringList>DoNothingPlugin::DoNothingPlugin(){ // Do nothing}DoNothingPlugin::~DoNothingPlugin(){ // Do notning}bool DoNothingPlugin::initialize(const QStringList& args, QString *errMsg){ Q_UNUSED(args); Q_UNUSED(errMsg); return true;}void DoNothingPlugin::extensionsInitialized(){ // Do nothing}void DoNothingPlugin::shutdown(){ // Do nothing}Q_EXPORT_PLUGIN(DoNothingPlugin)
initialize()函数会在Qt Creator请求插件初始化时被调用,常用于初始化插件的内部状态和插件注册actions/objects到QtCreator。当插件依赖的所有资源都被加载后,initialize()函数才会被调用。初始化成功返回true,用于告诉QtCreator本插件已经初始化成功。如果初始化不成功,应该在errMsg中存储可读的错误信息,供QtCreator在界面上显示出来。
extensionsInitialized()函数在插件初始化后被调用(例如initialize()函数调用后)。extensionsInitialized()函数会由第一个依赖于本插件的其他插件进行调用。
shutdown()函数在插件即将被卸载的时候调用。
Q_EXPORT_PLUGIN()宏用于将类导出。
每个插件都需要提供一个插件描述文件pluginspec,用于提供关于插件的元数据,例如版本、依赖项等。DoNothing插件的pluginspec文件DoNothing.pluginspec内容如下:
<plugin name="DoNothing" version="1.0.0" compatVersion="2.8.1"> <vendor>Scorpio.org</vendor> <copyright>(C) 2010-2011 Scorpio.org</copyright> <license>Do anything you want.</license> <description>A plugin that does nothing.</description> <url>http://www.scorpio.net</url> <dependencyList> <dependency name="Core" version="2.8.1"/> </dependencyList></plugin>
pluginspec文件是一个XML文件,提供了如下信息:
插件名称:插件名称用于作提供插件实现的库的名称
插件版本号
要求的Qt Creator的版本号
插件提供者。
版权。
协议文本。
插件描述。
插件提供者的URL。
依赖列表。列出本插件依赖的所有插件,Qt Creator将保证此处列出的所有依赖项都加载并且初始化后采取加载本插件。
DoNothing.pro会利用qtcreatorplugin.pri文件检查插件相应的依赖信息。因此需要创建一个插件依赖描述文件xxx_dependencies.pri。
DoNothing_dependencies.pri文件内容如下:
QTC_PLUGIN_NAME = DoNothingQTC_PLUGIN_DEPENDS += \ Coreplugin
文件说明了插件的名称和依赖
6、编译插件DoNothing目录下文件如下:
从命令行进入build目录,执行如下命令:
qmake ../qtcreator.pro -recursive
make
/build/lib/qtcreator/plugins目录下会有一个QtProject目录,即编译链接的插件的目录。
运行build/bin目录下的QtCreator,在帮助菜单中“已安装插件”的对话框中可以找到DoNothing插件:
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。