properly rewind oidentd config file
[quassel.git] / src / qtui / chatview.h
index 4fb3661..51522d2 100644 (file)
@@ -65,11 +65,18 @@ public:
   /** Using this method more efficient than calling visibleChatLinesSorted() and taking its last element.
    *  \return The last fully visible ChatLine in the view
    */
-  ChatLine *lastVisibleChatLine() const;
+  ChatLine *lastVisibleChatLine(bool ignoreDayChange = false) const;
 
   virtual void addActionsToMenu(QMenu *, const QPointF &pos);
 
-  virtual bool event(QEvent *event);
+  //! Tell the view that this ChatLine has cached data
+  /** ChatLines cache some layout data that should be cleared as soon as it's no
+   *  longer visible. A ChatLine caching data registers itself with this method to
+   *  tell the view about it. The view will call ChatLine::clearCache() when
+   *  appropriate.
+   *  \param line The ChatLine having cached data
+   */
+  void setHasCache(ChatLine *line, bool hasCache = true);
 
 public slots:
   inline virtual void clear() {}
@@ -77,8 +84,14 @@ public slots:
   void zoomOut();
   void zoomOriginal();
 
+  void setMarkerLineVisible(bool visible = true);
+  void setMarkerLine(MsgId msgId);
+  void jumpToMarkerLine(bool requestBacklog);
+
 protected:
+  virtual bool event(QEvent *event);
   virtual void resizeEvent(QResizeEvent *event);
+  virtual void scrollContentsBy(int dx, int dy);
 
 protected slots:
   virtual void verticalScrollbarChanged(int);
@@ -86,9 +99,11 @@ protected slots:
 private slots:
   void lastLineChanged(QGraphicsItem *chatLine, qreal offset);
   void adjustSceneRect();
+  void checkChatLineCaches();
   void mouseMoveWhileSelecting(const QPointF &scenePos);
   void scrollTimerTimeout();
   void invalidateFilter();
+  void markerLineSet(BufferId buffer, MsgId msg);
 
 private:
   void init(MessageFilter *filter);
@@ -100,6 +115,7 @@ private:
   QTimer _scrollTimer;
   int _scrollOffset;
   bool _invalidateFilter;
+  QSet<ChatLine *> _linesWithCache;
 };