X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fuisupport%2Faction.h;h=6fa2ae245b8305b435491de026a6cfdfc7014bcd;hp=3e90ca66354376d37aa9cae6099698066123c6ee;hb=f9efdde7f3a6004af8f834c409cfa6ae1d877692;hpb=084d95e60b0fb587b1950a3e4f8ec5e4f017446c diff --git a/src/uisupport/action.h b/src/uisupport/action.h index 3e90ca66..6fa2ae24 100644 --- a/src/uisupport/action.h +++ b/src/uisupport/action.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-08 by the Quassel Project * + * Copyright (C) 2005-2018 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -15,40 +15,61 @@ * You should have received a copy of the GNU General Public License * * along with this program; if not, write to the * * Free Software Foundation, Inc., * - * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * *************************************************************************** * Parts of this API have been shamelessly stolen from KDE's kaction.h * ***************************************************************************/ -#ifndef ACTION_H_ -#define ACTION_H_ +#pragma once -#ifndef HAVE_KDE +#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 { - Q_OBJECT - - Q_PROPERTY(QKeySequence shortcut READ shortcut WRITE setShortcut) - Q_PROPERTY(bool shortcutConfigurable READ isShortcutConfigurable WRITE setShortcutConfigurable) - Q_FLAGS(ShortcutType) - - public: - enum ShortcutType { - ActiveShortcut = 0x01, - DefaultShortcut = 0x02 +class UISUPPORT_EXPORT Action : public QWidgetAction +{ + Q_OBJECT + + Q_PROPERTY(QKeySequence shortcut READ shortcut WRITE setShortcut) + Q_PROPERTY(bool shortcutConfigurable READ isShortcutConfigurable WRITE setShortcutConfigurable) + Q_FLAGS(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); + 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)); @@ -57,32 +78,12 @@ class Action : public QWidgetAction { bool isShortcutConfigurable() const; void setShortcutConfigurable(bool configurable); - signals: +signals: void triggered(Qt::MouseButtons buttons, Qt::KeyboardModifiers modifiers); - private: - void init(); - - private slots: +private slots: void slotTriggered(); }; -Q_DECLARE_OPERATORS_FOR_FLAGS(Action::ShortcutTypes) - -#else /* HAVE_KDE */ -#include -class Action : public KAction { - Q_OBJECT - - public: - 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); - - private: - void init(); -}; -#endif - -#endif +Q_DECLARE_OPERATORS_FOR_FLAGS(Action::ShortcutTypes)