Blame SOURCES/0054-gtktiledviewer-do-HTML-copying-if-possible.patch

f325b2
From 25bb8e0fa54097cc0197e5883b0b95b648d75452 Mon Sep 17 00:00:00 2001
f325b2
From: Miklos Vajna <vmiklos@collabora.co.uk>
f325b2
Date: Mon, 22 Jun 2015 09:06:31 +0200
f325b2
Subject: [PATCH 054/398] gtktiledviewer: do HTML copying if possible
f325b2
f325b2
(cherry picked from commit f403cecdaedf263f11081c91bed62640362a3a3e)
f325b2
f325b2
Change-Id: I24e7b18442cb08814a73dd33b368b368039a11e4
f325b2
---
f325b2
 .../qa/gtktiledviewer/gtktiledviewer.cxx           | 38 ++++++++++++++++++++--
f325b2
 1 file changed, 36 insertions(+), 2 deletions(-)
f325b2
f325b2
diff --git a/libreofficekit/qa/gtktiledviewer/gtktiledviewer.cxx b/libreofficekit/qa/gtktiledviewer/gtktiledviewer.cxx
f325b2
index 9496ba5ea180..57556616d803 100644
f325b2
--- a/libreofficekit/qa/gtktiledviewer/gtktiledviewer.cxx
f325b2
+++ b/libreofficekit/qa/gtktiledviewer/gtktiledviewer.cxx
f325b2
@@ -125,15 +125,49 @@ static void toggleFindbar(GtkWidget* /*pButton*/, gpointer /*pItem*/)
f325b2
     }
f325b2
 }
f325b2
 
f325b2
+/// Our GtkClipboardGetFunc implementation for HTML.
f325b2
+static void htmlGetFunc(GtkClipboard* /*pClipboard*/, GtkSelectionData* pSelectionData, guint /*info*/, gpointer pUserData)
f325b2
+{
f325b2
+    GdkAtom aAtom(gdk_atom_intern("text/html", false));
f325b2
+    const gchar* pSelection = static_cast<const gchar*>(pUserData);
f325b2
+    gtk_selection_data_set(pSelectionData, aAtom, 8, reinterpret_cast<const guchar *>(pSelection), strlen(pSelection));
f325b2
+}
f325b2
+
f325b2
+/// Our GtkClipboardClearFunc implementation for HTML.
f325b2
+static void htmlClearFunc(GtkClipboard* /*pClipboard*/, gpointer pData)
f325b2
+{
f325b2
+    g_free(pData);
f325b2
+}
f325b2
+
f325b2
+/// Same as gtk_clipboard_set_text(), but sets HTML.
f325b2
+static void clipboardSetHtml(GtkClipboard* pClipboard, const char* pSelection)
f325b2
+{
f325b2
+    GtkTargetList* pList = gtk_target_list_new(0, 0);
f325b2
+    GdkAtom aAtom(gdk_atom_intern("text/html", false));
f325b2
+    gtk_target_list_add(pList, aAtom, 0, 0);
f325b2
+    gint nTargets = 0;
f325b2
+    GtkTargetEntry* pTargets = gtk_target_table_new_from_list(pList, &nTargets);
f325b2
+
f325b2
+    gtk_clipboard_set_with_data(pClipboard, pTargets, nTargets, htmlGetFunc, htmlClearFunc, g_strdup(pSelection));
f325b2
+
f325b2
+    gtk_target_table_free(pTargets, nTargets);
f325b2
+    gtk_target_list_unref(pList);
f325b2
+}
f325b2
+
f325b2
 /// Handler for the copy button: write clipboard.
f325b2
 static void doCopy(GtkWidget* /*pButton*/, gpointer /*pItem*/)
f325b2
 {
f325b2
     LOKDocView* pLOKDocView = LOK_DOC_VIEW(pDocView);
f325b2
     LibreOfficeKitDocument* pDocument = lok_doc_view_get_document(pLOKDocView);
f325b2
-    char* pSelection = pDocument->pClass->getTextSelection(pDocument, "text/plain;charset=utf-8");
f325b2
+    char* pUsedFormat = 0;
f325b2
+    char* pSelection = pDocument->pClass->getTextSelection(pDocument, "text/html", &pUsedFormat);
f325b2
 
f325b2
     GtkClipboard* pClipboard = gtk_clipboard_get_for_display(gtk_widget_get_display(pDocView), GDK_SELECTION_CLIPBOARD);
f325b2
-    gtk_clipboard_set_text(pClipboard, pSelection, -1);
f325b2
+    std::string aUsedFormat(pUsedFormat);
f325b2
+    if (aUsedFormat == "text/plain;charset=utf-8")
f325b2
+        gtk_clipboard_set_text(pClipboard, pSelection, -1);
f325b2
+    else
f325b2
+        clipboardSetHtml(pClipboard, pSelection);
f325b2
 
f325b2
     free(pSelection);
f325b2
 }
f325b2
-- 
f325b2
2.12.0
f325b2