/* GTK - The GIMP Toolkit * gtkprintsettings.c: Print Settings * Copyright (C) 2006, Red Hat, Inc. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library. If not, see <http://www.gnu.org/licenses/>. */ #include "config.h" #include <string.h> #include <stdlib.h> #include <glib/gprintf.h> #include "gtkprintsettings.h" #include "gtkprintutils.h" #include "gtktypebuiltins.h" #include "gtkwidget.h" /** * GtkPrintSettings: * * A `GtkPrintSettings` object represents the settings of a print dialog in * a system-independent way. * * The main use for this object is that once you’ve printed you can get a * settings object that represents the settings the user chose, and the next * time you print you can pass that object in so that the user doesn’t have * to re-set all his settings. * * Its also possible to enumerate the settings so that you can easily save * the settings for the next time your app runs, or even store them in a * document. The predefined keys try to use shared values as much as possible * so that moving such a document between systems still works. */ typedef struct _GtkPrintSettingsClass GtkPrintSettingsClass; #define GTK_IS_PRINT_SETTINGS_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_PRINT_SETTINGS)) #define GTK_PRINT_SETTINGS_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_PRINT_SETTINGS, GtkPrintSettingsClass)) #define GTK_PRINT_SETTINGS_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_PRINT_SETTINGS, GtkPrintSettingsClass)) struct _GtkPrintSettings { GObject parent_instance; GHashTable *hash; }; struct _GtkPrintSettingsClass { GObjectClass parent_class; }; #define KEYFILE_GROUP_NAME "Print Settings" G_DEFINE_TYPE (GtkPrintSettings, gtk_print_settings, G_TYPE_OBJECT) static void gtk_print_settings_finalize (GObject *object) { GtkPrintSettings *settings = GTK_PRINT_SETTINGS (object); g_hash_table_destroy (settings->hash); G_OBJECT_CLASS (gtk_print_settings_parent_class)->finalize (object); } static void gtk_print_settings_init (GtkPrintSettings *settings) { settings->hash = g_hash_table_new_full (g_str_hash, g_str_equal, g_free, g_free); } static void gtk_print_settings_class_init (GtkPrintSettingsClass *class) { GObjectClass *gobject_class = (GObjectClass *)class; gobject_class->finalize = gtk_print_settings_finalize; } /** * gtk_print_settings_new: * * Creates a new `GtkPrintSettings` object. * * Returns: a new `GtkPrintSettings` object */ GtkPrintSettings * gtk_print_settings_new (void) { return g_object_new (GTK_TYPE_PRINT_SETTINGS, NULL); } static void copy_hash_entry (gpointer key, gpointer value, gpointer user_data) { GtkPrintSettings *settings = user_data; g_hash_table_insert (settings->hash, g_strdup (key), g_strdup (value)); } /** * gtk_print_settings_copy: * @other: a `GtkPrintSettings` * * Copies a `GtkPrintSettings` object. * * Returns: (transfer full): a newly allocated copy of @other */ GtkPrintSettings * gtk_print_settings_copy (GtkPrintSettings *other) { GtkPrintSettings *settings; if (other == NULL) return NULL; g_return_val_if_fail (GTK_IS_PRINT_SETTINGS (other), NULL); settings = gtk_print_settings_new (); g_hash_table_foreach (other->hash, copy_hash_entry, settings); return settings; } /** * gtk_print_settings_get: * @settings: a `GtkPrintSettings` * @key: a key * * Looks up the string value associated with @key. * * Returns: (nullable): the string value for @key */ const char * gtk_print_settings_get (GtkPrintSettings *settings, const char *key) { return g_hash_table_lookup (settings->hash, key); } /** * gtk_print_settings_set: * @settings: a `GtkPrintSettings` * @key: a key * @value: (nullable): a string value * * Associates @value with @key. */ void gtk_print_settings_set (GtkPrintSettings *settings, const char *key, const char *value) { if (value == NULL) gtk_print_settings_unset (settings, key); else g_hash_table_insert (settings->hash, g_strdup (key), g_strdup (value)); } /** * gtk_print_settings_unset: * @settings: a `GtkPrintSettings` * @key: a key * * Removes any value associated with @key. * * This has the same effect as setting the value to %NULL. */ void gtk_print_settings_unset (GtkPrintSettings *settings, const char *key) { g_hash_table_remove (settings->hash, key); } /** * gtk_print_settings_has_key: * @settings: a `GtkPrintSettings` * @key: a key * * Returns %TRUE, if a value is associated with @key. * * Returns: %TRUE, if @key has a value */ gboolean gtk_print_settings_has_key (GtkPrintSettings *settings, const char *key) { return gtk_print_settings_get (settings, key) != NULL; } /** * gtk_print_settings_get_bool: * @settings: a `GtkPrintSettings` * @key: a key * * Returns the boolean represented by the value * that is associated with @key. * * The string “true” represents %TRUE, any other * string %FALSE. * * Returns: %TRUE, if @key maps to a true value. */ gboolean gtk_print_settings_get_bool (GtkPrintSettings *settings, const char *key) { const char *val; val = gtk_print_settings_get (settings, key); if (g_strcmp0 (val, "true") == 0) return TRUE; return FALSE; } /** * gtk_print_settings_get_bool_with_default: * @settings: a `GtkPrintSettings` * @key: a key * @default_val: the default value * * Returns the boolean represented by the value * that is associated with @key, or @default_val * if the value does not represent a boolean. * * The string “true” represents %TRUE, the string * “false” represents %FALSE. * * Returns: the boolean value associated with @key */ static gboolean gtk_print_settings_get_bool_with_default (GtkPrintSettings *settings, const char *key, gboolean default_val) { const char *val; val = gtk_print_settings_get (settings, key); if (g_strcmp0 (val, "true") == 0) return TRUE; if (g_strcmp0 (val, "false") == 0) return FALSE; return default_val; } /** * gtk_print_settings_set_bool: * @settings: a `GtkPrintSettings` * @key: a key * @value: a boolean * * Sets @key to a boolean value. */ void gtk_print_settings_set_bool (GtkPrintSettings *settings, const char *key, gboolean value) { if (value) gtk_print_settings_set (settings, key, "true"); else gtk_print_settings_set (settings, key, "false"); } /** * gtk_print_settings_get_double_with_default: * @settings: a `GtkPrintSettings` * @key: a key * @def: the default value * * Returns the floating point number represented by * the value that is associated with @key, or @default_val * if the value does not represent a floating point number. * * Floating point numbers are parsed with g_ascii_strtod(). * * Returns: the floating point number associated with @key */ double gtk_print_settings_get_double_with_default (GtkPrintSettings *settings, const char *key, double def) { const char *val; val = gtk_print_settings_get (settings, key); if (val == NULL) return def; return g_ascii_strtod (val, NULL); } /** * gtk_print_settings_get_double: * @settings: a `GtkPrintSettings` * @key: a key * * Returns the double value associated with @key, or 0. * * Returns: the double value of @key */ double gtk_print_settings_get_double (GtkPrintSettings *settings, const char *key) { return gtk_print_settings_get_double_with_default (settings, key, 0.0); } /** * gtk_print_settings_set_double: * @settings: a `GtkPrintSettings` * @key: a key * @value: a double value * * Sets @key to a double value. */ void gtk_print_settings_set_double (GtkPrintSettings *settings, const char *key, double value) { char buf[G_ASCII_DTOSTR_BUF_SIZE]; g_ascii_dtostr (buf, G_ASCII_DTOSTR_BUF_SIZE, value); gtk_print_settings_set (settings, key, buf); } /** * gtk_print_settings_get_length: * @settings: a `GtkPrintSettings` * @key: a key * @unit: the unit of the return value * * Returns the value associated with @key, interpreted * as a length. * * The returned value is converted to @units. * * Returns: the length value of @key, converted to @unit */ double gtk_print_settings_get_length (GtkPrintSettings *settings, const char *key, GtkUnit unit) { double length = gtk_print_settings_get_double (settings, key); return _gtk_print_convert_from_mm (length, unit); } /** * gtk_print_settings_set_length: * @settings: a `GtkPrintSettings` * @key: a key * @value: a length * @unit: the unit of @length * * Associates a length in units of @unit with @key. */ void gtk_print_settings_set_length (GtkPrintSettings *settings, const char *key, double value, GtkUnit unit) { gtk_print_settings_set_double (settings, key, _gtk_print_convert_to_mm (value, unit)); } /** * gtk_print_settings_get_int_with_default: * @settings: a `GtkPrintSettings` * @key: a key * @def: the default value * * Returns the value of @key, interpreted as * an integer, or the default value. * * Returns: the integer value of @key */ int gtk_print_settings_get_int_with_default (GtkPrintSettings *settings, const char *key, int def) { const char *val; val = gtk_print_settings_get (settings, key); if (val == NULL) return def; return atoi (val); } /** * gtk_print_settings_get_int: * @settings: a `GtkPrintSettings` * @key: a key * * Returns the integer value of @key, or 0. * * Returns: the integer value of @key */ int gtk_print_settings_get_int (GtkPrintSettings *settings, const char *key) { return gtk_print_settings_get_int_with_default (settings, key, 0); } /** * gtk_print_settings_set_int: * @settings: a `GtkPrintSettings` * @key: a key * @value: an integer * * Sets @key to an integer value. */ void gtk_print_settings_set_int (GtkPrintSettings *settings, const char *key, int value) { char buf[128]; g_sprintf (buf, "%d", value); gtk_print_settings_set (settings, key, buf); } /** * gtk_print_settings_foreach: * @settings: a `GtkPrintSettings` * @func: (scope call): the function to call * @user_data: (closure): user data for @func * * Calls @func for each key-value pair of @settings. */ void gtk_print_settings_foreach (GtkPrintSettings *settings, GtkPrintSettingsFunc func, gpointer user_data) { g_hash_table_foreach (settings->hash, (GHFunc)func, user_data); } /** * gtk_print_settings_get_printer: * @settings: a `GtkPrintSettings` * * Convenience function to obtain the value of * %GTK_PRINT_SETTINGS_PRINTER. * * Returns: (nullable): the printer name */ const char * gtk_print_settings_get_printer (GtkPrintSettings *settings) { return gtk_print_settings_get (settings, GTK_PRINT_SETTINGS_PRINTER); } /** * gtk_print_settings_set_printer: * @settings: a `GtkPrintSettings` * @printer: the printer name * * Convenience function to set %GTK_PRINT_SETTINGS_PRINTER * to @printer. */ void gtk_print_settings_set_printer (GtkPrintSettings *settings, const char *printer) { gtk_print_settings_set (settings, GTK_PRINT_SETTINGS_PRINTER, printer); } /** * gtk_print_settings_get_orientation: * @settings: a `GtkPrintSettings` * * Get the value of %GTK_PRINT_SETTINGS_ORIENTATION, * converted to a `GtkPageOrientation`. * * Returns: the orientation */ GtkPageOrientation gtk_print_settings_get_orientation (GtkPrintSettings *settings) { const char *val; val = gtk_print_settings_get (settings, GTK_PRINT_SETTINGS_ORIENTATION); if (val == NULL || strcmp (val, "portrait") == 0) return GTK_PAGE_ORIENTATION_PORTRAIT; if (strcmp (val, "landscape") == 0) return GTK_PAGE_ORIENTATION_LANDSCAPE; if (strcmp (val, "reverse_portrait") == 0) return GTK_PAGE_ORIENTATION_REVERSE_PORTRAIT; if (strcmp (val, "reverse_landscape") == 0) return GTK_PAGE_ORIENTATION_REVERSE_LANDSCAPE; return GTK_PAGE_ORIENTATION_PORTRAIT; } /** * gtk_print_settings_set_orientation: * @settings: a `GtkPrintSettings` * @orientation: a page orientation * * Sets the value of %GTK_PRINT_SETTINGS_ORIENTATION. */ void gtk_print_settings_set_orientation (GtkPrintSettings *settings, GtkPageOrientation orientation) { const char *val; switch (orientation) { case GTK_PAGE_ORIENTATION_LANDSCAPE: val = "landscape"; break; default: case GTK_PAGE_ORIENTATION_PORTRAIT: val = "portrait"; break; case GTK_PAGE_ORIENTATION_REVERSE_LANDSCAPE: val = "reverse_landscape"; break; case GTK_PAGE_ORIENTATION_REVERSE_PORTRAIT: val = "reverse_portrait"; break; } gtk_print_settings_set (settings, GTK_PRINT_SETTINGS_ORIENTATION, val); } /** * gtk_print_settings_get_paper_size: * @settings: a `GtkPrintSettings` * * Gets the value of %GTK_PRINT_SETTINGS_PAPER_FORMAT, * converted to a `GtkPaperSize`. * * Returns: (nullable): the paper size */ GtkPaperSize * gtk_print_settings_get_paper_size (GtkPrintSettings *settings) { const char *val; const char *name; double w, h; val = gtk_print_settings_get (settings, GTK_PRINT_SETTINGS_PAPER_FORMAT); if (val == NULL) return NULL; if (g_str_has_prefix (val, "custom-")) { name = val + strlen ("custom-"); w = gtk_print_settings_get_paper_width (settings, GTK_UNIT_MM); h = gtk_print_settings_get_paper_height (settings, GTK_UNIT_MM); return gtk_paper_size_new_custom (name, name, w, h, GTK_UNIT_MM); } return gtk_paper_size_new (val); } /** * gtk_print_settings_set_paper_size: * @settings: a `GtkPrintSettings` * @paper_size: a paper size * * Sets the value of %GTK_PRINT_SETTINGS_PAPER_FORMAT, * %GTK_PRINT_SETTINGS_PAPER_WIDTH and * %GTK_PRINT_SETTINGS_PAPER_HEIGHT. */ void gtk_print_settings_set_paper_size (GtkPrintSettings *settings, GtkPaperSize *paper_size) { char *custom_name; if (paper_size == NULL) { gtk_print_settings_set (settings, GTK_PRINT_SETTINGS_PAPER_FORMAT, NULL); gtk_print_settings_set (settings, GTK_PRINT_SETTINGS_PAPER_WIDTH, NULL); gtk_print_settings_set (settings, GTK_PRINT_SETTINGS_PAPER_HEIGHT, NULL); } else if (gtk_paper_size_is_custom (paper_size)) { custom_name = g_strdup_printf ("custom-%s", gtk_paper_size_get_name (paper_size)); gtk_print_settings_set (settings, GTK_PRINT_SETTINGS_PAPER_FORMAT, custom_name); g_free (custom_name); gtk_print_settings_set_paper_width (settings, gtk_paper_size_get_width (paper_size, GTK_UNIT_MM), GTK_UNIT_MM); gtk_print_settings_set_paper_height (settings, gtk_paper_size_get_height (paper_size, GTK_UNIT_MM), GTK_UNIT_MM); } else gtk_print_settings_set (settings, GTK_PRINT_SETTINGS_PAPER_FORMAT, gtk_paper_size_get_name (paper_size)); } /** * gtk_print_settings_get_paper_width: * @settings: a `GtkPrintSettings` * @unit: the unit for the return value * * Gets the value of %GTK_PRINT_SETTINGS_PAPER_WIDTH, * converted to @unit. * * Returns: the paper width, in units of @unit */ double gtk_print_settings_get_paper_width (GtkPrintSettings *settings, GtkUnit unit) { return gtk_print_settings_get_length (settings, GTK_PRINT_SETTINGS_PAPER_WIDTH, unit); } /** * gtk_print_settings_set_paper_width: * @settings: a `GtkPrintSettings` * @width: the paper width * @unit: the units of @width * * Sets the value of %GTK_PRINT_SETTINGS_PAPER_WIDTH. */ void gtk_print_settings_set_paper_width (GtkPrintSettings *settings, double width, GtkUnit unit) { gtk_print_settings_set_length (settings, GTK_PRINT_SETTINGS_PAPER_WIDTH, width, unit); } /** * gtk_print_settings_get_paper_height: * @settings: a `GtkPrintSettings` * @unit: the unit for the return value * * Gets the value of %GTK_PRINT_SETTINGS_PAPER_HEIGHT, * converted to @unit. * * Returns: the paper height, in units of @unit */ double gtk_print_settings_get_paper_height (GtkPrintSettings *settings, GtkUnit unit) { return gtk_print_settings_get_length (settings, GTK_PRINT_SETTINGS_PAPER_HEIGHT, unit); } /** * gtk_print_settings_set_paper_height: * @settings: a `GtkPrintSettings` * @height: the paper height * @unit: the units of @height * * Sets the value of %GTK_PRINT_SETTINGS_PAPER_HEIGHT. */ void gtk_print_settings_set_paper_height (GtkPrintSettings *settings, double height, GtkUnit unit) { gtk_print_settings_set_length (settings, GTK_PRINT_SETTINGS_PAPER_HEIGHT, height, unit); } /** * gtk_print_settings_get_use_color: * @settings: a `GtkPrintSettings` * * Gets the value of %GTK_PRINT_SETTINGS_USE_COLOR. * * Returns: whether to use color */ gboolean gtk_print_settings_get_use_color (GtkPrintSettings *settings) { return gtk_print_settings_get_bool_with_default (settings, GTK_PRINT_SETTINGS_USE_COLOR, TRUE); } /** * gtk_print_settings_set_use_color: * @settings: a `GtkPrintSettings` * @use_color: whether to use color * * Sets the value of %GTK_PRINT_SETTINGS_USE_COLOR. */ void gtk_print_settings_set_use_color (GtkPrintSettings *settings, gboolean use_color) { gtk_print_settings_set_bool (settings, GTK_PRINT_SETTINGS_USE_COLOR, use_color); } /** * gtk_print_settings_get_collate: * @settings: a `GtkPrintSettings` * * Gets the value of %GTK_PRINT_SETTINGS_COLLATE. * * Returns: whether to collate the printed pages */ gboolean gtk_print_settings_get_collate (GtkPrintSettings *settings) { return gtk_print_settings_get_bool_with_default (settings, GTK_PRINT_SETTINGS_COLLATE, TRUE); } /** * gtk_print_settings_set_collate: * @settings: a `GtkPrintSettings` * @collate: whether to collate the output * * Sets the value of %GTK_PRINT_SETTINGS_COLLATE. */ void gtk_print_settings_set_collate (GtkPrintSettings *settings, gboolean collate) { gtk_print_settings_set_bool (settings, GTK_PRINT_SETTINGS_COLLATE, collate); } /** * gtk_print_settings_get_reverse: * @settings: a `GtkPrintSettings` * * Gets the value of %GTK_PRINT_SETTINGS_REVERSE. * * Returns: whether to reverse the order of the printed pages */ gboolean gtk_print_settings_get_reverse (GtkPrintSettings *settings) { return gtk_print_settings_get_bool (settings, GTK_PRINT_SETTINGS_REVERSE); } /** * gtk_print_settings_set_reverse: * @settings: a `GtkPrintSettings` * @reverse: whether to reverse the output * * Sets the value of %GTK_PRINT_SETTINGS_REVERSE. */ void gtk_print_settings_set_reverse (GtkPrintSettings *settings, gboolean reverse) { gtk_print_settings_set_bool (settings, GTK_PRINT_SETTINGS_REVERSE, reverse); } /** * gtk_print_settings_get_duplex: * @settings: a `GtkPrintSettings` * * Gets the value of %GTK_PRINT_SETTINGS_DUPLEX. * * Returns: whether to print the output in duplex. */ GtkPrintDuplex gtk_print_settings_get_duplex (GtkPrintSettings *settings) { const char *val; val = gtk_print_settings_get (settings, GTK_PRINT_SETTINGS_DUPLEX); if (val == NULL || (strcmp (val, "simplex") == 0)) return GTK_PRINT_DUPLEX_SIMPLEX; if (strcmp (val, "horizontal") == 0) return GTK_PRINT_DUPLEX_HORIZONTAL; if (strcmp (val, "vertical") == 0) return GTK_PRINT_DUPLEX_VERTICAL; return GTK_PRINT_DUPLEX_SIMPLEX; } /** * gtk_print_settings_set_duplex: * @settings: a `GtkPrintSettings` * @duplex: a `GtkPrintDuplex` value * * Sets the value of %GTK_PRINT_SETTINGS_DUPLEX. */ void gtk_print_settings_set_duplex (GtkPrintSettings *settings, GtkPrintDuplex duplex) { const char *str; switch (duplex) { default: case GTK_PRINT_DUPLEX_SIMPLEX: str = "simplex"; break; case GTK_PRINT_DUPLEX_HORIZONTAL: str = "horizontal"; break; case GTK_PRINT_DUPLEX_VERTICAL: str = "vertical"; break; } gtk_print_settings_set (settings, GTK_PRINT_SETTINGS_DUPLEX, str); } /** * gtk_print_settings_get_quality: * @settings: a `GtkPrintSettings` * * Gets the value of %GTK_PRINT_SETTINGS_QUALITY. * * Returns: the print quality */ GtkPrintQuality gtk_print_settings_get_quality (GtkPrintSettings *settings) { const char *val; val = gtk_print_settings_get (settings, GTK_PRINT_SETTINGS_QUALITY); if (val == NULL || (strcmp (val, "normal") == 0)) return GTK_PRINT_QUALITY_NORMAL; if (strcmp (val, "high") == 0) return GTK_PRINT_QUALITY_HIGH; if (strcmp (val, "low") == 0) return GTK_PRINT_QUALITY_LOW; if (strcmp (val, "draft") == 0) return GTK_PRINT_QUALITY_DRAFT; return GTK_PRINT_QUALITY_NORMAL; } /** * gtk_print_settings_set_quality: * @settings: a `GtkPrintSettings` * @quality: a `GtkPrintQuality` value * * Sets the value of %GTK_PRINT_SETTINGS_QUALITY. */ void gtk_print_settings_set_quality (GtkPrintSettings *settings, GtkPrintQuality quality) { const char *str; switch (quality) { default: case GTK_PRINT_QUALITY_NORMAL: str = "normal"; break; case GTK_PRINT_QUALITY_HIGH: str = "high"; break; case GTK_PRINT_QUALITY_LOW: str = "low"; break; case GTK_PRINT_QUALITY_DRAFT: str = "draft"; break; } gtk_print_settings_set (settings, GTK_PRINT_SETTINGS_QUALITY, str); } /** * gtk_print_settings_get_page_set: * @settings: a `GtkPrintSettings` * * Gets the value of %GTK_PRINT_SETTINGS_PAGE_SET. * * Returns: the set of pages to print */ GtkPageSet gtk_print_settings_get_page_set (GtkPrintSettings *settings) { const char *val; val = gtk_print_settings_get (settings, GTK_PRINT_SETTINGS_PAGE_SET); if (val == NULL || (strcmp (val, "all") == 0)) return GTK_PAGE_SET_ALL; if (strcmp (val, "even") == 0) return GTK_PAGE_SET_EVEN; if (strcmp (val, "odd") == 0) return GTK_PAGE_SET_ODD; return GTK_PAGE_SET_ALL; } /** * gtk_print_settings_set_page_set: * @settings: a `GtkPrintSettings` * @page_set: a `GtkPageSet` value * * Sets the value of %GTK_PRINT_SETTINGS_PAGE_SET. */ void gtk_print_settings_set_page_set (GtkPrintSettings *settings, GtkPageSet page_set) { const char *str; switch (page_set) { default: case GTK_PAGE_SET_ALL: str = "all"; break; case GTK_PAGE_SET_EVEN: str = "even"; break; case GTK_PAGE_SET_ODD: str = "odd"; break; } gtk_print_settings_set (settings, GTK_PRINT_SETTINGS_PAGE_SET, str); } /** * gtk_print_settings_get_number_up_layout: * @settings: a `GtkPrintSettings` * * Gets the value of %GTK_PRINT_SETTINGS_NUMBER_UP_LAYOUT. * * Returns: layout of page in number-up mode */ GtkNumberUpLayout gtk_print_settings_get_number_up_layout (GtkPrintSettings *settings) { GtkNumberUpLayout layout; GtkTextDirection text_direction; GEnumClass *enum_class; GEnumValue *enum_value; const char *val; g_return_val_if_fail (GTK_IS_PRINT_SETTINGS (settings), GTK_NUMBER_UP_LAYOUT_LEFT_TO_RIGHT_TOP_TO_BOTTOM); val = gtk_print_settings_get (settings, GTK_PRINT_SETTINGS_NUMBER_UP_LAYOUT); text_direction = gtk_widget_get_default_direction (); if (text_direction == GTK_TEXT_DIR_LTR) layout = GTK_NUMBER_UP_LAYOUT_LEFT_TO_RIGHT_TOP_TO_BOTTOM; else layout = GTK_NUMBER_UP_LAYOUT_RIGHT_TO_LEFT_TOP_TO_BOTTOM; if (val == NULL) return layout; enum_class = g_type_class_ref (GTK_TYPE_NUMBER_UP_LAYOUT); enum_value = g_enum_get_value_by_nick (enum_class, val); if (enum_value) layout = enum_value->value; g_type_class_unref (enum_class); return layout; } /** * gtk_print_settings_set_number_up_layout: * @settings: a `GtkPrintSettings` * @number_up_layout: a `GtkNumberUpLayout` value * * Sets the value of %GTK_PRINT_SETTINGS_NUMBER_UP_LAYOUT. */ void gtk_print_settings_set_number_up_layout (GtkPrintSettings *settings, GtkNumberUpLayout number_up_layout) { GEnumClass *enum_class; GEnumValue *enum_value; g_return_if_fail (GTK_IS_PRINT_SETTINGS (settings)); enum_class = g_type_class_ref (GTK_TYPE_NUMBER_UP_LAYOUT); enum_value = g_enum_get_value (enum_class, number_up_layout); g_return_if_fail (enum_value != NULL); gtk_print_settings_set (settings, GTK_PRINT_SETTINGS_NUMBER_UP_LAYOUT, enum_value->value_nick); g_type_class_unref (enum_class); } /** * gtk_print_settings_get_n_copies: * @settings: a `GtkPrintSettings` * * Gets the value of %GTK_PRINT_SETTINGS_N_COPIES. * * Returns: the number of copies to print */ int gtk_print_settings_get_n_copies (GtkPrintSettings *settings) { return gtk_print_settings_get_int_with_default (settings, GTK_PRINT_SETTINGS_N_COPIES, 1); } /** * gtk_print_settings_set_n_copies: * @settings: a `GtkPrintSettings` * @num_copies: the number of copies * * Sets the value of %GTK_PRINT_SETTINGS_N_COPIES. */ void gtk_print_settings_set_n_copies (GtkPrintSettings *settings, int num_copies) { gtk_print_settings_set_int (settings, GTK_PRINT_SETTINGS_N_COPIES, num_copies); } /** * gtk_print_settings_get_number_up: * @settings: a `GtkPrintSettings` * * Gets the value of %GTK_PRINT_SETTINGS_NUMBER_UP. * * Returns: the number of pages per sheet */ int gtk_print_settings_get_number_up (GtkPrintSettings *settings) { return gtk_print_settings_get_int_with_default (settings, GTK_PRINT_SETTINGS_NUMBER_UP, 1); } /** * gtk_print_settings_set_number_up: * @settings: a `GtkPrintSettings` * @number_up: the number of pages per sheet * * Sets the value of %GTK_PRINT_SETTINGS_NUMBER_UP. */ void gtk_print_settings_set_number_up (GtkPrintSettings *settings, int number_up) { gtk_print_settings_set_int (settings, GTK_PRINT_SETTINGS_NUMBER_UP, number_up); } /** * gtk_print_settings_get_resolution: * @settings: a `GtkPrintSettings` * * Gets the value of %GTK_PRINT_SETTINGS_RESOLUTION. * * Returns: the resolution in dpi */ int gtk_print_settings_get_resolution (GtkPrintSettings *settings) { return gtk_print_settings_get_int_with_default (settings, GTK_PRINT_SETTINGS_RESOLUTION, 300); } /** * gtk_print_settings_set_resolution: * @settings: a `GtkPrintSettings` * @resolution: the resolution in dpi * * Sets the values of %GTK_PRINT_SETTINGS_RESOLUTION, * %GTK_PRINT_SETTINGS_RESOLUTION_X and * %GTK_PRINT_SETTINGS_RESOLUTION_Y. */ void gtk_print_settings_set_resolution (GtkPrintSettings *settings, int resolution) { gtk_print_settings_set_int (settings, GTK_PRINT_SETTINGS_RESOLUTION, resolution); gtk_print_settings_set_int (settings, GTK_PRINT_SETTINGS_RESOLUTION_X, resolution); gtk_print_settings_set_int (settings, GTK_PRINT_SETTINGS_RESOLUTION_Y, resolution); } /** * gtk_print_settings_get_resolution_x: * @settings: a `GtkPrintSettings` * * Gets the value of %GTK_PRINT_SETTINGS_RESOLUTION_X. * * Returns: the horizontal resolution in dpi */ int gtk_print_settings_get_resolution_x (GtkPrintSettings *settings) { return gtk_print_settings_get_int_with_default (settings, GTK_PRINT_SETTINGS_RESOLUTION_X, 300); } /** * gtk_print_settings_get_resolution_y: * @settings: a `GtkPrintSettings` * * Gets the value of %GTK_PRINT_SETTINGS_RESOLUTION_Y. * * Returns: the vertical resolution in dpi */ int gtk_print_settings_get_resolution_y (GtkPrintSettings *settings) { return gtk_print_settings_get_int_with_default (settings, GTK_PRINT_SETTINGS_RESOLUTION_Y, 300); } /** * gtk_print_settings_set_resolution_xy: * @settings: a `GtkPrintSettings` * @resolution_x: the horizontal resolution in dpi * @resolution_y: the vertical resolution in dpi * * Sets the values of %GTK_PRINT_SETTINGS_RESOLUTION, * %GTK_PRINT_SETTINGS_RESOLUTION_X and * %GTK_PRINT_SETTINGS_RESOLUTION_Y. */ void gtk_print_settings_set_resolution_xy (GtkPrintSettings *settings, int resolution_x, int resolution_y) { gtk_print_settings_set_int (settings, GTK_PRINT_SETTINGS_RESOLUTION_X, resolution_x); gtk_print_settings_set_int (settings, GTK_PRINT_SETTINGS_RESOLUTION_Y, resolution_y); gtk_print_settings_set_int (settings, GTK_PRINT_SETTINGS_RESOLUTION, resolution_x); } /** * gtk_print_settings_get_printer_lpi: * @settings: a `GtkPrintSettings` * * Gets the value of %GTK_PRINT_SETTINGS_PRINTER_LPI. * * Returns: the resolution in lpi (lines per inch) */ double gtk_print_settings_get_printer_lpi (GtkPrintSettings *settings) { return gtk_print_settings_get_double_with_default (settings, GTK_PRINT_SETTINGS_PRINTER_LPI, 150.0); } /** * gtk_print_settings_set_printer_lpi: * @settings: a `GtkPrintSettings` * @lpi: the resolution in lpi (lines per inch) * * Sets the value of %GTK_PRINT_SETTINGS_PRINTER_LPI. */ void gtk_print_settings_set_printer_lpi (GtkPrintSettings *settings, double lpi) { gtk_print_settings_set_double (settings, GTK_PRINT_SETTINGS_PRINTER_LPI, lpi); } /** * gtk_print_settings_get_scale: * @settings: a `GtkPrintSettings` * * Gets the value of %GTK_PRINT_SETTINGS_SCALE. * * Returns: the scale in percent */ double gtk_print_settings_get_scale (GtkPrintSettings *settings) { return gtk_print_settings_get_double_with_default (settings, GTK_PRINT_SETTINGS_SCALE, 100.0); } /** * gtk_print_settings_set_scale: * @settings: a `GtkPrintSettings` * @scale: the scale in percent * * Sets the value of %GTK_PRINT_SETTINGS_SCALE. */ void gtk_print_settings_set_scale (GtkPrintSettings *settings, double scale) { gtk_print_settings_set_double (settings, GTK_PRINT_SETTINGS_SCALE, scale); } /** * gtk_print_settings_get_print_pages: * @settings: a `GtkPrintSettings` * * Gets the value of %GTK_PRINT_SETTINGS_PRINT_PAGES. * * Returns: which pages to print */ GtkPrintPages gtk_print_settings_get_print_pages (GtkPrintSettings *settings) { const char *val; val = gtk_print_settings_get (settings, GTK_PRINT_SETTINGS_PRINT_PAGES); if (val == NULL || (strcmp (val, "all") == 0)) return GTK_PRINT_PAGES_ALL; if (strcmp (val, "selection") == 0) return GTK_PRINT_PAGES_SELECTION; if (strcmp (val, "current") == 0) return GTK_PRINT_PAGES_CURRENT; if (strcmp (val, "ranges") == 0) return GTK_PRINT_PAGES_RANGES; return GTK_PRINT_PAGES_ALL; } /** * gtk_print_settings_set_print_pages: * @settings: a `GtkPrintSettings` * @pages: a `GtkPrintPages` value * * Sets the value of %GTK_PRINT_SETTINGS_PRINT_PAGES. */ void gtk_print_settings_set_print_pages (GtkPrintSettings *settings, GtkPrintPages pages) { const char *str; switch (pages) { default: case GTK_PRINT_PAGES_ALL: str = "all"; break; case GTK_PRINT_PAGES_CURRENT: str = "current"; break; case GTK_PRINT_PAGES_SELECTION: str = "selection"; break; case GTK_PRINT_PAGES_RANGES: str = "ranges"; break; } gtk_print_settings_set (settings, GTK_PRINT_SETTINGS_PRINT_PAGES, str); } /** * gtk_print_settings_get_page_ranges: * @settings: a `GtkPrintSettings` * @num_ranges: (out): return location for the length of the returned array * * Gets the value of %GTK_PRINT_SETTINGS_PAGE_RANGES. * * Returns: (array length=num_ranges) (transfer full): an array * of `GtkPageRange`s. Use g_free() to free the array when * it is no longer needed. */ GtkPageRange * gtk_print_settings_get_page_ranges (GtkPrintSettings *settings, int *num_ranges) { const char *val; char **range_strs; GtkPageRange *ranges; int i, n; val = gtk_print_settings_get (settings, GTK_PRINT_SETTINGS_PAGE_RANGES); if (val == NULL) { *num_ranges = 0; return NULL; } range_strs = g_strsplit (val, ",", 0); for (i = 0; range_strs[i] != NULL; i++) ; n = i; ranges = g_new0 (GtkPageRange, n); for (i = 0; i < n; i++) { int start, end; char *str; start = (int)strtol (range_strs[i], &str, 10); end = start; if (*str == '-') { str++; end = (int)strtol (str, NULL, 10); } ranges[i].start = start; ranges[i].end = end; } g_strfreev (range_strs); *num_ranges = n; return ranges; } /** * gtk_print_settings_set_page_ranges: * @settings: a `GtkPrintSettings` * @page_ranges: (array length=num_ranges): an array of `GtkPageRange`s * @num_ranges: the length of @page_ranges * * Sets the value of %GTK_PRINT_SETTINGS_PAGE_RANGES. */ void gtk_print_settings_set_page_ranges (GtkPrintSettings *settings, GtkPageRange *page_ranges, int num_ranges) { GString *s; int i; s = g_string_new (""); for (i = 0; i < num_ranges; i++) { if (page_ranges[i].start == page_ranges[i].end) g_string_append_printf (s, "%d", page_ranges[i].start); else g_string_append_printf (s, "%d-%d", page_ranges[i].start, page_ranges[i].end); if (i < num_ranges - 1) g_string_append (s, ","); } gtk_print_settings_set (settings, GTK_PRINT_SETTINGS_PAGE_RANGES, s->str); g_string_free (s, TRUE); } /** * gtk_print_settings_get_default_source: * @settings: a `GtkPrintSettings` * * Gets the value of %GTK_PRINT_SETTINGS_DEFAULT_SOURCE. * * Returns: (nullable): the default source */ const char * gtk_print_settings_get_default_source (GtkPrintSettings *settings) { return gtk_print_settings_get (settings, GTK_PRINT_SETTINGS_DEFAULT_SOURCE); } /** * gtk_print_settings_set_default_source: * @settings: a `GtkPrintSettings` * @default_source: the default source * * Sets the value of %GTK_PRINT_SETTINGS_DEFAULT_SOURCE. */ void gtk_print_settings_set_default_source (GtkPrintSettings *settings, const char *default_source) { gtk_print_settings_set (settings, GTK_PRINT_SETTINGS_DEFAULT_SOURCE, default_source); } /** * gtk_print_settings_get_media_type: * @settings: a `GtkPrintSettings` * * Gets the value of %GTK_PRINT_SETTINGS_MEDIA_TYPE. * * The set of media types is defined in PWG 5101.1-2002 PWG. * * Returns: (nullable): the media type */ const char * gtk_print_settings_get_media_type (GtkPrintSettings *settings) { return gtk_print_settings_get (settings, GTK_PRINT_SETTINGS_MEDIA_TYPE); } /** * gtk_print_settings_set_media_type: * @settings: a `GtkPrintSettings` * @media_type: the media type * * Sets the value of %GTK_PRINT_SETTINGS_MEDIA_TYPE. * * The set of media types is defined in PWG 5101.1-2002 PWG. */ void gtk_print_settings_set_media_type (GtkPrintSettings *settings, const char *media_type) { gtk_print_settings_set (settings, GTK_PRINT_SETTINGS_MEDIA_TYPE, media_type); } /** * gtk_print_settings_get_dither: * @settings: a `GtkPrintSettings` * * Gets the value of %GTK_PRINT_SETTINGS_DITHER. * * Returns: (nullable): the dithering that is used */ const char * gtk_print_settings_get_dither (GtkPrintSettings *settings) { return gtk_print_settings_get (settings, GTK_PRINT_SETTINGS_DITHER); } /** * gtk_print_settings_set_dither: * @settings: a `GtkPrintSettings` * @dither: the dithering that is used * * Sets the value of %GTK_PRINT_SETTINGS_DITHER. */ void gtk_print_settings_set_dither (GtkPrintSettings *settings, const char *dither) { gtk_print_settings_set (settings, GTK_PRINT_SETTINGS_DITHER, dither); } /** * gtk_print_settings_get_finishings: * @settings: a `GtkPrintSettings` * * Gets the value of %GTK_PRINT_SETTINGS_FINISHINGS. * * Returns: (nullable): the finishings */ const char * gtk_print_settings_get_finishings (GtkPrintSettings *settings) { return gtk_print_settings_get (settings, GTK_PRINT_SETTINGS_FINISHINGS); } /** * gtk_print_settings_set_finishings: * @settings: a `GtkPrintSettings` * @finishings: the finishings * * Sets the value of %GTK_PRINT_SETTINGS_FINISHINGS. */ void gtk_print_settings_set_finishings (GtkPrintSettings *settings, const char *finishings) { gtk_print_settings_set (settings, GTK_PRINT_SETTINGS_FINISHINGS, finishings); } /** * gtk_print_settings_get_output_bin: * @settings: a `GtkPrintSettings` * * Gets the value of %GTK_PRINT_SETTINGS_OUTPUT_BIN. * * Returns: (nullable): the output bin */ const char * gtk_print_settings_get_output_bin (GtkPrintSettings *settings) { return gtk_print_settings_get (settings, GTK_PRINT_SETTINGS_OUTPUT_BIN); } /** * gtk_print_settings_set_output_bin: * @settings: a `GtkPrintSettings` * @output_bin: the output bin * * Sets the value of %GTK_PRINT_SETTINGS_OUTPUT_BIN. */ void gtk_print_settings_set_output_bin (GtkPrintSettings *settings, const char *output_bin) { gtk_print_settings_set (settings, GTK_PRINT_SETTINGS_OUTPUT_BIN, output_bin); } /** * gtk_print_settings_load_file: * @settings: a `GtkPrintSettings` * @file_name: (type filename): the filename to read the settings from * @error: (nullable): return location for errors * * Reads the print settings from @file_name. * * If the file could not be loaded then error is set to either * a `GFileError` or `GKeyFileError`. * * See [method@Gtk.PrintSettings.to_file]. * * Returns: %TRUE on success */ gboolean gtk_print_settings_load_file (GtkPrintSettings *settings, const char *file_name, GError **error) { gboolean retval = FALSE; GKeyFile *key_file; g_return_val_if_fail (GTK_IS_PRINT_SETTINGS (settings), FALSE); g_return_val_if_fail (file_name != NULL, FALSE); key_file = g_key_file_new (); if (g_key_file_load_from_file (key_file, file_name, 0, error) && gtk_print_settings_load_key_file (settings, key_file, NULL, error)) retval = TRUE; g_key_file_free (key_file); return retval; } /** * gtk_print_settings_new_from_file: * @file_name: (type filename): the filename to read the settings from * @error: (nullable): return location for errors * * Reads the print settings from @file_name. * * Returns a new `GtkPrintSettings` object with the restored settings, * or %NULL if an error occurred. If the file could not be loaded then * error is set to either a `GFileError` or `GKeyFileError`. * * See [method@Gtk.PrintSettings.to_file]. * * Returns: the restored `GtkPrintSettings` */ GtkPrintSettings * gtk_print_settings_new_from_file (const char *file_name, GError **error) { GtkPrintSettings *settings = gtk_print_settings_new (); if (!gtk_print_settings_load_file (settings, file_name, error)) { g_object_unref (settings); settings = NULL; } return settings; } /** * gtk_print_settings_load_key_file: * @settings: a `GtkPrintSettings` * @key_file: the `GKeyFile` to retrieve the settings from * @group_name: (nullable): the name of the group to use, or %NULL * to use the default “Print Settings” * @error: (nullable): return location for errors * * Reads the print settings from the group @group_name in @key_file. * * If the file could not be loaded then error is set to either a * `GFileError` or `GKeyFileError`. * * Returns: %TRUE on success */ gboolean gtk_print_settings_load_key_file (GtkPrintSettings *settings, GKeyFile *key_file, const char *group_name, GError **error) { char **keys; gsize n_keys, i; GError *err = NULL; g_return_val_if_fail (GTK_IS_PRINT_SETTINGS (settings), FALSE); g_return_val_if_fail (key_file != NULL, FALSE); if (!group_name) group_name = KEYFILE_GROUP_NAME; keys = g_key_file_get_keys (key_file, group_name, &n_keys, &err); if (err != NULL) { g_propagate_error (error, err); return FALSE; } for (i = 0 ; i < n_keys; ++i) { char *value; value = g_key_file_get_string (key_file, group_name, keys[i], NULL); if (!value) continue; gtk_print_settings_set (settings, keys[i], value); g_free (value); } g_strfreev (keys); return TRUE; } /** * gtk_print_settings_new_from_key_file: * @key_file: the `GKeyFile` to retrieve the settings from * @group_name: (nullable): the name of the group to use, or %NULL to use * the default “Print Settings” * @error: (nullable): return location for errors * * Reads the print settings from the group @group_name in @key_file. * * Returns a new `GtkPrintSettings` object with the restored settings, * or %NULL if an error occurred. If the file could not be loaded then * error is set to either `GFileError` or `GKeyFileError`. * * Returns: the restored `GtkPrintSettings` */ GtkPrintSettings * gtk_print_settings_new_from_key_file (GKeyFile *key_file, const char *group_name, GError **error) { GtkPrintSettings *settings = gtk_print_settings_new (); if (!gtk_print_settings_load_key_file (settings, key_file, group_name, error)) { g_object_unref (settings); settings = NULL; } return settings; } /** * gtk_print_settings_to_file: * @settings: a `GtkPrintSettings` * @file_name: (type filename): the file to save to * @error: (nullable): return location for errors * * This function saves the print settings from @settings to @file_name. * * If the file could not be written then error is set to either a * `GFileError` or `GKeyFileError`. * * Returns: %TRUE on success */ gboolean gtk_print_settings_to_file (GtkPrintSettings *settings, const char *file_name, GError **error) { GKeyFile *key_file; gboolean retval = FALSE; char *data = NULL; gsize len; GError *err = NULL; g_return_val_if_fail (GTK_IS_PRINT_SETTINGS (settings), FALSE); g_return_val_if_fail (file_name != NULL, FALSE); key_file = g_key_file_new (); gtk_print_settings_to_key_file (settings, key_file, NULL); data = g_key_file_to_data (key_file, &len, &err); if (!data) goto out; retval = g_file_set_contents (file_name, data, len, &err); out: if (err != NULL) g_propagate_error (error, err); g_key_file_free (key_file); g_free (data); return retval; } typedef struct { GKeyFile *key_file; const char *group_name; } SettingsData; static void add_value_to_key_file (const char *key, const char *value, SettingsData *data) { g_key_file_set_string (data->key_file, data->group_name, key, value); } /** * gtk_print_settings_to_key_file: * @settings: a `GtkPrintSettings` * @key_file: the `GKeyFile` to save the print settings to * @group_name: (nullable): the group to add the settings to in @key_file, or * %NULL to use the default “Print Settings” * * This function adds the print settings from @settings to @key_file. */ void gtk_print_settings_to_key_file (GtkPrintSettings *settings, GKeyFile *key_file, const char *group_name) { SettingsData data; g_return_if_fail (GTK_IS_PRINT_SETTINGS (settings)); g_return_if_fail (key_file != NULL); if (!group_name) group_name = KEYFILE_GROUP_NAME; data.key_file = key_file; data.group_name = group_name; gtk_print_settings_foreach (settings, (GtkPrintSettingsFunc) add_value_to_key_file, &data); } static void add_to_variant (const char *key, const char *value, gpointer data) { GVariantBuilder *builder = data; g_variant_builder_add (builder, "{sv}", key, g_variant_new_string (value)); } /** * gtk_print_settings_to_gvariant: * @settings: a `GtkPrintSettings` * * Serialize print settings to an a{sv} variant. * * Returns: (transfer none): a new, floating, `GVariant` */ GVariant * gtk_print_settings_to_gvariant (GtkPrintSettings *settings) { GVariantBuilder builder; g_variant_builder_init (&builder, G_VARIANT_TYPE_VARDICT); gtk_print_settings_foreach (settings, add_to_variant, &builder); return g_variant_builder_end (&builder); } /** * gtk_print_settings_new_from_gvariant: * @variant: an a{sv} `GVariant` * * Deserialize print settings from an a{sv} variant. * * The variant must be in the format produced by * [method@Gtk.PrintSettings.to_gvariant]. * * Returns: (transfer full): a new `GtkPrintSettings` object */ GtkPrintSettings * gtk_print_settings_new_from_gvariant (GVariant *variant) { GtkPrintSettings *settings; int i; g_return_val_if_fail (g_variant_is_of_type (variant, G_VARIANT_TYPE_VARDICT), NULL); settings = gtk_print_settings_new (); for (i = 0; i < g_variant_n_children (variant); i++) { const char *key; GVariant *v; g_variant_get_child (variant, i, "{&sv}", &key, &v); if (g_variant_is_of_type (v, G_VARIANT_TYPE_STRING)) gtk_print_settings_set (settings, key, g_variant_get_string (v, NULL)); g_variant_unref (v); } return settings; }