2022-08-19 15:59:36 +02:00
|
|
|
// Copyright (C) 2020 The Qt Company Ltd.
|
|
|
|
|
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GFDL-1.3-no-invariants-only
|
2011-10-10 08:32:07 +02:00
|
|
|
|
|
|
|
|
/*!
|
|
|
|
|
\page creating-plugins.html
|
|
|
|
|
\title Creating Plugins
|
|
|
|
|
|
2015-06-23 15:21:22 +02:00
|
|
|
At its very core, \QC consists of a plugin loader that loads and runs a set
|
|
|
|
|
of plugins, which then actually provide the functionality that you know from
|
|
|
|
|
\QC the IDE. So, even the main application window and menus are all provided
|
|
|
|
|
by plugins. Plugins can use different means to provide other plugins access
|
|
|
|
|
to their functionality and to allow them to extend certain aspects of the
|
|
|
|
|
application.
|
2011-10-10 08:32:07 +02:00
|
|
|
|
2015-06-23 15:21:22 +02:00
|
|
|
For example the \c Core plugin, which is the very basic plugin that must be
|
2011-10-10 08:32:07 +02:00
|
|
|
present for \QC to run at all, provides the main window itself, and API
|
|
|
|
|
for adding menu items, modes, editor types, navigation panels and many other
|
|
|
|
|
things.
|
2015-06-23 15:21:22 +02:00
|
|
|
|
|
|
|
|
The \c TextEditor plugin provides a framework and base implementation for
|
|
|
|
|
different text editors with highlighting, completion and folding, that is
|
|
|
|
|
then used by other plugins to add more specialized text editor types to \QC,
|
|
|
|
|
like for editing C/C++ or \c {.pro} files.
|
2011-10-10 08:32:07 +02:00
|
|
|
|
|
|
|
|
After reading this guide you will know what a basic plugin consists of,
|
|
|
|
|
how to write a plugin specification file, what the lifecycle of a plugin is,
|
2015-06-23 15:21:22 +02:00
|
|
|
what the general principles for extending existing plugins' functionality
|
|
|
|
|
and providing interfaces for other plugins are, and will be able to write
|
|
|
|
|
your first plugin.
|
2011-10-10 08:32:07 +02:00
|
|
|
|
|
|
|
|
\section1 Basics
|
2015-06-23 15:21:22 +02:00
|
|
|
|
2011-10-10 08:32:07 +02:00
|
|
|
\list
|
2015-06-23 15:21:55 +02:00
|
|
|
\li \l{Getting and Building Qt Creator}
|
|
|
|
|
\li \l{Creating Your First Plugin}
|
|
|
|
|
\li \l{Plugin Meta Data}
|
|
|
|
|
\li \l{Plugin Life Cycle}
|
2020-05-25 14:26:04 +02:00
|
|
|
\li \l{Distributing Plugins}
|
2011-10-10 08:32:07 +02:00
|
|
|
\endlist
|
|
|
|
|
|
2023-01-25 16:01:27 +01:00
|
|
|
\section1 Topics
|
|
|
|
|
|
|
|
|
|
\list
|
|
|
|
|
\li \l{Adding Tests}
|
|
|
|
|
\endlist
|
|
|
|
|
|
2011-10-10 08:32:07 +02:00
|
|
|
\section1 Design Principles
|
2015-06-23 15:21:22 +02:00
|
|
|
|
2011-10-10 08:32:07 +02:00
|
|
|
\list
|
2015-06-23 15:21:55 +02:00
|
|
|
\li \l{The Plugin Manager, the Object Pool, and Registered Objects}
|
2020-04-03 12:51:37 +02:00
|
|
|
\li \l{The Action Manager and Commands}
|
2020-01-28 17:01:23 +01:00
|
|
|
\omit
|
2015-06-23 15:21:55 +02:00
|
|
|
\li \l{Aggregations}
|
|
|
|
|
\li \l{Extending and Providing Interfaces}
|
2011-10-10 08:32:07 +02:00
|
|
|
\endlist
|
|
|
|
|
|
|
|
|
|
\section1 Creating 3rd-Party Plugins
|
2015-06-23 15:21:22 +02:00
|
|
|
|
2011-10-10 08:32:07 +02:00
|
|
|
\list
|
2015-06-23 15:21:55 +02:00
|
|
|
\li \l{A Note on Binary Compatibility}
|
|
|
|
|
\li \l{Creating User-Installable Plugins}
|
2020-01-28 17:01:23 +01:00
|
|
|
\endomit
|
2011-10-10 08:32:07 +02:00
|
|
|
\endlist
|
|
|
|
|
*/
|