summaryrefslogtreecommitdiff
path: root/gtk/window.c
diff options
context:
space:
mode:
authorDaniel Silverstone <dsilvers@digital-scurf.org>2014-01-05 17:03:17 +0000
committerDaniel Silverstone <dsilvers@digital-scurf.org>2014-01-05 17:03:17 +0000
commit9a9cb399f9fc5503cf64a906d44ec016564d06bb (patch)
tree3eafe6402d08b56ae7d616c79fdf5b9664bea8a4 /gtk/window.c
parent0d5960a68cc031758dd17edf7e83c342c13ea144 (diff)
parentef5c516ee372d29ca636fa0f7bd422c312be0acf (diff)
downloadnetsurf-9a9cb399f9fc5503cf64a906d44ec016564d06bb.tar.gz
netsurf-9a9cb399f9fc5503cf64a906d44ec016564d06bb.tar.bz2
Merge branch 'rjek/click-file-gadget'
Diffstat (limited to 'gtk/window.c')
-rw-r--r--gtk/window.c32
1 files changed, 32 insertions, 0 deletions
diff --git a/gtk/window.c b/gtk/window.c
index 8f449ced2..8f05c3799 100644
--- a/gtk/window.c
+++ b/gtk/window.c
@@ -1162,3 +1162,35 @@ void gui_window_get_dimensions(struct gui_window *g, int *width, int *height,
LOG(("width: %i", *width));
LOG(("height: %i", *height));
}
+
+void gui_file_gadget_open(struct gui_window *g, hlcache_handle *hl,
+ struct form_control *gadget)
+{
+ GtkWidget *dialog;
+
+ LOG(("Awooga."));
+
+ dialog = gtk_file_chooser_dialog_new("Select File",
+ nsgtk_scaffolding_window(g->scaffold),
+ GTK_FILE_CHOOSER_ACTION_OPEN,
+ GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL,
+ GTK_STOCK_OPEN, GTK_RESPONSE_ACCEPT,
+ NULL);
+
+ LOG(("*** open dialog: %p", dialog));
+
+ int ret = gtk_dialog_run(GTK_DIALOG(dialog));
+ LOG(("*** return value: %d", ret));
+ if (ret == GTK_RESPONSE_ACCEPT) {
+ char *filename;
+
+ filename = gtk_file_chooser_get_filename(
+ GTK_FILE_CHOOSER(dialog));
+
+ browser_window_set_gadget_filename(g->bw, gadget, filename);
+
+ g_free(filename);
+ }
+
+ gtk_widget_destroy(dialog);
+}