X-Git-Url: https://www.fi.muni.cz/~kas/git//home/kas/public_html/git/?a=blobdiff_plain;f=shell%2Fev-properties-fonts.c;h=54ed063d15eb6be900bfb521746034a0b949d129;hb=3d85ea1b45e9d6d2141df6cb797f8ad8325b4769;hp=ce5109112d2d00d1d1da2b2dc07ce101545a0935;hpb=2ad5c80aafe43d53698e1084db86e34bf15290a9;p=evince.git diff --git a/shell/ev-properties-fonts.c b/shell/ev-properties-fonts.c index ce510911..54ed063d 100644 --- a/shell/ev-properties-fonts.c +++ b/shell/ev-properties-fonts.c @@ -31,12 +31,6 @@ #include #include -enum -{ - FONT_NAME_COL, - NUM_COLS -}; - struct _EvPropertiesFonts { GtkVBox base_instance; @@ -44,6 +38,7 @@ struct _EvPropertiesFonts { GtkWidget *fonts_treeview; GtkWidget *fonts_progress_label; + EvJob *fonts_job; EvDocument *document; }; @@ -52,6 +47,9 @@ struct _EvPropertiesFontsClass { GtkVBoxClass base_class; }; +static void +job_fonts_finished_cb (EvJob *job, EvPropertiesFonts *properties); + G_DEFINE_TYPE (EvPropertiesFonts, ev_properties_fonts, GTK_TYPE_VBOX) static void @@ -63,6 +61,20 @@ ev_properties_fonts_dispose (GObject *object) g_object_unref (properties->xml); properties->xml = NULL; } + + if (properties->fonts_job) { + + g_signal_handlers_disconnect_by_func + (properties->fonts_job, + job_fonts_finished_cb, + properties); + ev_job_queue_remove_job (properties->fonts_job); + + g_object_unref (properties->fonts_job); + properties->fonts_job = NULL; + } + + G_OBJECT_CLASS (ev_properties_fonts_parent_class)->dispose (object); } static void @@ -73,6 +85,33 @@ ev_properties_fonts_class_init (EvPropertiesFontsClass *properties_class) g_object_class->dispose = ev_properties_fonts_dispose; } +static void +font_cell_data_func (GtkTreeViewColumn *col, GtkCellRenderer *renderer, + GtkTreeModel *model, GtkTreeIter *iter, gpointer user_data) +{ + char *name; + char *details; + char *markup; + + gtk_tree_model_get(model, iter, + EV_DOCUMENT_FONTS_COLUMN_NAME, &name, + EV_DOCUMENT_FONTS_COLUMN_DETAILS, &details, + -1); + + if (details) { + markup = g_strdup_printf ("%s\n%s", + name, details); + } else { + markup = g_strdup_printf ("%s", name); + } + + g_object_set (renderer, "markup", markup, NULL); + + g_free (markup); + g_free (details); + g_free (name); +} + static void ev_properties_fonts_init (EvPropertiesFonts *properties) { @@ -96,12 +135,13 @@ ev_properties_fonts_init (EvPropertiesFonts *properties) gtk_tree_view_column_set_expand (GTK_TREE_VIEW_COLUMN (column), TRUE); gtk_tree_view_append_column (GTK_TREE_VIEW (properties->fonts_treeview), column); - renderer = gtk_cell_renderer_text_new (); + renderer = GTK_CELL_RENDERER (g_object_new (GTK_TYPE_CELL_RENDERER_TEXT, + "ypad", 6, NULL)); gtk_tree_view_column_pack_start (GTK_TREE_VIEW_COLUMN (column), renderer, FALSE); - gtk_tree_view_column_set_title (GTK_TREE_VIEW_COLUMN (column), _("Name")); - gtk_tree_view_column_set_attributes (GTK_TREE_VIEW_COLUMN (column), renderer, - "text", EV_DOCUMENT_FONTS_COLUMN_NAME, - NULL); + gtk_tree_view_column_set_title (GTK_TREE_VIEW_COLUMN (column), _("Font")); + gtk_tree_view_column_set_cell_data_func (column, renderer, + font_cell_data_func, + NULL, NULL); } static void @@ -124,25 +164,25 @@ job_fonts_finished_cb (EvJob *job, EvPropertiesFonts *properties) { EvDocumentFonts *document_fonts = EV_DOCUMENT_FONTS (job->document); double progress; - + progress = ev_document_fonts_get_progress (document_fonts); update_progress_label (properties->fonts_progress_label, progress); if (EV_JOB_FONTS (job)->scan_completed) { g_signal_handlers_disconnect_by_func (job, job_fonts_finished_cb, properties); + g_object_unref (properties->fonts_job); + properties->fonts_job = NULL; } else { GtkTreeModel *model; - EvJob *new_job; model = gtk_tree_view_get_model (GTK_TREE_VIEW (properties->fonts_treeview)); ev_document_doc_mutex_lock (); ev_document_fonts_fill_model (document_fonts, model); ev_document_doc_mutex_unlock (); - new_job = ev_job_fonts_new (job->document); + ev_job_queue_add_job (job, EV_JOB_PRIORITY_LOW); - g_object_unref (new_job); } } @@ -152,19 +192,18 @@ ev_properties_fonts_set_document (EvPropertiesFonts *properties, { GtkTreeView *tree_view = GTK_TREE_VIEW (properties->fonts_treeview); GtkListStore *list_store; - EvJob *job; properties->document = document; - list_store = gtk_list_store_new (NUM_COLS, G_TYPE_STRING); + list_store = gtk_list_store_new (EV_DOCUMENT_FONTS_COLUMN_NUM_COLUMNS, + G_TYPE_STRING, G_TYPE_STRING); gtk_tree_view_set_model (tree_view, GTK_TREE_MODEL (list_store)); - job = ev_job_fonts_new (properties->document); - g_signal_connect_object (job, "finished", - G_CALLBACK (job_fonts_finished_cb), - properties, 0); - ev_job_queue_add_job (job, EV_JOB_PRIORITY_LOW); - g_object_unref (job); + properties->fonts_job = ev_job_fonts_new (properties->document); + g_signal_connect (properties->fonts_job, "finished", + G_CALLBACK (job_fonts_finished_cb), + properties); + ev_job_queue_add_job (properties->fonts_job, EV_JOB_PRIORITY_LOW); } GtkWidget *