diff options
author | Marc-André Lureau <marcandre.lureau@gmail.com> | 2013-05-17 03:59:36 +0200 |
---|---|---|
committer | Marc-André Lureau <marcandre.lureau@gmail.com> | 2013-05-17 14:15:06 +0200 |
commit | 79255e80d57c2355faa276bc55f559cb84ce328f (patch) | |
tree | d077e676b50c745eca998f4968d865181e92d220 /src/remote-viewer-main.c | |
parent | 93ac885838a2c0cec567a0b5b7e1c37a8264dc5f (diff) | |
download | virt-viewer-79255e80d57c2355faa276bc55f559cb84ce328f.tar.gz virt-viewer-79255e80d57c2355faa276bc55f559cb84ce328f.tar.xz virt-viewer-79255e80d57c2355faa276bc55f559cb84ce328f.zip |
Move connect dialog to remote-viewer.c
Diffstat (limited to 'src/remote-viewer-main.c')
-rw-r--r-- | src/remote-viewer-main.c | 95 |
1 files changed, 2 insertions, 93 deletions
diff --git a/src/remote-viewer-main.c b/src/remote-viewer-main.c index de1544f..ee0025e 100644 --- a/src/remote-viewer-main.c +++ b/src/remote-viewer-main.c @@ -70,94 +70,6 @@ option_fullscreen(G_GNUC_UNUSED const gchar *option_name, return FALSE; } -static void recent_selection_changed_dialog_cb(GtkRecentChooser *chooser, gpointer data) -{ - GtkRecentInfo *info; - GtkWidget *entry = data; - const gchar *uri; - - info = gtk_recent_chooser_get_current_item(chooser); - if (info == NULL) - return; - - uri = gtk_recent_info_get_uri(info); - g_return_if_fail(uri != NULL); - - gtk_entry_set_text(GTK_ENTRY(entry), uri); - - gtk_recent_info_unref(info); -} - -static void recent_item_activated_dialog_cb(GtkRecentChooser *chooser G_GNUC_UNUSED, gpointer data) -{ - gtk_dialog_response (GTK_DIALOG (data), GTK_RESPONSE_ACCEPT); -} - -static gint connect_dialog(gchar **uri) -{ - GtkWidget *dialog, *area, *label, *entry, *recent; - GtkRecentFilter *rfilter; - GtkTable *table; - gint retval; - - /* Create the widgets */ - dialog = gtk_dialog_new_with_buttons(_("Connection details"), - NULL, - GTK_DIALOG_DESTROY_WITH_PARENT, - GTK_STOCK_CANCEL, - GTK_RESPONSE_REJECT, - GTK_STOCK_CONNECT, - GTK_RESPONSE_ACCEPT, - NULL); - gtk_dialog_set_default_response(GTK_DIALOG(dialog), GTK_RESPONSE_ACCEPT); - area = gtk_dialog_get_content_area(GTK_DIALOG(dialog)); - table = GTK_TABLE(gtk_table_new(1, 2, 0)); - gtk_box_pack_start(GTK_BOX(area), GTK_WIDGET(table), TRUE, TRUE, 0); - gtk_table_set_row_spacings(table, 5); - gtk_table_set_col_spacings(table, 5); - - label = gtk_label_new(_("URL:")); - gtk_misc_set_alignment(GTK_MISC(label), 0, 0.5); - gtk_table_attach_defaults(table, label, 0, 1, 0, 1); - entry = GTK_WIDGET(gtk_entry_new()); - gtk_entry_set_activates_default(GTK_ENTRY(entry), TRUE); - g_object_set(entry, "width-request", 200, NULL); - gtk_table_attach_defaults(table, entry, 1, 2, 0, 1); - - label = gtk_label_new(_("Recent connections:")); - gtk_box_pack_start(GTK_BOX(area), label, TRUE, TRUE, 0); - gtk_misc_set_alignment(GTK_MISC(label), 0, 0.5); - - recent = GTK_WIDGET(gtk_recent_chooser_widget_new()); - gtk_recent_chooser_set_show_icons(GTK_RECENT_CHOOSER(recent), FALSE); - gtk_recent_chooser_set_sort_type(GTK_RECENT_CHOOSER(recent), GTK_RECENT_SORT_MRU); - gtk_box_pack_start(GTK_BOX(area), recent, TRUE, TRUE, 0); - - rfilter = gtk_recent_filter_new(); - gtk_recent_filter_add_mime_type(rfilter, "application/x-spice"); - gtk_recent_filter_add_mime_type(rfilter, "application/x-vnc"); - gtk_recent_filter_add_mime_type(rfilter, "application/x-virt-viewer"); - gtk_recent_chooser_set_filter(GTK_RECENT_CHOOSER(recent), rfilter); - gtk_recent_chooser_set_local_only(GTK_RECENT_CHOOSER(recent), FALSE); - g_signal_connect(recent, "selection-changed", - G_CALLBACK(recent_selection_changed_dialog_cb), entry); - g_signal_connect(recent, "item-activated", - G_CALLBACK(recent_item_activated_dialog_cb), dialog); - - /* show and wait for response */ - gtk_widget_show_all(dialog); - if (gtk_dialog_run(GTK_DIALOG(dialog)) == GTK_RESPONSE_ACCEPT) { - *uri = g_strdup(gtk_entry_get_text(GTK_ENTRY(entry))); - retval = 0; - } else { - *uri = NULL; - retval = -1; - } - gtk_widget_destroy(dialog); - - return retval; -} - static void recent_add(gchar *uri, const gchar *mime_type) { @@ -265,13 +177,10 @@ main(int argc, char **argv) } } else #endif - if (!args || g_strv_length(args) == 0) { - if (connect_dialog(&uri) != 0) - goto cleanup; - } else if (g_strv_length(args) > 1) { + if (g_strv_length(args) > 1) { g_printerr(_("Error: can't handle multiple URIs\n")); goto cleanup; - } else { + } else if (g_strv_length(args) == 1) { uri = g_strdup(args[0]); } |