X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fuisupport%2Faction.h;h=10a5435cfa330fe2396c39135b53b92a6c79c70f;hb=c8ddabf364eff2400c61cea395aefe69eb8ba1b3;hp=ba03a24570fd093e54cbdb6674a25d61a614e311;hpb=92fc8c5b119111a35ab8423c3cbde5b2a022badf;p=quassel.git diff --git a/src/uisupport/action.h b/src/uisupport/action.h index ba03a245..10a5435c 100644 --- a/src/uisupport/action.h +++ b/src/uisupport/action.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2018 by the Quassel Project * + * Copyright (C) 2005-2022 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -24,9 +24,13 @@ #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. @@ -39,20 +43,38 @@ class UISUPPORT_EXPORT Action : public QWidgetAction Q_PROPERTY(bool shortcutConfigurable READ isShortcutConfigurable WRITE setShortcutConfigurable) Q_FLAGS(ShortcutType) -public : - enum ShortcutType { +public: + enum ShortcutType + { ActiveShortcut = 0x01, DefaultShortcut = 0x02 }; 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); + explicit Action(QObject* parent); + 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)); - void setShortcut(const QKeySequence &shortcut, ShortcutTypes type = ShortcutTypes(ActiveShortcut | DefaultShortcut)); + void setShortcut(const QShortcut& shortcut, ShortcutTypes type = ShortcutTypes(ActiveShortcut | DefaultShortcut)); + void setShortcut(const QKeySequence& shortcut, ShortcutTypes type = ShortcutTypes(ActiveShortcut | DefaultShortcut)); bool isShortcutConfigurable() const; void setShortcutConfigurable(bool configurable); @@ -60,12 +82,8 @@ public : signals: void triggered(Qt::MouseButtons buttons, Qt::KeyboardModifiers modifiers); -private: - void init(); - private slots: void slotTriggered(); }; - Q_DECLARE_OPERATORS_FOR_FLAGS(Action::ShortcutTypes)