1 /*************************************************************************** 2 * Copyright (C) 2005-2020 by the Quassel Project * 3 * devel@quassel-irc.org * 4 * * 5 * This program is free software; you can redistribute it and/or modify * 6 * it under the terms of the GNU General Public License as published by * 7 * the Free Software Foundation; either version 2 of the License, or * 8 * (at your option) version 3. * 9 * * 10 * This program is distributed in the hope that it will be useful, * 11 * but WITHOUT ANY WARRANTY; without even the implied warranty of * 12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * 13 * GNU General Public License for more details. * 14 * * 15 * You should have received a copy of the GNU General Public License * 16 * along with this program; if not, write to the * 17 * Free Software Foundation, Inc., * 18 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * 19 ***************************************************************************/ 20 21 #ifndef CLIENTUSERINPUTHANDLER_H_ 22 #define CLIENTUSERINPUTHANDLER_H_ 23 24 #include "basichandler.h" 25 26 class BufferInfo; 27 struct NetworkId; 28 29 class ClientUserInputHandler : public BasicHandler 30 { 31 Q_OBJECT 32 33 public: 34 ClientUserInputHandler(QObject* parent = nullptr); 35 36 public slots: 37 void handleUserInput(const BufferInfo& bufferInfo, const QString& msg); 38 39 signals: 40 void sendInput(const BufferInfo&, const QString&); 41 42 private slots: 43 void completionSuffixChanged(const QVariant&); 44 45 void handleExec(const BufferInfo& bufferInfo, const QString& execString); 46 void handleJoin(const BufferInfo& bufferInfo, const QString& text); 47 void handleQuery(const BufferInfo& bufferInfo, const QString& text); 48 void handleIgnore(const BufferInfo& bufferInfo, const QString& text); 49 void handleList(const BufferInfo& bufferInfo, const QString& text); 50 void defaultHandler(const QString& cmd, const BufferInfo& bufferInfo, const QString& text); 51 52 private: 53 QRegExp _nickRx; 54 55 //! Helper method for switching to new/existing buffers 56 /** Immediately switches to the given buffer or schedules a switch for whenever 57 * the buffer is created 58 */ 59 void switchBuffer(const NetworkId& networkId, const QString& bufferName); 60 }; 61 62 #endif 63