X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fuisupport%2Fabstractbuffercontainer.h;h=9af43ca0b46da94557a82135139300a0da91caac;hp=0e466277c1c83fdca7e0eb2934d5e79fd0ac39e0;hb=68878dc8366f2f4a0afe132847aad9a51a80cdbf;hpb=533eaaeda64759c01daa624365b8fc63eeba5ccf diff --git a/src/uisupport/abstractbuffercontainer.h b/src/uisupport/abstractbuffercontainer.h index 0e466277..9af43ca0 100644 --- a/src/uisupport/abstractbuffercontainer.h +++ b/src/uisupport/abstractbuffercontainer.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-08 by the Quassel IRC Team * + * Copyright (C) 2005-2018 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -15,7 +15,7 @@ * 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. * ***************************************************************************/ #ifndef ABSTRACTBUFFERCONTAINER_H_ @@ -28,19 +28,21 @@ class AbstractChatView; class AbstractUiMsg; class Buffer; -class AbstractBufferContainer : public AbstractItemView { - Q_OBJECT +class AbstractBufferContainer : public AbstractItemView +{ + Q_OBJECT - public: +public: AbstractBufferContainer(QWidget *parent); virtual ~AbstractBufferContainer(); inline BufferId currentBuffer() const { return _currentBuffer; } - signals: +signals: void currentChanged(BufferId); + void currentChanged(const QModelIndex &); - protected: +protected: //! Create an AbstractChatView for the given BufferId and add it to the UI if necessary virtual AbstractChatView *createChatView(BufferId) = 0; @@ -51,7 +53,12 @@ class AbstractBufferContainer : public AbstractItemView { */ virtual void removeChatView(BufferId) = 0; - protected slots: + //! If true, the marker line will be set automatically on buffer switch + /** \return Whether the marker line should be set on buffer switch + */ + virtual inline bool autoMarkerLine() const { return true; } + +protected slots: virtual void currentChanged(const QModelIndex ¤t, const QModelIndex &previous); virtual void rowsAboutToBeRemoved(const QModelIndex &parent, int start, int end); @@ -62,20 +69,22 @@ class AbstractBufferContainer : public AbstractItemView { */ virtual void showChatView(BufferId) = 0; - private slots: +private slots: void removeBuffer(BufferId bufferId); void setCurrentBuffer(BufferId bufferId); - private: +private: BufferId _currentBuffer; QHash _chatViews; }; -class AbstractChatView { - public: +class AbstractChatView +{ +public: virtual ~AbstractChatView() {}; virtual MsgId lastMsgId() const = 0; }; + #endif