Files
qt-creator/share/qtcreator/templates/wizards/qtcreatorplugin/myplugin.cpp
Eike Ziller 4c1044981f Plugin wizard: Add missing license templates
Change-Id: I3b43ebdb9823a5a7430946ca789188628a910b9d
Reviewed-by: Alessandro Portale <alessandro.portale@qt.io>
2023-11-14 13:28:46 +00:00

79 lines
2.5 KiB
C++

%{Cpp:LicenseTemplate}\
#include "%{HdrFileName}"
#include "%{ConstantsHdrFileName}"
#include "%{TrHdrFileName}"
#include <coreplugin/icore.h>
#include <coreplugin/icontext.h>
#include <coreplugin/actionmanager/actionmanager.h>
#include <coreplugin/actionmanager/command.h>
#include <coreplugin/actionmanager/actioncontainer.h>
#include <coreplugin/coreconstants.h>
#include <QAction>
#include <QMessageBox>
#include <QMainWindow>
#include <QMenu>
namespace %{PluginName}::Internal {
%{CN}::%{CN}()
{
// Create your members
}
%{CN}::~%{CN}()
{
// Unregister objects from the plugin manager's object pool
// Delete members
}
void %{CN}::initialize()
{
// Register objects in the plugin manager's object pool
// Load settings
// Add actions to menus
// Connect to other plugins' signals
// In the initialize function, a plugin can be sure that the plugins it
// depends on have initialized their members.
// If you need access to command line arguments or to report errors, use the
// bool IPlugin::initialize(const QStringList &arguments, QString *errorString)
// overload.
auto action = new QAction(Tr::tr("%{PluginName} Action"), this);
Core::Command *cmd = Core::ActionManager::registerAction(action, Constants::ACTION_ID,
Core::Context(Core::Constants::C_GLOBAL));
cmd->setDefaultKeySequence(QKeySequence(Tr::tr("Ctrl+Alt+Meta+A")));
connect(action, &QAction::triggered, this, &%{CN}::triggerAction);
Core::ActionContainer *menu = Core::ActionManager::createMenu(Constants::MENU_ID);
menu->menu()->setTitle(Tr::tr("%{PluginName}"));
menu->addAction(cmd);
Core::ActionManager::actionContainer(Core::Constants::M_TOOLS)->addMenu(menu);
}
void %{CN}::extensionsInitialized()
{
// Retrieve objects from the plugin manager's object pool
// In the extensionsInitialized function, a plugin can be sure that all
// plugins that depend on it are completely initialized.
}
ExtensionSystem::IPlugin::ShutdownFlag %{CN}::aboutToShutdown()
{
// Save settings
// Disconnect from signals that are not needed during shutdown
// Hide UI (if you add UI that is not in the main window directly)
return SynchronousShutdown;
}
void %{CN}::triggerAction()
{
QMessageBox::information(Core::ICore::mainWindow(),
Tr::tr("Action Triggered"),
Tr::tr("This is an action from %{PluginName}."));
}
} // namespace %{PluginName}::Internal