[evince] pdf: Make annotation names unique
- From: Carlos Garcia Campos <carlosgc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [evince] pdf: Make annotation names unique
- Date: Fri, 15 Aug 2014 09:23:34 +0000 (UTC)
commit 0f38a2718b572ca862808fe51117862e3435fe57
Author: Giselle Machado <gisellemnr src gnome org>
Date: Fri Jun 27 19:41:57 2014 +0200
pdf: Make annotation names unique
Naming the annotations sequentially by number is
problematic when they can be removed (see
https://bugzilla.gnome.org/show_bug.cgi?id=649044#c33).
This patch changes the annotation names to
timestamps, guaranteeing that they are indeed
unique.
https://bugzilla.gnome.org/show_bug.cgi?id=649044
backend/pdf/ev-poppler.cc | 27 ++++++++++++++-------------
1 files changed, 14 insertions(+), 13 deletions(-)
---
diff --git a/backend/pdf/ev-poppler.cc b/backend/pdf/ev-poppler.cc
index 3ef778a..57fc80d 100644
--- a/backend/pdf/ev-poppler.cc
+++ b/backend/pdf/ev-poppler.cc
@@ -3002,6 +3002,16 @@ ev_annot_from_poppler_annot (PopplerAnnot *poppler_annot,
return ev_annot;
}
+static void
+annot_set_unique_name (EvAnnotation *annot)
+{
+ gchar *name;
+
+ name = g_strdup_printf ("annot-%"G_GUINT64_FORMAT, g_get_real_time ());
+ ev_annotation_set_name (annot, name);
+ g_free (name);
+}
+
static EvMappingList *
pdf_document_annotations_get_annotations (EvDocumentAnnotations *document_annotations,
EvPage *page)
@@ -3042,12 +3052,8 @@ pdf_document_annotations_get_annotations (EvDocumentAnnotations *document_annota
i++;
/* Make sure annot has a unique name */
- if (!ev_annotation_get_name (ev_annot)) {
- gchar *name = g_strdup_printf ("annot-%d-%d", page->index, i);
-
- ev_annotation_set_name (ev_annot, name);
- g_free (name);
- }
+ if (!ev_annotation_get_name (ev_annot))
+ annot_set_unique_name (ev_annot);
annot_mapping = g_new (EvMapping, 1);
annot_mapping->area.x1 = mapping->area.x1;
@@ -3106,7 +3112,6 @@ pdf_document_annotations_add_annotation (EvDocumentAnnotations *document_annotat
gdouble height;
PopplerColor poppler_color;
GdkColor color;
- gchar *name;
pdf_document = PDF_DOCUMENT (document_annotations);
page = ev_annotation_get_page (annot);
@@ -3183,16 +3188,12 @@ pdf_document_annotations_add_annotation (EvDocumentAnnotations *document_annotat
mapping_list = NULL;
}
+ annot_set_unique_name (annot);
+
if (mapping_list) {
list = ev_mapping_list_get_list (mapping_list);
- name = g_strdup_printf ("annot-%d-%d", page->index, g_list_length (list) + 1);
- ev_annotation_set_name (annot, name);
- g_free (name);
list = g_list_append (list, annot_mapping);
} else {
- name = g_strdup_printf ("annot-%d-0", page->index);
- ev_annotation_set_name (annot, name);
- g_free (name);
list = g_list_append (list, annot_mapping);
mapping_list = ev_mapping_list_new (page->index, list, (GDestroyNotify)g_object_unref);
g_hash_table_insert (pdf_document->annots,
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]