-void ClientUserInputHandler::handleUserInput(const BufferInfo &bufferInfo, const QString &msg) {
-
- if(!msg.startsWith('/')) {
- if(_nickRx.indexIn(msg) == 0) {
- const Network *net = Client::network(bufferInfo.networkId());
- IrcUser *user = net ? net->ircUser(_nickRx.cap(1)) : 0;
- if(user)
- user->setLastSpokenTo(bufferInfo.bufferId(), QDateTime::currentDateTime().toUTC());
+void ClientUserInputHandler::handleUserInput(const BufferInfo& bufferInfo, const QString& msg)
+{
+ if (msg.isEmpty())
+ return;
+
+ if (!msg.startsWith('/')) {
+ if (_nickRx.indexIn(msg) == 0) {
+ const Network* net = Client::network(bufferInfo.networkId());
+ IrcUser* user = net ? net->ircUser(_nickRx.cap(1)) : nullptr;
+ if (user)
+ user->setLastSpokenTo(bufferInfo.bufferId(), QDateTime::currentDateTime().toUTC());
+ }
+ }
+
+ AliasManager::CommandList clist = Client::aliasManager()->processInput(bufferInfo, msg);
+
+ for (int i = 0; i < clist.count(); i++) {
+ QString cmd = clist.at(i).second.section(' ', 0, 0).remove(0, 1).toUpper();
+ QString payload = clist.at(i).second.section(' ', 1);
+ handle(cmd, Q_ARG(BufferInfo, clist.at(i).first), Q_ARG(QString, payload));
+ }
+}
+
+void ClientUserInputHandler::defaultHandler(const QString& cmd, const BufferInfo& bufferInfo, const QString& text)
+{
+ QString command = QString("/%1 %2").arg(cmd, text);
+ emit sendInput(bufferInfo, command);
+}
+
+void ClientUserInputHandler::handleExec(const BufferInfo& bufferInfo, const QString& execString)
+{
+ auto* exec = new ExecWrapper(this); // gets suicidal when it's done
+ exec->start(bufferInfo, execString);
+}
+
+void ClientUserInputHandler::handleJoin(const BufferInfo& bufferInfo, const QString& text)
+{
+ auto channelName = text;
+ if (channelName.isEmpty()) {
+ if (bufferInfo.type() == BufferInfo::ChannelBuffer) {
+ channelName = bufferInfo.bufferName();
+ } else {
+ Client::messageModel()->insertErrorMessage(bufferInfo, tr("/JOIN expects a channel"));
+ return;
+ }