From de0fcfaa0a6d707b15f50e5db0328bb4cd6a8c37 Mon Sep 17 00:00:00 2001
From: Francois Ferrand <thetypz@gmail.com>
Date: Mon, 12 Mar 2012 17:34:07 +0100
Subject: [PATCH] TextEditor: Avoid duplicates in circular clipboard.

When data is added to the circular, first check if it is already
present. In that case, the item is moved to the beginning of the
circular clipboard.

This avoids dropping old data prematurly, and traversing the same data
multiple times when pasting.

Change-Id: Iecaf8d2f5a05d08e6f5faa8555d24f4d7a1d33ab
Reviewed-by: Leandro Melo <leandro.melo@nokia.com>
---
 src/plugins/texteditor/circularclipboard.cpp | 10 ++++++++++
 1 file changed, 10 insertions(+)

diff --git a/src/plugins/texteditor/circularclipboard.cpp b/src/plugins/texteditor/circularclipboard.cpp
index 32c20ab5395..bba248a84a3 100644
--- a/src/plugins/texteditor/circularclipboard.cpp
+++ b/src/plugins/texteditor/circularclipboard.cpp
@@ -53,6 +53,16 @@ CircularClipboard *CircularClipboard::instance()
 
 void CircularClipboard::collect(const QMimeData *mimeData)
 {
+    //Avoid duplicates
+    const QString text = mimeData->text();
+    for (QList<const QMimeData *>::iterator i = m_items.begin(); i != m_items.end(); ++i) {
+        if (mimeData == *i || text == (*i)->text()) {
+            if (mimeData != *i)
+                delete *i;
+            m_items.erase(i);
+            break;
+        }
+    }
     if (m_items.size() > kMaxSize) {
         delete m_items.last();
         m_items.removeLast();
-- 
GitLab