X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Faliasmanager.h;h=c72f57dd19b0d37f0d5d1f65148f4ee43c392b09;hp=cc936cdadefca4f52052c23d62fb5ced1d5ba06a;hb=7a44d67d565fe4f627e64b158a91a5978591c743;hpb=f824db0e31b54969e0b7fa0b5405b1e9173d482c diff --git a/src/common/aliasmanager.h b/src/common/aliasmanager.h index cc936cda..c72f57dd 100644 --- a/src/common/aliasmanager.h +++ b/src/common/aliasmanager.h @@ -21,9 +21,12 @@ #ifndef ALIASMANAGER_H #define ALIASMANAGER_H +#include + +#include "bufferinfo.h" #include "syncableobject.h" -#include +class Network; class AliasManager : public SyncableObject { Q_OBJECT @@ -31,7 +34,7 @@ class AliasManager : public SyncableObject { public: inline AliasManager(QObject *parent = 0) : SyncableObject(parent) { setAllowClientUpdates(true); } AliasManager &operator=(const AliasManager &other); - + struct Alias { QString name; QString expansion; @@ -45,24 +48,32 @@ public: inline int count() const { return _aliases.count(); } inline void removeAt(int index) { _aliases.removeAt(index); } inline Alias &operator[](int i) { return _aliases[i]; } - inline const Alias &operator[](int i) const { return _aliases[i]; } + inline const Alias &operator[](int i) const { return _aliases.at(i); } inline const AliasList &aliases() const { return _aliases; } static AliasList defaults(); + typedef QList > CommandList; + + CommandList processInput(const BufferInfo &info, const QString &message); + public slots: virtual QVariantMap initAliases() const; virtual void initSetAliases(const QVariantMap &aliases); virtual void addAlias(const QString &name, const QString &expansion); - + protected: void setAliases(const QList &aliases) { _aliases = aliases; } + virtual const Network *network(NetworkId) const = 0; // core and client require different access signals: void aliasAdded(const QString &name, const QString &expansion); - + private: + void processInput(const BufferInfo &info, const QString &message, CommandList &previousCommands); + void expand(const QString &alias, const BufferInfo &bufferInfo, const QString &msg, CommandList &previousCommands); + AliasList _aliases; };