mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-12 05:20:17 +00:00
Parse lpoptions correctly
Parse options job-sheets, job-hold-until and sides correctly.
Add get_lpoption_name() for translation of lpoption names to
gtk option names. Usable for options which values don't need
conversion (e.g. number-up, number-up-layout, job-billing
and job-priority).
Rename array option_names to ppd_option_names to reflect its
purpose better. Rename get_option_name() to get_ppd_option_name()
because of the same reason.
(cherry picked from commit 95e69afea8
)
This commit is contained in:
parent
d942045c10
commit
5045337162
@ -2558,6 +2558,13 @@ dialog_get_number_up_layout (GtkPrintUnixDialog *dialog)
|
|||||||
if (val == NULL)
|
if (val == NULL)
|
||||||
return layout;
|
return layout;
|
||||||
|
|
||||||
|
if (val[0] == '\0' && priv->options)
|
||||||
|
{
|
||||||
|
GtkPrinterOption *option = gtk_printer_option_set_lookup (priv->options, "gtk-n-up-layout");
|
||||||
|
if (option)
|
||||||
|
val = option->value;
|
||||||
|
}
|
||||||
|
|
||||||
enum_class = g_type_class_ref (GTK_TYPE_NUMBER_UP_LAYOUT);
|
enum_class = g_type_class_ref (GTK_TYPE_NUMBER_UP_LAYOUT);
|
||||||
enum_value = g_enum_get_value_by_nick (enum_class, val);
|
enum_value = g_enum_get_value_by_nick (enum_class, val);
|
||||||
if (enum_value)
|
if (enum_value)
|
||||||
|
@ -2829,13 +2829,23 @@ static const struct {
|
|||||||
static const struct {
|
static const struct {
|
||||||
const char *ppd_keyword;
|
const char *ppd_keyword;
|
||||||
const char *name;
|
const char *name;
|
||||||
} option_names[] = {
|
} ppd_option_names[] = {
|
||||||
{"Duplex", "gtk-duplex" },
|
{"Duplex", "gtk-duplex" },
|
||||||
{"MediaType", "gtk-paper-type"},
|
{"MediaType", "gtk-paper-type"},
|
||||||
{"InputSlot", "gtk-paper-source"},
|
{"InputSlot", "gtk-paper-source"},
|
||||||
{"OutputBin", "gtk-output-tray"},
|
{"OutputBin", "gtk-output-tray"},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static const struct {
|
||||||
|
const char *lpoption;
|
||||||
|
const char *name;
|
||||||
|
} lpoption_names[] = {
|
||||||
|
{"number-up", "gtk-n-up" },
|
||||||
|
{"number-up-layout", "gtk-n-up-layout"},
|
||||||
|
{"job-billing", "gtk-billing-info"},
|
||||||
|
{"job-priority", "gtk-job-prio"},
|
||||||
|
};
|
||||||
|
|
||||||
/* keep sorted when changing */
|
/* keep sorted when changing */
|
||||||
static const char *color_option_whitelist[] = {
|
static const char *color_option_whitelist[] = {
|
||||||
"BRColorEnhancement",
|
"BRColorEnhancement",
|
||||||
@ -3351,17 +3361,33 @@ create_boolean_option (ppd_file_t *ppd_file,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static gchar *
|
static gchar *
|
||||||
get_option_name (const gchar *keyword)
|
get_ppd_option_name (const gchar *keyword)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < G_N_ELEMENTS (option_names); i++)
|
for (i = 0; i < G_N_ELEMENTS (ppd_option_names); i++)
|
||||||
if (strcmp (option_names[i].ppd_keyword, keyword) == 0)
|
if (strcmp (ppd_option_names[i].ppd_keyword, keyword) == 0)
|
||||||
return g_strdup (option_names[i].name);
|
return g_strdup (ppd_option_names[i].name);
|
||||||
|
|
||||||
return g_strdup_printf ("cups-%s", keyword);
|
return g_strdup_printf ("cups-%s", keyword);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gchar *
|
||||||
|
get_lpoption_name (const gchar *lpoption)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
for (i = 0; i < G_N_ELEMENTS (ppd_option_names); i++)
|
||||||
|
if (strcmp (ppd_option_names[i].ppd_keyword, lpoption) == 0)
|
||||||
|
return g_strdup (ppd_option_names[i].name);
|
||||||
|
|
||||||
|
for (i = 0; i < G_N_ELEMENTS (lpoption_names); i++)
|
||||||
|
if (strcmp (lpoption_names[i].lpoption, lpoption) == 0)
|
||||||
|
return g_strdup (lpoption_names[i].name);
|
||||||
|
|
||||||
|
return g_strdup_printf ("cups-%s", lpoption);
|
||||||
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
strptr_cmp (const void *a,
|
strptr_cmp (const void *a,
|
||||||
const void *b)
|
const void *b)
|
||||||
@ -3396,7 +3422,7 @@ handle_option (GtkPrinterOptionSet *set,
|
|||||||
if (STRING_IN_TABLE (ppd_option->keyword, cups_option_blacklist))
|
if (STRING_IN_TABLE (ppd_option->keyword, cups_option_blacklist))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
name = get_option_name (ppd_option->keyword);
|
name = get_ppd_option_name (ppd_option->keyword);
|
||||||
|
|
||||||
option = NULL;
|
option = NULL;
|
||||||
if (ppd_option->ui == PPD_UI_PICKONE)
|
if (ppd_option->ui == PPD_UI_PICKONE)
|
||||||
@ -3720,10 +3746,62 @@ cups_printer_get_options (GtkPrinter *printer,
|
|||||||
if (STRING_IN_TABLE (opts[i].name, cups_option_blacklist))
|
if (STRING_IN_TABLE (opts[i].name, cups_option_blacklist))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
name = get_option_name (opts[i].name);
|
name = get_lpoption_name (opts[i].name);
|
||||||
option = gtk_printer_option_set_lookup (set, name);
|
if (strcmp (name, "cups-job-sheets") == 0)
|
||||||
if (option)
|
{
|
||||||
gtk_printer_option_set (option, opts[i].value);
|
gchar **values;
|
||||||
|
gint num_values;
|
||||||
|
|
||||||
|
values = g_strsplit (opts[i].value, ",", 2);
|
||||||
|
num_values = g_strv_length (values);
|
||||||
|
|
||||||
|
option = gtk_printer_option_set_lookup (set, "gtk-cover-before");
|
||||||
|
if (option && num_values > 0)
|
||||||
|
gtk_printer_option_set (option, g_strstrip (values[0]));
|
||||||
|
|
||||||
|
option = gtk_printer_option_set_lookup (set, "gtk-cover-after");
|
||||||
|
if (option && num_values > 1)
|
||||||
|
gtk_printer_option_set (option, g_strstrip (values[1]));
|
||||||
|
|
||||||
|
g_strfreev (values);
|
||||||
|
}
|
||||||
|
else if (strcmp (name, "cups-job-hold-until") == 0)
|
||||||
|
{
|
||||||
|
GtkPrinterOption *option2 = NULL;
|
||||||
|
|
||||||
|
option = gtk_printer_option_set_lookup (set, "gtk-print-time-text");
|
||||||
|
if (option && opts[i].value)
|
||||||
|
{
|
||||||
|
option2 = gtk_printer_option_set_lookup (set, "gtk-print-time");
|
||||||
|
if (option2)
|
||||||
|
{
|
||||||
|
if (strcmp (opts[i].value, "indefinite") == 0)
|
||||||
|
gtk_printer_option_set (option2, "on-hold");
|
||||||
|
else
|
||||||
|
{
|
||||||
|
gtk_printer_option_set (option2, "at");
|
||||||
|
gtk_printer_option_set (option, opts[i].value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (strcmp (name, "cups-sides") == 0)
|
||||||
|
{
|
||||||
|
option = gtk_printer_option_set_lookup (set, "gtk-duplex");
|
||||||
|
if (option && opts[i].value)
|
||||||
|
{
|
||||||
|
if (strcmp (opts[i].value, "two-sided-short-edge") == 0)
|
||||||
|
gtk_printer_option_set (option, "DuplexTumble");
|
||||||
|
else if (strcmp (opts[i].value, "two-sided-long-edge") == 0)
|
||||||
|
gtk_printer_option_set (option, "DuplexNoTumble");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
option = gtk_printer_option_set_lookup (set, name);
|
||||||
|
if (option)
|
||||||
|
gtk_printer_option_set (option, opts[i].value);
|
||||||
|
}
|
||||||
g_free (name);
|
g_free (name);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3739,7 +3817,7 @@ mark_option_from_set (GtkPrinterOptionSet *set,
|
|||||||
ppd_option_t *ppd_option)
|
ppd_option_t *ppd_option)
|
||||||
{
|
{
|
||||||
GtkPrinterOption *option;
|
GtkPrinterOption *option;
|
||||||
char *name = get_option_name (ppd_option->keyword);
|
char *name = get_ppd_option_name (ppd_option->keyword);
|
||||||
|
|
||||||
option = gtk_printer_option_set_lookup (set, name);
|
option = gtk_printer_option_set_lookup (set, name);
|
||||||
|
|
||||||
@ -3774,7 +3852,7 @@ set_conflicts_from_option (GtkPrinterOptionSet *set,
|
|||||||
|
|
||||||
if (ppd_option->conflicted)
|
if (ppd_option->conflicted)
|
||||||
{
|
{
|
||||||
name = get_option_name (ppd_option->keyword);
|
name = get_ppd_option_name (ppd_option->keyword);
|
||||||
option = gtk_printer_option_set_lookup (set, name);
|
option = gtk_printer_option_set_lookup (set, name);
|
||||||
|
|
||||||
if (option)
|
if (option)
|
||||||
|
Loading…
Reference in New Issue
Block a user