X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fuisupport%2Factioncollection.cpp;h=c553554bcffd769c26c4bb7de78aa648fe58a001;hb=a4251618e99c35f727c526f8480055d5a9c5e41f;hp=9175eccb9bb85dbcc738fdc727b40711009d46dc;hpb=7f586ab22eee4c914901c608304d1da144bc3789;p=quassel.git diff --git a/src/uisupport/actioncollection.cpp b/src/uisupport/actioncollection.cpp index 9175eccb..c553554b 100644 --- a/src/uisupport/actioncollection.cpp +++ b/src/uisupport/actioncollection.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-08 by the Quassel Project * + * Copyright (C) 2005-09 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -20,12 +20,15 @@ * Parts of this implementation are based on KDE's KActionCollection. * ***************************************************************************/ +#ifndef HAVE_KDE + #include #include #include "actioncollection.h" #include "action.h" +#include "uisettings.h" ActionCollection::ActionCollection(QObject *parent) : QObject(parent) { _connectTriggered = _connectHovered = false; @@ -126,12 +129,30 @@ QAction *ActionCollection::takeAction(QAction *action) { } void ActionCollection::readSettings() { - + ShortcutSettings s; + QStringList savedShortcuts = s.savedShortcuts(); + + foreach(const QString &name, _actionByName.keys()) { + if(!savedShortcuts.contains(name)) + continue; + Action *action = qobject_cast(_actionByName.value(name)); + if(action) + action->setShortcut(s.loadShortcut(name), Action::ActiveShortcut); + } } void ActionCollection::writeSettings() const { - - + ShortcutSettings s; + foreach(const QString &name, _actionByName.keys()) { + Action *action = qobject_cast(_actionByName.value(name)); + if(!action) + continue; + if(!action->isShortcutConfigurable()) + continue; + if(action->shortcut(Action::ActiveShortcut) == action->shortcut(Action::DefaultShortcut)) + continue; + s.saveShortcut(name, action->shortcut(Action::ActiveShortcut)); + } } void ActionCollection::slotActionTriggered() { @@ -226,3 +247,5 @@ bool ActionCollection::unlistAction(QAction *action) { return true; } + +#endif /* HAVE_KDE */