[gtk+/portal: 13/14] Add api to serialize GtkPageSetup to a variant



commit 98fae1254ede795852e5067e40c6830469aff1f8
Author: Matthias Clasen <mclasen redhat com>
Date:   Sat Jul 2 20:29:51 2016 -0400

    Add api to serialize GtkPageSetup to a variant
    
    This will be useful for portalized print support.

 gtk/gtkpagesetup.c |   88 ++++++++++++++++++++++++++++++++++++++++++++++++++++
 gtk/gtkpagesetup.h |    5 +++
 2 files changed, 93 insertions(+), 0 deletions(-)
---
diff --git a/gtk/gtkpagesetup.c b/gtk/gtkpagesetup.c
index aa95703..2eb5118 100644
--- a/gtk/gtkpagesetup.c
+++ b/gtk/gtkpagesetup.c
@@ -837,3 +837,91 @@ gtk_page_setup_to_key_file (GtkPageSetup *setup,
                         "Orientation", orientation);
   g_free (orientation);
 }
+
+GVariant *
+gtk_page_setup_to_gvariant (GtkPageSetup *setup)
+{
+  GtkPaperSize *paper_size;
+  GVariantBuilder builder;
+  const char *name;
+  const char *ppd_name;
+  const char *display_name;
+  char *orientation;
+
+  g_variant_builder_init (&builder, G_VARIANT_TYPE_VARDICT);
+
+  paper_size = gtk_page_setup_get_paper_size (setup);
+  name = gtk_paper_size_get_name (paper_size);
+  ppd_name = gtk_paper_size_get_ppd_name (paper_size);
+  display_name = gtk_paper_size_get_display_name (paper_size);
+
+  if (ppd_name != NULL)
+    g_variant_builder_add (&builder, "{sv}", "PPDName", g_variant_new_string (ppd_name));
+  else
+    g_variant_builder_add (&builder, "{sv}", "Name", g_variant_new_string (name));
+
+  if (display_name != NULL)
+    g_variant_builder_add (&builder, "{sv}", "DisplayName", g_variant_new_string (display_name));
+
+  g_variant_builder_add (&builder, "{sv}", "Width", g_variant_new_double (gtk_paper_size_get_width 
(paper_size, GTK_UNIT_MM)));
+  g_variant_builder_add (&builder, "{sv}", "Height", g_variant_new_double (gtk_paper_size_get_height 
(paper_size, GTK_UNIT_MM)));
+
+  g_variant_builder_add (&builder, "{sv}", "MarginTop", g_variant_new_double (gtk_page_setup_get_top_margin 
(setup, GTK_UNIT_MM)));
+  g_variant_builder_add (&builder, "{sv}", "MarginBottom", g_variant_new_double 
(gtk_page_setup_get_bottom_margin (setup, GTK_UNIT_MM)));
+  g_variant_builder_add (&builder, "{sv}", "MarginLeft", g_variant_new_double 
(gtk_page_setup_get_left_margin (setup, GTK_UNIT_MM)));
+  g_variant_builder_add (&builder, "{sv}", "MarginRight", g_variant_new_double 
(gtk_page_setup_get_right_margin (setup, GTK_UNIT_MM)));
+
+  orientation = enum_to_string (GTK_TYPE_PAGE_ORIENTATION,
+                                gtk_page_setup_get_orientation (setup));
+  g_variant_builder_add (&builder, "{sv}", "Orientation", g_variant_new_string (orientation));
+  g_free (orientation);
+
+  return g_variant_builder_end (&builder);
+}
+
+GtkPageSetup *
+gtk_page_setup_from_gvariant (GVariant *variant)
+{
+  GtkPageSetup *setup;
+  const char *orientation;
+  gdouble margin;
+  gdouble size;
+  GKeyFile *key_file;
+  const char *name;
+  GtkPaperSize *paper_size;
+
+  g_return_val_if_fail (g_variant_is_of_type (variant, G_VARIANT_TYPE_VARDICT), NULL);
+
+  setup = gtk_page_setup_new ();
+
+  key_file = g_key_file_new ();
+  if (g_variant_lookup (variant, "PPDName", "&s", &name))
+    g_key_file_set_string (key_file, "Page Setup", "PPDName", name);
+  else if (g_variant_lookup (variant, "Name", "&s", &name))
+    g_key_file_set_string (key_file, "Page Setup", "Name", name);
+  if (g_variant_lookup (variant, "DisplayName", "&s", &name))
+    g_key_file_set_string (key_file, "Page Setup", "DisplayName", name);
+  if (g_variant_lookup (variant, "Width", "d",  &size))
+    g_key_file_set_double (key_file, "Page Setup", "Width", size);
+  if (g_variant_lookup (variant, "Height", "d",  &size))
+    g_key_file_set_double (key_file, "Page Setup", "Height", size);
+  paper_size = gtk_paper_size_new_from_key_file (key_file, "Page Setup", NULL);
+  gtk_page_setup_set_paper_size (setup, paper_size);
+  gtk_paper_size_free (paper_size);
+  g_key_file_unref (key_file);
+
+  if (g_variant_lookup (variant, "MarginTop", "d", &margin))
+    gtk_page_setup_set_top_margin (setup, margin, GTK_UNIT_MM);
+  if (g_variant_lookup (variant, "MarginBottom", "d", &margin))
+    gtk_page_setup_set_bottom_margin (setup, margin, GTK_UNIT_MM);
+  if (g_variant_lookup (variant, "MarginLeft", "d", &margin))
+    gtk_page_setup_set_left_margin (setup, margin, GTK_UNIT_MM);
+  if (g_variant_lookup (variant, "MarginRight", "d", &margin))
+    gtk_page_setup_set_right_margin (setup, margin, GTK_UNIT_MM);
+
+  if (g_variant_lookup (variant, "Orientation", "&s", &orientation))
+    gtk_page_setup_set_orientation (setup, string_to_enum (GTK_TYPE_PAGE_ORIENTATION,
+                                                           orientation));
+
+  return setup;
+}
diff --git a/gtk/gtkpagesetup.h b/gtk/gtkpagesetup.h
index 559ae43..d3b4f15 100644
--- a/gtk/gtkpagesetup.h
+++ b/gtk/gtkpagesetup.h
@@ -127,6 +127,11 @@ void                  gtk_page_setup_to_key_file       (GtkPageSetup        *setup,
                                                     GKeyFile            *key_file,
                                                     const gchar         *group_name);
 
+GDK_AVAILABLE_IN_3_22
+GVariant          *gtk_page_setup_to_gvariant       (GtkPageSetup        *setup);
+GDK_AVAILABLE_IN_3_22
+GtkPageSetup      *gtk_page_setup_from_gvariant     (GVariant            *variant);
+
 G_END_DECLS
 
 #endif /* __GTK_PAGE_SETUP_H__ */


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]