kbrown / rpms / libreoffice

Forked from rpms/libreoffice 2 years ago
Clone

Blame SOURCES/0081-lokdocview-Use-only-one-ctor-for-instantiating-LOEve.patch

f325b2
From a9ed2a81b472091a2f255cf1ffba6f48001f46d6 Mon Sep 17 00:00:00 2001
f325b2
From: Pranav Kant <pranavk@gnome.org>
f325b2
Date: Sun, 26 Jul 2015 18:24:02 +0530
f325b2
Subject: [PATCH 081/398] lokdocview: Use only one ctor for instantiating
f325b2
 LOEvent
f325b2
f325b2
... and set each member variable manually.
f325b2
f325b2
Additionally, improves documentation of the struct LOEvent.
f325b2
f325b2
Change-Id: I2e8e1dc70298dc85943769e2f01c6127eedb8207
f325b2
(cherry picked from commit 4fb3d2e6be39fb3a7323b11a02adf853ed37a3ca)
f325b2
---
f325b2
 libreofficekit/source/gtk/lokdocview.cxx | 41 +++++++++++++++---------
f325b2
 libreofficekit/source/gtk/tilebuffer.cxx | 17 +++++++---
f325b2
 libreofficekit/source/gtk/tilebuffer.hxx | 54 +++++++++++++++-----------------
f325b2
 3 files changed, 65 insertions(+), 47 deletions(-)
f325b2
f325b2
diff --git a/libreofficekit/source/gtk/lokdocview.cxx b/libreofficekit/source/gtk/lokdocview.cxx
f325b2
index e44f9b96886a..6bee2f513ae9 100644
f325b2
--- a/libreofficekit/source/gtk/lokdocview.cxx
f325b2
+++ b/libreofficekit/source/gtk/lokdocview.cxx
f325b2
@@ -39,8 +39,8 @@
f325b2
 /// Private struct used by this GObject type
f325b2
 struct _LOKDocViewPrivate
f325b2
 {
f325b2
-    gchar* m_aLOPath;
f325b2
-    gchar* m_aDocPath;
f325b2
+    const gchar* m_aLOPath;
f325b2
+    const gchar* m_aDocPath;
f325b2
     gdouble m_nLoadProgress;
f325b2
     gboolean m_bIsLoading;
f325b2
     gboolean m_bCanZoomIn;
f325b2
@@ -302,7 +302,10 @@ signalKey (GtkWidget* pWidget, GdkEventKey* pEvent)
f325b2
     if (pEvent->type == GDK_KEY_RELEASE)
f325b2
     {
f325b2
         GTask* task = g_task_new(pDocView, NULL, NULL, NULL);
f325b2
-        LOEvent* pLOEvent = new LOEvent(LOK_POST_KEY, LOK_KEYEVENT_KEYUP, nCharCode, nKeyCode);
f325b2
+        LOEvent* pLOEvent = new LOEvent(LOK_POST_KEY);
f325b2
+        pLOEvent->m_nKeyEvent = LOK_KEYEVENT_KEYUP;
f325b2
+        pLOEvent->m_nCharCode = nCharCode;
f325b2
+        pLOEvent->m_nKeyCode  = nKeyCode;
f325b2
         g_task_set_task_data(task, pLOEvent, g_free);
f325b2
         g_thread_pool_push(lokThreadPool, g_object_ref(task), NULL);
f325b2
         g_object_unref(task);
f325b2
@@ -310,7 +313,10 @@ signalKey (GtkWidget* pWidget, GdkEventKey* pEvent)
f325b2
     else
f325b2
     {
f325b2
         GTask* task = g_task_new(pDocView, NULL, NULL, NULL);
f325b2
-        LOEvent* pLOEvent = new LOEvent(LOK_POST_KEY, LOK_KEYEVENT_KEYINPUT, nCharCode, nKeyCode);
f325b2
+        LOEvent* pLOEvent = new LOEvent(LOK_POST_KEY);
f325b2
+        pLOEvent->m_nKeyEvent = LOK_KEYEVENT_KEYINPUT;
f325b2
+        pLOEvent->m_nCharCode = nCharCode;
f325b2
+        pLOEvent->m_nKeyCode  = nKeyCode;
f325b2
         g_task_set_task_data(task, pLOEvent, g_free);
f325b2
         g_thread_pool_push(lokThreadPool, g_object_ref(task), NULL);
f325b2
         g_object_unref(task);
f325b2
@@ -1163,7 +1169,7 @@ paintTileInThread (gpointer data)
f325b2
     LOKDocViewPrivate *priv = static_cast<LOKDocViewPrivate*>(lok_doc_view_get_instance_private (pDocView));
f325b2
     LOEvent* pLOEvent = static_cast<LOEvent*>(g_task_get_task_data(task));
f325b2
     TileBuffer& buffer = priv->m_aTileBuffer;
f325b2
-    int index = pLOEvent->m_nX * buffer.m_nWidth + pLOEvent->m_nY;
f325b2
+    int index = pLOEvent->m_nPaintTileX * buffer.m_nWidth + pLOEvent->m_nPaintTileY;
f325b2
     if (buffer.m_mTiles.find(index) != buffer.m_mTiles.end() &&
f325b2
         buffer.m_mTiles[index].valid)
f325b2
         return;
f325b2
@@ -1177,21 +1183,21 @@ paintTileInThread (gpointer data)
f325b2
 
f325b2
     unsigned char* pBuffer = gdk_pixbuf_get_pixels(pPixBuf);
f325b2
     GdkRectangle aTileRectangle;
f325b2
-    aTileRectangle.x = pixelToTwip(nTileSizePixels, pLOEvent->m_fZoom) * pLOEvent->m_nY;
f325b2
-    aTileRectangle.y = pixelToTwip(nTileSizePixels, pLOEvent->m_fZoom) * pLOEvent->m_nX;
f325b2
+    aTileRectangle.x = pixelToTwip(nTileSizePixels, pLOEvent->m_fPaintTileZoom) * pLOEvent->m_nPaintTileY;
f325b2
+    aTileRectangle.y = pixelToTwip(nTileSizePixels, pLOEvent->m_fPaintTileZoom) * pLOEvent->m_nPaintTileX;
f325b2
 
f325b2
     g_test_timer_start();
f325b2
     priv->m_pDocument->pClass->paintTile(priv->m_pDocument,
f325b2
                                          pBuffer,
f325b2
                                          nTileSizePixels, nTileSizePixels,
f325b2
                                          aTileRectangle.x, aTileRectangle.y,
f325b2
-                                         pixelToTwip(nTileSizePixels, pLOEvent->m_fZoom),
f325b2
-                                         pixelToTwip(nTileSizePixels, pLOEvent->m_fZoom));
f325b2
+                                         pixelToTwip(nTileSizePixels, pLOEvent->m_fPaintTileZoom),
f325b2
+                                         pixelToTwip(nTileSizePixels, pLOEvent->m_fPaintTileZoom));
f325b2
 
f325b2
     double elapsedTime = g_test_timer_elapsed();
f325b2
     g_info ("Rendered (%d, %d) in %f seconds",
f325b2
-            pLOEvent->m_nX,
f325b2
-            pLOEvent->m_nY,
f325b2
+            pLOEvent->m_nPaintTileX,
f325b2
+            pLOEvent->m_nPaintTileY,
f325b2
             elapsedTime);
f325b2
 
f325b2
     //create a mapping for it
f325b2
@@ -1674,9 +1680,12 @@ lok_doc_view_open_document (LOKDocView* pDocView,
f325b2
                             gpointer userdata)
f325b2
 {
f325b2
     GTask* task = g_task_new(pDocView, cancellable, callback, userdata);
f325b2
-    LOEvent* pLOEvent = new LOEvent(LOK_LOAD_DOC, pPath);
f325b2
     LOKDocViewPrivate *priv = static_cast<LOKDocViewPrivate*>(lok_doc_view_get_instance_private (pDocView));
f325b2
-    priv->m_aDocPath = g_strdup(pPath);
f325b2
+
f325b2
+    LOEvent* pLOEvent = new LOEvent(LOK_LOAD_DOC);
f325b2
+    pLOEvent->m_pPath = pPath;
f325b2
+
f325b2
+    priv->m_aDocPath = pPath;
f325b2
     g_task_set_task_data(task, pLOEvent, g_free);
f325b2
 
f325b2
     g_thread_pool_push(lokThreadPool, g_object_ref(task), NULL);
f325b2
@@ -1836,9 +1845,11 @@ lok_doc_view_post_command (LOKDocView* pDocView,
f325b2
 {
f325b2
 
f325b2
     GTask* task = g_task_new(pDocView, NULL, NULL, NULL);
f325b2
-    LOEvent* pLOEvent = new LOEvent(LOK_POST_COMMAND, pCommand, pArguments);
f325b2
-    g_task_set_task_data(task, pLOEvent, g_free);
f325b2
+    LOEvent* pLOEvent = new LOEvent(LOK_POST_COMMAND);
f325b2
+    pLOEvent->m_pCommand = pCommand;
f325b2
+    pLOEvent->m_pArguments  = pArguments;
f325b2
 
f325b2
+    g_task_set_task_data(task, pLOEvent, g_free);
f325b2
     g_thread_pool_push(lokThreadPool, g_object_ref(task), NULL);
f325b2
     g_object_unref(task);
f325b2
 }
f325b2
diff --git a/libreofficekit/source/gtk/tilebuffer.cxx b/libreofficekit/source/gtk/tilebuffer.cxx
f325b2
index a8594fc916f0..21ea58b0faff 100644
f325b2
--- a/libreofficekit/source/gtk/tilebuffer.cxx
f325b2
+++ b/libreofficekit/source/gtk/tilebuffer.cxx
f325b2
@@ -70,26 +70,35 @@ void TileBuffer::setInvalid(int x, int y, float fZoom, GTask* task)
f325b2
     {
f325b2
         m_mTiles[index].valid = false;
f325b2
 
f325b2
-        LOEvent* pLOEvent = new LOEvent(LOK_PAINT_TILE, x, y, fZoom);
f325b2
+        LOEvent* pLOEvent = new LOEvent(LOK_PAINT_TILE);
f325b2
+        pLOEvent->m_nPaintTileX = x;
f325b2
+        pLOEvent->m_nPaintTileY = y;
f325b2
+        pLOEvent->m_fPaintTileZoom = fZoom;
f325b2
         g_task_set_task_data(task, pLOEvent, g_free);
f325b2
         g_thread_pool_push(lokThreadPool, g_object_ref(task), NULL);
f325b2
     }
f325b2
 }
f325b2
 
f325b2
-Tile& TileBuffer::getTile(int x, int y, float aZoom, GTask* task)
f325b2
+Tile& TileBuffer::getTile(int x, int y, float fZoom, GTask* task)
f325b2
 {
f325b2
     int index = x * m_nWidth + y;
f325b2
 
f325b2
     if (m_mTiles.find(index) != m_mTiles.end() && !m_mTiles[index].valid)
f325b2
     {
f325b2
-        LOEvent* pLOEvent = new LOEvent(LOK_PAINT_TILE, x, y, aZoom);
f325b2
+        LOEvent* pLOEvent = new LOEvent(LOK_PAINT_TILE);
f325b2
+        pLOEvent->m_nPaintTileX = x;
f325b2
+        pLOEvent->m_nPaintTileY = y;
f325b2
+        pLOEvent->m_fPaintTileZoom = fZoom;
f325b2
         g_task_set_task_data(task, pLOEvent, g_free);
f325b2
         g_thread_pool_push(lokThreadPool, g_object_ref(task), NULL);
f325b2
         return m_mTiles[index];
f325b2
     }
f325b2
     else if(m_mTiles.find(index) == m_mTiles.end())
f325b2
     {
f325b2
-        LOEvent* pLOEvent = new LOEvent(LOK_PAINT_TILE, x, y, aZoom);
f325b2
+        LOEvent* pLOEvent = new LOEvent(LOK_PAINT_TILE);
f325b2
+        pLOEvent->m_nPaintTileX = x;
f325b2
+        pLOEvent->m_nPaintTileY = y;
f325b2
+        pLOEvent->m_fPaintTileZoom = fZoom;
f325b2
         g_task_set_task_data(task, pLOEvent, g_free);
f325b2
         g_thread_pool_push(lokThreadPool, g_object_ref(task), NULL);
f325b2
         return m_DummyTile;
f325b2
diff --git a/libreofficekit/source/gtk/tilebuffer.hxx b/libreofficekit/source/gtk/tilebuffer.hxx
f325b2
index f23b02330616..6e57d2fe8bd5 100644
f325b2
--- a/libreofficekit/source/gtk/tilebuffer.hxx
f325b2
+++ b/libreofficekit/source/gtk/tilebuffer.hxx
f325b2
@@ -152,46 +152,44 @@ struct LOEvent
f325b2
 {
f325b2
     /// To identify the type of LOK call
f325b2
     int m_nType;
f325b2
+
f325b2
+    /// @name post_command parameters
f325b2
+    ///@{
f325b2
     const gchar* m_pCommand;
f325b2
     const gchar* m_pArguments;
f325b2
-    gchar* m_pPath;
f325b2
+    ///@}
f325b2
+
f325b2
+    /// @name open_document parameter
f325b2
+    ///@{
f325b2
+    const gchar* m_pPath;
f325b2
+    ///@}
f325b2
+
f325b2
+    /// set_edit parameter
f325b2
     gboolean m_bEdit;
f325b2
+
f325b2
+    /// set_partmode parameter
f325b2
     int m_nPartMode;
f325b2
+
f325b2
+    /// set_part parameter
f325b2
     int m_nPart;
f325b2
+
f325b2
+    /// @name postKeyEvent parameters
f325b2
+    ///@{
f325b2
     int m_nKeyEvent;
f325b2
     int m_nCharCode;
f325b2
     int m_nKeyCode;
f325b2
+    ///@}
f325b2
 
f325b2
-    int m_nX;
f325b2
-    int m_nY;
f325b2
-    float m_fZoom;
f325b2
+    /// @name paintTile parameters
f325b2
+    ///@{
f325b2
+    int m_nPaintTileX;
f325b2
+    int m_nPaintTileY;
f325b2
+    float m_fPaintTileZoom;
f325b2
+    ///@}
f325b2
 
f325b2
-    /// Constructor to easily instantiate an object for LOK call of `type' type.
f325b2
+    /// Constructor to instantiate an object of type `type`.
f325b2
     LOEvent(int type)
f325b2
         : m_nType(type) {}
f325b2
-
f325b2
-    LOEvent(int type, const gchar* pCommand, const gchar* pArguments)
f325b2
-        : m_nType(type),
f325b2
-          m_pCommand(pCommand),
f325b2
-          m_pArguments(pArguments) {}
f325b2
-
f325b2
-    LOEvent(int type, const gchar* pPath)
f325b2
-        : m_nType(type)
f325b2
-    {
f325b2
-        m_pPath = g_strdup(pPath);
f325b2
-    }
f325b2
-
f325b2
-    LOEvent(int type, int nKeyEvent, int nCharCode, int nKeyCode)
f325b2
-        : m_nType(type),
f325b2
-          m_nKeyEvent(nKeyEvent),
f325b2
-          m_nCharCode(nCharCode),
f325b2
-          m_nKeyCode(nKeyCode) {}
f325b2
-
f325b2
-    LOEvent(int type, int x, int y, float zoom)
f325b2
-        : m_nType(type),
f325b2
-          m_nX(x),
f325b2
-          m_nY(y),
f325b2
-          m_fZoom(zoom) {}
f325b2
 };
f325b2
 
f325b2
 #endif // INCLUDED_TILEBUFFER_HXX
f325b2
-- 
f325b2
2.12.0
f325b2