[gtk/gtk-4-6] printdialog: Handle nonexisting files better
- From: Matthias Clasen <matthiasc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk/gtk-4-6] printdialog: Handle nonexisting files better
- Date: Wed, 11 May 2022 20:32:31 +0000 (UTC)
commit f54c1537750e35f7bef365c6b87a65123ab2fa13
Author: Matthias Clasen <mclasen redhat com>
Date: Sat May 7 20:30:55 2022 -0400
printdialog: Handle nonexisting files better
When a non-existing file is selected in the file chooser
for print-to-file, we weren't updating the button label
to show the new filename. Fix that.
Also, use newer file chooser api.
gtk/gtkprinteroptionwidget.c | 46 ++++++++++++++++++++++----------------------
1 file changed, 23 insertions(+), 23 deletions(-)
---
diff --git a/gtk/gtkprinteroptionwidget.c b/gtk/gtkprinteroptionwidget.c
index 9d8aefa480..0ccb6caeda 100644
--- a/gtk/gtkprinteroptionwidget.c
+++ b/gtk/gtkprinteroptionwidget.c
@@ -146,7 +146,7 @@ gtk_printer_option_widget_finalize (GObject *object)
{
GtkPrinterOptionWidget *widget = GTK_PRINTER_OPTION_WIDGET (object);
GtkPrinterOptionWidgetPrivate *priv = widget->priv;
-
+
if (priv->source)
{
g_signal_handler_disconnect (priv->source,
@@ -154,7 +154,7 @@ gtk_printer_option_widget_finalize (GObject *object)
g_object_unref (priv->source);
priv->source = NULL;
}
-
+
G_OBJECT_CLASS (gtk_printer_option_widget_parent_class)->finalize (object);
}
@@ -165,7 +165,7 @@ gtk_printer_option_widget_set_property (GObject *object,
GParamSpec *pspec)
{
GtkPrinterOptionWidget *widget;
-
+
widget = GTK_PRINTER_OPTION_WIDGET (object);
switch (prop_id)
@@ -246,7 +246,7 @@ gtk_printer_option_widget_set_source (GtkPrinterOptionWidget *widget,
if (source)
g_object_ref (source);
-
+
if (priv->source)
{
g_signal_handler_disconnect (priv->source,
@@ -672,6 +672,17 @@ dialog_response_callback (GtkDialog *dialog,
g_free (filename_short);
g_object_unref (info);
}
+ else
+ {
+ const char *path = g_file_peek_path (new_location);
+ char *filename_utf8 = g_utf8_make_valid (path, -1);
+
+ char *filename_short = trim_long_filename (filename_utf8);
+ gtk_button_set_label (GTK_BUTTON (priv->button), filename_short);
+
+ g_free (filename_short);
+ g_free (filename_utf8);
+ }
}
gtk_window_destroy (GTK_WINDOW (dialog));
@@ -719,18 +730,7 @@ filesave_choose_cb (GtkWidget *button,
{
priv->last_location = g_file_new_for_uri (priv->source->value);
if (priv->last_location)
- {
- char *basename;
- char *basename_utf8;
-
- gtk_file_chooser_select_file (GTK_FILE_CHOOSER (dialog), priv->last_location, NULL);
-
- basename = g_file_get_basename (priv->last_location);
- basename_utf8 = g_filename_to_utf8 (basename, -1, NULL, NULL, NULL);
- gtk_file_chooser_set_current_name (GTK_FILE_CHOOSER (dialog), basename_utf8);
- g_free (basename_utf8);
- g_free (basename);
- }
+ gtk_file_chooser_set_file (GTK_FILE_CHOOSER (dialog), priv->last_location, NULL);
}
g_signal_connect (dialog, "response",
@@ -760,7 +760,7 @@ filter_numeric (const char *val,
filtered_val[j] = val[i];
j++;
}
- else if (allow_dec && !dec_set &&
+ else if (allow_dec && !dec_set &&
(val[i] == '.' || val[i] == ','))
{
/* allow one period or comma
@@ -796,7 +796,7 @@ combo_changed_cb (GtkWidget *combo,
gboolean custom = TRUE;
g_signal_handler_block (priv->source, priv->source_changed_handler);
-
+
value = combo_box_get (priv->combo, &custom);
/* Handle constraints if the user entered a custom value. */
@@ -851,7 +851,7 @@ entry_changed_cb (GtkWidget *entry,
{
GtkPrinterOptionWidgetPrivate *priv = widget->priv;
const char *value;
-
+
g_signal_handler_block (priv->source, priv->source_changed_handler);
value = gtk_editable_get_text (GTK_EDITABLE (entry));
if (value)
@@ -867,7 +867,7 @@ radio_changed_cb (GtkWidget *button,
{
GtkPrinterOptionWidgetPrivate *priv = widget->priv;
char *value;
-
+
g_signal_handler_block (priv->source, priv->source_changed_handler);
value = g_object_get_data (G_OBJECT (button), "value");
if (value)
@@ -928,9 +928,9 @@ construct_widgets (GtkPrinterOptionWidget *widget)
GtkWidget *group;
source = priv->source;
-
+
deconstruct_widgets (widget);
-
+
gtk_widget_set_sensitive (GTK_WIDGET (widget), TRUE);
if (source == NULL)
@@ -1112,7 +1112,7 @@ update_widgets (GtkPrinterOptionWidget *widget)
GtkPrinterOption *source;
source = priv->source;
-
+
if (source == NULL)
{
gtk_widget_hide (priv->image);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]