| 
									
										
										
										
											2016-01-15 14:51:16 +01:00
										 |  |  | /**************************************************************************** | 
					
						
							| 
									
										
										
										
											2011-10-10 08:32:07 +02:00
										 |  |  | ** | 
					
						
							| 
									
										
										
										
											2016-01-15 14:51:16 +01:00
										 |  |  | ** Copyright (C) 2016 The Qt Company Ltd. | 
					
						
							|  |  |  | ** Contact: https://www.qt.io/licensing/ | 
					
						
							| 
									
										
										
										
											2011-10-10 08:32:07 +02:00
										 |  |  | ** | 
					
						
							| 
									
										
										
										
											2016-01-15 14:51:16 +01:00
										 |  |  | ** This file is part of the Qt Creator documentation. | 
					
						
							| 
									
										
										
										
											2011-10-10 08:32:07 +02:00
										 |  |  | ** | 
					
						
							| 
									
										
										
										
											2016-01-15 14:51:16 +01:00
										 |  |  | ** Commercial License Usage | 
					
						
							|  |  |  | ** Licensees holding valid commercial Qt licenses may use this file in | 
					
						
							|  |  |  | ** accordance with the commercial license agreement provided with the | 
					
						
							|  |  |  | ** Software or, alternatively, in accordance with the terms contained in | 
					
						
							|  |  |  | ** a written agreement between you and The Qt Company. For licensing terms | 
					
						
							|  |  |  | ** and conditions see https://www.qt.io/terms-conditions. For further | 
					
						
							|  |  |  | ** information use the contact form at https://www.qt.io/contact-us. | 
					
						
							| 
									
										
										
										
											2011-10-10 08:32:07 +02:00
										 |  |  | ** | 
					
						
							| 
									
										
										
										
											2016-01-15 14:51:16 +01:00
										 |  |  | ** GNU Free Documentation License Usage | 
					
						
							| 
									
										
										
										
											2011-10-10 08:32:07 +02:00
										 |  |  | ** Alternatively, this file may be used under the terms of the GNU Free | 
					
						
							|  |  |  | ** Documentation License version 1.3 as published by the Free Software | 
					
						
							| 
									
										
										
										
											2016-01-15 14:51:16 +01:00
										 |  |  | ** Foundation and appearing in the file included in the packaging of | 
					
						
							|  |  |  | ** this file. Please review the following information to ensure | 
					
						
							|  |  |  | ** the GNU Free Documentation License version 1.3 requirements | 
					
						
							|  |  |  | ** will be met: https://www.gnu.org/licenses/fdl-1.3.html. | 
					
						
							| 
									
										
										
										
											2011-10-10 08:32:07 +02:00
										 |  |  | ** | 
					
						
							| 
									
										
										
										
											2016-01-15 14:51:16 +01:00
										 |  |  | ****************************************************************************/ | 
					
						
							| 
									
										
										
										
											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} | 
					
						
							| 
									
										
										
										
											2011-10-10 08:32:07 +02:00
										 |  |  |     \endlist | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     \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} | 
					
						
							|  |  |  |         \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} | 
					
						
							| 
									
										
										
										
											2011-10-10 08:32:07 +02:00
										 |  |  |     \endlist | 
					
						
							|  |  |  | */ |