]> www.fi.muni.cz Git - evince.git/commitdiff
Add reference to subfont. Fixes bug #374277.
authorNickolay V. Shmyrev <nshmyrev@yandex.ru>
Thu, 16 Nov 2006 15:58:37 +0000 (15:58 +0000)
committerNickolay V. Shmyrev <nshmyrev@src.gnome.org>
Thu, 16 Nov 2006 15:58:37 +0000 (15:58 +0000)
2006-11-16  Nickolay V. Shmyrev  <nshmyrev@yandex.ru>

* dvi/dvi-document.c: (dvi_document_load), (dvi_document_finalize),
(dvi_document_class_init), (dvi_document_init_params):
* dvi/mdvi-lib/font.c: (font_reference):

Add reference to subfont. Fixes bug #374277.

ChangeLog
dvi/dvi-document.c
dvi/mdvi-lib/font.c

index 998dd12ec4542665a30c66c868487f8567d94d65..9ce2a693eef13fe3bfb22129ad7a78b030d2e73f 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,11 @@
+2006-11-16  Nickolay V. Shmyrev  <nshmyrev@yandex.ru>
+
+       * dvi/dvi-document.c: (dvi_document_load), (dvi_document_finalize),
+       (dvi_document_class_init), (dvi_document_init_params):
+       * dvi/mdvi-lib/font.c: (font_reference):
+       
+       Add reference to subfont. Fixes bug #374277.
+
 2006-11-16  Carlos Garcia Campos  <carlosgc@gnome.org>
 
        * shell/ev-window.c: (ev_window_create_tmp_symlink),
index 81a2af273ea417779613f4f54fb288eef31162f0..4de5e64eddc74457ccbcb405063abf2abd8f9cf9 100644 (file)
@@ -92,10 +92,12 @@ dvi_document_load (EvDocument  *document,
                return FALSE;
     }
        
+    g_mutex_lock (dvi_context_mutex);
     if (dvi_document->context)
        mdvi_destroy_context (dvi_document->context);
 
     dvi_document->context = mdvi_init_context(dvi_document->params, dvi_document->spec, filename);
+    g_mutex_unlock (dvi_context_mutex);
 
     if (!dvi_document->context) {
                g_set_error (error,
@@ -113,8 +115,6 @@ dvi_document_load (EvDocument  *document,
     dvi_document->base_height = dvi_document->context->dvi_page_h * dvi_document->context->params.vconv 
                + 2 * unit2pix(dvi_document->params->vdpi, MDVI_VMARGIN) / dvi_document->params->vshrink;
 
-    dvi_context_mutex = g_mutex_new ();
-
     g_free (dvi_document->uri);
     dvi_document->uri = g_strdup (uri);
 
@@ -206,12 +206,14 @@ static void
 dvi_document_finalize (GObject *object)
 {      
        DviDocument *dvi_document = DVI_DOCUMENT(object);
-
+       
+       g_mutex_lock (dvi_context_mutex);
        if (dvi_document->context)
            {
                mdvi_pixbuf_device_free (&dvi_document->context->device);
                mdvi_destroy_context (dvi_document->context);
            }
+       g_mutex_unlock (dvi_context_mutex);
 
        if (dvi_document->params)
                g_free (dvi_document->params);
@@ -228,6 +230,11 @@ dvi_document_class_init (DviDocumentClass *klass)
        GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
 
        gobject_class->finalize = dvi_document_finalize;
+
+       mdvi_init_kpathsea("evince", MDVI_MFMODE, MDVI_FALLBACK_FONT, MDVI_DPI);
+       mdvi_register_fonts ();
+
+       dvi_context_mutex = g_mutex_new ();
 }
 
 static gboolean
@@ -359,10 +366,6 @@ dvi_document_init_params (DviDocument *dvi_document)
        
         dvi_document->params->bg = 0xffffffff;
         dvi_document->params->fg = 0xff000000;
-
-       mdvi_init_kpathsea("evince", MDVI_MFMODE, MDVI_FALLBACK_FONT, MDVI_DPI);
-       
-       mdvi_register_fonts ();
 }
 
 static void
index ca3436c5ee8f368aab1cc819100beb6af0c29269..fedb7e78a595a580d8257c77f56971ce9f541d5f 100644 (file)
@@ -162,6 +162,7 @@ font_reference(
 {
        DviFont *font;
        DviFontRef *ref;
+       DviFontRef *subfont_ref;
        
        /* see if there is a font with the same characteristics */
        for(font = (DviFont *)fontlist.head; font; font = font->next) {
@@ -185,7 +186,13 @@ font_reference(
        }
        ref = xalloc(DviFontRef);
        ref->ref = font;
+
        font->links++;
+       for(subfont_ref = font->subfonts; subfont_ref; subfont_ref = subfont_ref->next) {
+               /* just adjust the reference counts */
+               subfont_ref->ref->links++;
+       }
+
        ref->fontid = id;
 
        if(LIST(font) != fontlist.head) {