X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fawaylogfilter.cpp;h=c5c7b58250b77e360accd04ae43564c72861dfbf;hp=8e5366b0f84d5548c64280274663c2d2bc256c68;hb=edc55b1f86cf613a332eeeb5d85537a54120dfa5;hpb=c91b08f855152297a89ec3586792f6616acd0eb9 diff --git a/src/qtui/awaylogfilter.cpp b/src/qtui/awaylogfilter.cpp index 8e5366b0..c5c7b582 100644 --- a/src/qtui/awaylogfilter.cpp +++ b/src/qtui/awaylogfilter.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-08 by the Quassel Project * + * Copyright (C) 2005-2019 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -15,42 +15,58 @@ * 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. * ***************************************************************************/ #include "awaylogfilter.h" -AwayLogFilter::AwayLogFilter(MessageModel *model, QObject *parent) - : ChatMonitorFilter(model, parent) +#include "clientignorelistmanager.h" + +AwayLogFilter::AwayLogFilter(MessageModel* model, QObject* parent) + : ChatMonitorFilter(model, parent) +{} + +bool AwayLogFilter::filterAcceptsRow(int sourceRow, const QModelIndex& sourceParent) const { -} + Q_UNUSED(sourceParent) -bool AwayLogFilter::filterAcceptsRow(int sourceRow, const QModelIndex &sourceParent) const { - Q_UNUSED(sourceParent) + QModelIndex source_index = sourceModel()->index(sourceRow, 0); - QModelIndex source_index = sourceModel()->index(sourceRow, 0); + Message::Flags flags = (Message::Flags)sourceModel()->data(source_index, MessageModel::FlagsRole).toInt(); + // Only show highlights from the backlog + if (!(flags & Message::Backlog && flags & Message::Highlight)) { + return false; + } - Message::Flags flags = (Message::Flags)sourceModel()->data(source_index, MessageModel::FlagsRole).toInt(); - if(!(flags & Message::Backlog && flags & Message::Highlight)) - return false; + // do not use invalid buffers + BufferId bufferId = sourceModel()->data(source_index, MessageModel::BufferIdRole).value(); + if (!bufferId.isValid()) { + return false; + } - BufferId bufferId = sourceModel()->data(source_index, MessageModel::BufferIdRole).value(); - if(!bufferId.isValid()) { - return false; - } + // only show messages that were sent after the user detached + if (Client::networkModel()->lastSeenMsgId(bufferId) >= sourceModel()->data(source_index, MessageModel::MsgIdRole).value()) { + return false; + } - if(Client::networkModel()->lastSeenMsgId(bufferId) >= sourceModel()->data(source_index, MessageModel::MsgIdRole).value()) - return false; + // ignorelist handling + // only match if message is not flagged as server msg + if (!(flags & Message::ServerMsg) && Client::ignoreListManager() + && Client::ignoreListManager()->match(source_index.data(MessageModel::MessageRole).value(), + Client::networkModel()->networkName(bufferId))) { + return false; + } - return true; + return true; } -QVariant AwayLogFilter::data(const QModelIndex &index, int role) const { - if(role != MessageModel::FlagsRole) - return ChatMonitorFilter::data(index, role); +QVariant AwayLogFilter::data(const QModelIndex& index, int role) const +{ + if (role != MessageModel::FlagsRole) + return ChatMonitorFilter::data(index, role); - QModelIndex source_index = mapToSource(index); - Message::Flags flags = (Message::Flags)sourceModel()->data(source_index, MessageModel::FlagsRole).toInt(); - flags &= ~Message::Highlight; - return (int)flags; + QModelIndex source_index = mapToSource(index); + Message::Flags flags = (Message::Flags)sourceModel()->data(source_index, MessageModel::FlagsRole).toInt(); + flags &= ~Message::Highlight; + return (int)flags; }