Blame SOURCES/0163-libreofficekit-fix-mismatched-free-delete.patch

135360
From 6ac4def0a86d75c2ffc49ef8319515ba4bff26cc Mon Sep 17 00:00:00 2001
135360
From: Miklos Vajna <vmiklos@collabora.co.uk>
135360
Date: Mon, 28 Sep 2015 09:06:10 +0200
135360
Subject: [PATCH 163/398] libreofficekit: fix mismatched free() / delete
135360
135360
Change-Id: I60eb53d4bf9943fd52e0a9d8e3574a7d1cc027e0
135360
(cherry picked from commit 0067b4df75cdbeb325024cd2b66e3d64fe8b3fcd)
135360
---
135360
 libreofficekit/source/gtk/lokdocview.cxx | 28 ++++++++++++++--------------
135360
 libreofficekit/source/gtk/tilebuffer.cxx | 11 ++++++++---
135360
 libreofficekit/source/gtk/tilebuffer.hxx |  3 +++
135360
 3 files changed, 25 insertions(+), 17 deletions(-)
135360
135360
diff --git a/libreofficekit/source/gtk/lokdocview.cxx b/libreofficekit/source/gtk/lokdocview.cxx
135360
index 7c52ce2e2efb..6679cee56cd3 100644
135360
--- a/libreofficekit/source/gtk/lokdocview.cxx
135360
+++ b/libreofficekit/source/gtk/lokdocview.cxx
135360
@@ -314,7 +314,7 @@ signalKey (GtkWidget* pWidget, GdkEventKey* pEvent)
135360
         pLOEvent->m_nKeyEvent = LOK_KEYEVENT_KEYUP;
135360
         pLOEvent->m_nCharCode = nCharCode;
135360
         pLOEvent->m_nKeyCode  = nKeyCode;
135360
-        g_task_set_task_data(task, pLOEvent, g_free);
135360
+        g_task_set_task_data(task, pLOEvent, LOEvent::destroy);
135360
         g_thread_pool_push(priv->lokThreadPool, g_object_ref(task), NULL);
135360
         g_object_unref(task);
135360
     }
135360
@@ -325,7 +325,7 @@ signalKey (GtkWidget* pWidget, GdkEventKey* pEvent)
135360
         pLOEvent->m_nKeyEvent = LOK_KEYEVENT_KEYINPUT;
135360
         pLOEvent->m_nCharCode = nCharCode;
135360
         pLOEvent->m_nKeyCode  = nKeyCode;
135360
-        g_task_set_task_data(task, pLOEvent, g_free);
135360
+        g_task_set_task_data(task, pLOEvent, LOEvent::destroy);
135360
         g_thread_pool_push(priv->lokThreadPool, g_object_ref(task), NULL);
135360
         g_object_unref(task);
135360
     }
135360
@@ -951,7 +951,7 @@ lok_doc_view_signal_button(GtkWidget* pWidget, GdkEventButton* pEvent)
135360
                 pLOEvent->m_nSetGraphicSelectionType = LOK_SETGRAPHICSELECTION_END;
135360
                 pLOEvent->m_nSetGraphicSelectionX = pixelToTwip(pEvent->x, priv->m_fZoom);
135360
                 pLOEvent->m_nSetGraphicSelectionY = pixelToTwip(pEvent->y, priv->m_fZoom);
135360
-                g_task_set_task_data(task, pLOEvent, g_free);
135360
+                g_task_set_task_data(task, pLOEvent, LOEvent::destroy);
135360
 
135360
                 g_thread_pool_push(priv->lokThreadPool, g_object_ref(task), NULL);
135360
                 g_object_unref(task);
135360
@@ -970,7 +970,7 @@ lok_doc_view_signal_button(GtkWidget* pWidget, GdkEventButton* pEvent)
135360
             pLOEvent->m_nSetGraphicSelectionType = LOK_SETGRAPHICSELECTION_END;
135360
             pLOEvent->m_nSetGraphicSelectionX = pixelToTwip(pEvent->x, priv->m_fZoom);
135360
             pLOEvent->m_nSetGraphicSelectionY = pixelToTwip(pEvent->y, priv->m_fZoom);
135360
-            g_task_set_task_data(task, pLOEvent, g_free);
135360
+            g_task_set_task_data(task, pLOEvent, LOEvent::destroy);
135360
 
135360
             g_thread_pool_push(priv->lokThreadPool, g_object_ref(task), NULL);
135360
             g_object_unref(task);
135360
@@ -1019,7 +1019,7 @@ lok_doc_view_signal_button(GtkWidget* pWidget, GdkEventButton* pEvent)
135360
                     pLOEvent->m_nSetGraphicSelectionType = LOK_SETGRAPHICSELECTION_START;
135360
                     pLOEvent->m_nSetGraphicSelectionX = pixelToTwip(priv->m_aGraphicHandleRects[i].x + priv->m_aGraphicHandleRects[i].width / 2, priv->m_fZoom);
135360
                     pLOEvent->m_nSetGraphicSelectionY = pixelToTwip(priv->m_aGraphicHandleRects[i].y + priv->m_aGraphicHandleRects[i].height / 2, priv->m_fZoom);
135360
-                    g_task_set_task_data(task, pLOEvent, g_free);
135360
+                    g_task_set_task_data(task, pLOEvent, LOEvent::destroy);
135360
 
135360
                     g_thread_pool_push(priv->lokThreadPool, g_object_ref(task), NULL);
135360
                     g_object_unref(task);
135360
@@ -1047,7 +1047,7 @@ lok_doc_view_signal_button(GtkWidget* pWidget, GdkEventButton* pEvent)
135360
         pLOEvent->m_nPostMouseEventX = pixelToTwip(pEvent->x, priv->m_fZoom);
135360
         pLOEvent->m_nPostMouseEventY = pixelToTwip(pEvent->y, priv->m_fZoom);
135360
         pLOEvent->m_nPostMouseEventCount = nCount;
135360
-        g_task_set_task_data(task, pLOEvent, g_free);
135360
+        g_task_set_task_data(task, pLOEvent, LOEvent::destroy);
135360
 
135360
         g_thread_pool_push(priv->lokThreadPool, g_object_ref(task), NULL);
135360
         g_object_unref(task);
135360
@@ -1065,7 +1065,7 @@ lok_doc_view_signal_button(GtkWidget* pWidget, GdkEventButton* pEvent)
135360
         pLOEvent->m_nPostMouseEventX = pixelToTwip(pEvent->x, priv->m_fZoom);
135360
         pLOEvent->m_nPostMouseEventY = pixelToTwip(pEvent->y, priv->m_fZoom);
135360
         pLOEvent->m_nPostMouseEventCount = nCount;
135360
-        g_task_set_task_data(task, pLOEvent, g_free);
135360
+        g_task_set_task_data(task, pLOEvent, LOEvent::destroy);
135360
 
135360
         g_thread_pool_push(priv->lokThreadPool, g_object_ref(task), NULL);
135360
         g_object_unref(task);
135360
@@ -1153,7 +1153,7 @@ lok_doc_view_signal_motion (GtkWidget* pWidget, GdkEventMotion* pEvent)
135360
         pLOEvent->m_nSetGraphicSelectionType = LOK_SETGRAPHICSELECTION_START;
135360
         pLOEvent->m_nSetGraphicSelectionX = pixelToTwip(pEvent->x, priv->m_fZoom);
135360
         pLOEvent->m_nSetGraphicSelectionY = pixelToTwip(pEvent->y, priv->m_fZoom);
135360
-        g_task_set_task_data(task, pLOEvent, g_free);
135360
+        g_task_set_task_data(task, pLOEvent, LOEvent::destroy);
135360
 
135360
         g_thread_pool_push(priv->lokThreadPool, g_object_ref(task), NULL);
135360
         g_object_unref(task);
135360
@@ -1169,7 +1169,7 @@ lok_doc_view_signal_motion (GtkWidget* pWidget, GdkEventMotion* pEvent)
135360
     pLOEvent->m_nPostMouseEventX = pixelToTwip(pEvent->x, priv->m_fZoom);
135360
     pLOEvent->m_nPostMouseEventY = pixelToTwip(pEvent->y, priv->m_fZoom);
135360
     pLOEvent->m_nPostMouseEventCount = 1;
135360
-    g_task_set_task_data(task, pLOEvent, g_free);
135360
+    g_task_set_task_data(task, pLOEvent, LOEvent::destroy);
135360
 
135360
     g_thread_pool_push(priv->lokThreadPool, g_object_ref(task), NULL);
135360
     g_object_unref(task);
135360
@@ -1891,7 +1891,7 @@ lok_doc_view_open_document (LOKDocView* pDocView,
135360
     pLOEvent->m_pPath = pPath;
135360
 
135360
     priv->m_aDocPath = pPath;
135360
-    g_task_set_task_data(task, pLOEvent, g_free);
135360
+    g_task_set_task_data(task, pLOEvent, LOEvent::destroy);
135360
 
135360
     g_thread_pool_push(priv->lokThreadPool, g_object_ref(task), NULL);
135360
     g_object_unref(task);
135360
@@ -1953,7 +1953,7 @@ lok_doc_view_set_part (LOKDocView* pDocView, int nPart)
135360
     LOEvent* pLOEvent = new LOEvent(LOK_SET_PART);
135360
 
135360
     pLOEvent->m_nPart = nPart;
135360
-    g_task_set_task_data(task, pLOEvent, g_free);
135360
+    g_task_set_task_data(task, pLOEvent, LOEvent::destroy);
135360
 
135360
     g_thread_pool_push(priv->lokThreadPool, g_object_ref(task), NULL);
135360
     g_object_unref(task);
135360
@@ -1975,7 +1975,7 @@ lok_doc_view_set_partmode(LOKDocView* pDocView,
135360
     GTask* task = g_task_new(pDocView, NULL, NULL, NULL);
135360
     LOEvent* pLOEvent = new LOEvent(LOK_SET_PARTMODE);
135360
     pLOEvent->m_nPartMode = nPartMode;
135360
-    g_task_set_task_data(task, pLOEvent, g_free);
135360
+    g_task_set_task_data(task, pLOEvent, LOEvent::destroy);
135360
 
135360
     g_thread_pool_push(priv->lokThreadPool, g_object_ref(task), NULL);
135360
     g_object_unref(task);
135360
@@ -1997,7 +1997,7 @@ lok_doc_view_set_edit(LOKDocView* pDocView,
135360
     GTask* task = g_task_new(pDocView, NULL, NULL, NULL);
135360
     LOEvent* pLOEvent = new LOEvent(LOK_SET_EDIT);
135360
     pLOEvent->m_bEdit = bEdit;
135360
-    g_task_set_task_data(task, pLOEvent, g_free);
135360
+    g_task_set_task_data(task, pLOEvent, LOEvent::destroy);
135360
 
135360
     g_thread_pool_push(priv->lokThreadPool, g_object_ref(task), NULL);
135360
     g_object_unref(task);
135360
@@ -2022,7 +2022,7 @@ lok_doc_view_post_command (LOKDocView* pDocView,
135360
     pLOEvent->m_pCommand = pCommand;
135360
     pLOEvent->m_pArguments  = g_strdup(pArguments);
135360
 
135360
-    g_task_set_task_data(task, pLOEvent, g_free);
135360
+    g_task_set_task_data(task, pLOEvent, LOEvent::destroy);
135360
     g_thread_pool_push(priv->lokThreadPool, g_object_ref(task), NULL);
135360
     g_object_unref(task);
135360
 }
135360
diff --git a/libreofficekit/source/gtk/tilebuffer.cxx b/libreofficekit/source/gtk/tilebuffer.cxx
135360
index 85f6eb0422c2..687ef44d6468 100644
135360
--- a/libreofficekit/source/gtk/tilebuffer.cxx
135360
+++ b/libreofficekit/source/gtk/tilebuffer.cxx
135360
@@ -73,7 +73,7 @@ void TileBuffer::setInvalid(int x, int y, float fZoom, GTask* task,
135360
         pLOEvent->m_nPaintTileX = x;
135360
         pLOEvent->m_nPaintTileY = y;
135360
         pLOEvent->m_fPaintTileZoom = fZoom;
135360
-        g_task_set_task_data(task, pLOEvent, g_free);
135360
+        g_task_set_task_data(task, pLOEvent, LOEvent::destroy);
135360
         g_thread_pool_push(lokThreadPool, g_object_ref(task), NULL);
135360
     }
135360
 }
135360
@@ -89,7 +89,7 @@ Tile& TileBuffer::getTile(int x, int y, float fZoom, GTask* task,
135360
         pLOEvent->m_nPaintTileX = x;
135360
         pLOEvent->m_nPaintTileY = y;
135360
         pLOEvent->m_fPaintTileZoom = fZoom;
135360
-        g_task_set_task_data(task, pLOEvent, g_free);
135360
+        g_task_set_task_data(task, pLOEvent, LOEvent::destroy);
135360
         g_thread_pool_push(lokThreadPool, g_object_ref(task), NULL);
135360
         return m_mTiles[index];
135360
     }
135360
@@ -99,7 +99,7 @@ Tile& TileBuffer::getTile(int x, int y, float fZoom, GTask* task,
135360
         pLOEvent->m_nPaintTileX = x;
135360
         pLOEvent->m_nPaintTileY = y;
135360
         pLOEvent->m_fPaintTileZoom = fZoom;
135360
-        g_task_set_task_data(task, pLOEvent, g_free);
135360
+        g_task_set_task_data(task, pLOEvent, LOEvent::destroy);
135360
         g_thread_pool_push(lokThreadPool, g_object_ref(task), NULL);
135360
         return m_DummyTile;
135360
     }
135360
@@ -107,5 +107,10 @@ Tile& TileBuffer::getTile(int x, int y, float fZoom, GTask* task,
135360
     return m_mTiles[index];
135360
 }
135360
 
135360
+void LOEvent::destroy(void* pMemory)
135360
+{
135360
+    LOEvent* pLOEvent = static_cast<LOEvent*>(pMemory);
135360
+    delete pLOEvent;
135360
+}
135360
 
135360
 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
135360
diff --git a/libreofficekit/source/gtk/tilebuffer.hxx b/libreofficekit/source/gtk/tilebuffer.hxx
135360
index d4e7120e6587..fdcdd15eddd7 100644
135360
--- a/libreofficekit/source/gtk/tilebuffer.hxx
135360
+++ b/libreofficekit/source/gtk/tilebuffer.hxx
135360
@@ -237,6 +237,9 @@ struct LOEvent
135360
         , m_nSetGraphicSelectionY(0)
135360
     {
135360
     }
135360
+
135360
+    /// Wrapper around delete to help GLib.
135360
+    static void destroy(void* pMemory);
135360
 };
135360
 
135360
 #endif // INCLUDED_TILEBUFFER_HXX
135360
-- 
135360
2.12.0
135360