X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fuisupport%2Faction.h;h=6fa2ae245b8305b435491de026a6cfdfc7014bcd;hp=62bc8a37178ee14106b69b69b00dc0af26c6c463;hb=f9efdde7f3a6004af8f834c409cfa6ae1d877692;hpb=ab7ef4d24f62b5848b628482b7762ebfc0b53e1a diff --git a/src/uisupport/action.h b/src/uisupport/action.h index 62bc8a37..6fa2ae24 100644 --- a/src/uisupport/action.h +++ b/src/uisupport/action.h @@ -22,14 +22,20 @@ #pragma once +#include "uisupport-export.h" + +#include + #include #include +#include "util.h" + /// A specialized QWidgetAction, enhanced by some KDE features /** This declares/implements a subset of KAction's API (notably we've left out global shortcuts * for now), which should make it easy to plug in KDE support later on. */ -class Action : public QWidgetAction +class UISUPPORT_EXPORT Action : public QWidgetAction { Q_OBJECT @@ -45,8 +51,25 @@ public : Q_DECLARE_FLAGS(ShortcutTypes, ShortcutType) explicit Action(QObject *parent); - Action(const QString &text, QObject *parent, const QObject *receiver = 0, const char *slot = 0, const QKeySequence &shortcut = 0); - Action(const QIcon &icon, const QString &text, QObject *parent, const QObject *receiver = 0, const char *slot = 0, const QKeySequence &shortcut = 0); + Action(const QString &text, QObject *parent, const QKeySequence &shortcut = 0); + Action(const QIcon &icon, const QString &text, QObject *parent, const QKeySequence &shortcut = 0); + + template + Action(const QString &text, QObject *parent, const Receiver *receiver, Slot slot, const QKeySequence &shortcut = 0) + : Action(text, parent, shortcut) + { + static_assert(!std::is_same::value, "Old-style connects not supported"); + + setShortcut(shortcut); + connect(this, &QAction::triggered, receiver, slot); + } + + template + Action(const QIcon &icon, const QString &text, QObject *parent, const Receiver *receiver, Slot slot, const QKeySequence &shortcut = 0) + : Action(text, parent, receiver, slot, shortcut) + { + setIcon(icon); + } QKeySequence shortcut(ShortcutTypes types = ActiveShortcut) const; void setShortcut(const QShortcut &shortcut, ShortcutTypes type = ShortcutTypes(ActiveShortcut | DefaultShortcut)); @@ -58,9 +81,6 @@ public : signals: void triggered(Qt::MouseButtons buttons, Qt::KeyboardModifiers modifiers); -private: - void init(); - private slots: void slotTriggered(); };