Hello community, here is the log from the commit of package vinagre for openSUSE:12.2 checked in at 2012-07-25 10:46:30 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ Comparing /work/SRC/openSUSE:12.2/vinagre (Old) and /work/SRC/openSUSE:12.2/.vinagre.new (New) ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ Package is "vinagre", Maintainer is "gnome-maintainers@suse.de" Changes: -------- --- /work/SRC/openSUSE:12.2/vinagre/vinagre.changes 2012-06-25 15:57:06.000000000 +0200 +++ /work/SRC/openSUSE:12.2/.vinagre.new/vinagre.changes 2012-07-25 10:46:31.000000000 +0200 @@ -1,0 +2,6 @@ +Mon Jul 23 07:26:34 UTC 2012 - dimstar@opensuse.org + +- Add vinagre-cmdline-parsing.patch: Fix up handling of commandline + options (bnc#722709, bgo#662586) + +------------------------------------------------------------------- New: ---- vinagre-cmdline-parsing.patch ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ Other differences: ------------------ ++++++ vinagre.spec ++++++ --- /var/tmp/diff_new_pack.rPZxns/_old 2012-07-25 10:46:31.000000000 +0200 +++ /var/tmp/diff_new_pack.rPZxns/_new 2012-07-25 10:46:31.000000000 +0200 @@ -24,6 +24,8 @@ Release: 0 Url: http://www.gnome.org/projects/vinagre/ Source0: http://download.gnome.org/sources/vinagre/3.4/%{name}-%{version}.tar.xz +# PATCH-FIX-UPSTREAM vinagre-cmdline-parsing.patch bnc#722709 bgo#662586 dimstar@opensuse.org -- Fix up handling of commandline options +Patch0: vinagre-cmdline-parsing.patch BuildRequires: fdupes BuildRequires: gcc-c++ BuildRequires: gdbm-devel @@ -62,6 +64,7 @@ %lang_package %prep %setup -q +%patch0 -p1 translation-update-upstream %build ++++++ vinagre-cmdline-parsing.patch ++++++
From 5140ed1571dc38199469874f1012190fdc6a9c44 Mon Sep 17 00:00:00 2001 From: Matthias Clasen <mclasen@redhat.com> Date: Sun, 22 Jul 2012 22:32:44 -0400 Subject: [PATCH] Fix up handling of commandline options
The handling of commandlines in the primary instance was not really working at all. Fix things up by creating a new GOptionContext for each instance, and do the extra work to send --help output back to the remote instance. Also return a nonzero exit status when commandline parsing fails. https://bugzilla.gnome.org/show_bug.cgi?id=662586 --- vinagre/vinagre-main.c | 86 +++++++++++++++++++++++++++++++++-------------- vinagre/vinagre-options.c | 5 ++- vinagre/vinagre-options.h | 1 + 3 files changed, 65 insertions(+), 27 deletions(-) diff --git a/vinagre/vinagre-main.c b/vinagre/vinagre-main.c index e3d8994..9e66b72 100644 --- a/vinagre/vinagre-main.c +++ b/vinagre/vinagre-main.c @@ -44,7 +44,6 @@ static gboolean startup_called = FALSE; static GtkWindow *window = NULL; -static GOptionContext *context = NULL; #ifdef VINAGRE_HAVE_TELEPATHY_GLIB static VinagreTubesManager *vinagre_tubes_manager = NULL; @@ -80,6 +79,37 @@ app_startup (GApplication *app, startup_called = TRUE; } +static GOptionContext * +get_option_context (void) +{ + GOptionContext *context; + VinagreProtocol *extension; + GHashTable *extensions; + GHashTableIter iter; + + /* Setup command line options */ + context = g_option_context_new (_("- Remote Desktop Viewer")); + g_option_context_set_help_enabled (context, FALSE); + g_option_context_add_main_entries (context, all_options, GETTEXT_PACKAGE); + g_option_context_set_translation_domain (context, GETTEXT_PACKAGE); + g_option_context_add_group (context, gtk_get_option_group (TRUE)); + + extensions = vinagre_plugins_engine_get_plugins_by_protocol (vinagre_plugins_engine_get_default ()); + + g_hash_table_iter_init (&iter, extensions); + while (g_hash_table_iter_next (&iter, NULL, (gpointer *)&extension)) + { + GSList *groups, *l; + + groups = vinagre_protocol_get_context_groups (extension); + for (l = groups; l; l = l->next) + g_option_context_add_group (context, (GOptionGroup *)l->data); + g_slist_free (groups); + } + + return context; +} + static int app_command_line (GApplication *app, GApplicationCommandLine *command_line, @@ -88,10 +118,32 @@ app_command_line (GApplication *app, GError *error = NULL; int argc; char **argv; + GOptionContext *context; + int ret; + + ret = 0; + + context = get_option_context (); argv = g_application_command_line_get_arguments (command_line, &argc); - g_option_context_parse (context, &argc, &argv, &error); + optionstate.help = FALSE; + + if (!g_option_context_parse (context, &argc, &argv, &error)) + { + g_application_command_line_printerr (command_line, "%s\n", error->message); + g_error_free (error); + ret = 1; + goto out; + } + else if (optionstate.help) + { + gchar *text; + text = g_option_context_get_help (context, FALSE, NULL); + g_application_command_line_print (command_line, "%s", text); + g_free (text); + goto out; + } /* Don't create another window if we're remote. * We can't use g_application_get_is_remote() because it's not registered yet */ @@ -107,15 +159,16 @@ app_command_line (GApplication *app, vinagre_options_process_command_line (GTK_APPLICATION (app), window, &optionstate); +out: g_strfreev (argv); - return 0; + + g_option_context_free (context); + + return ret; } int main (int argc, char **argv) { GtkApplication *app; - VinagreProtocol *extension; - GHashTable *extensions; - GHashTableIter iter; int res; /* i18n */ @@ -129,25 +182,6 @@ int main (int argc, char **argv) { g_set_application_name (_("Remote Desktop Viewer")); optionstate.new_window = FALSE; - /* Setup command line options */ - context = g_option_context_new (_("- Remote Desktop Viewer")); - g_option_context_add_main_entries (context, all_options, GETTEXT_PACKAGE); - g_option_context_set_translation_domain(context, GETTEXT_PACKAGE); - g_option_context_add_group (context, gtk_get_option_group (TRUE)); - - extensions = vinagre_plugins_engine_get_plugins_by_protocol (vinagre_plugins_engine_get_default ()); - - g_hash_table_iter_init (&iter, extensions); - while (g_hash_table_iter_next (&iter, NULL, (gpointer *)&extension)) - { - GSList *groups, *l; - - groups = vinagre_protocol_get_context_groups (extension); - for (l = groups; l; l = l->next) - g_option_context_add_group (context, (GOptionGroup *)l->data); - g_slist_free (groups); - } - app = gtk_application_new ("org.gnome.vinagre", G_APPLICATION_HANDLES_COMMAND_LINE); /* https://bugzilla.gnome.org/show_bug.cgi?id=634990 */ /* g_application_set_option_context (G_APPLICATION (app), context); */ @@ -164,6 +198,7 @@ int main (int argc, char **argv) { if (res == 0) { #ifdef VINAGRE_HAVE_TELEPATHY_GLIB + if (vinagre_tubes_manager != NULL) g_object_unref (vinagre_tubes_manager); #endif @@ -177,7 +212,6 @@ int main (int argc, char **argv) { } g_object_unref (app); - g_option_context_free (context); return res; } diff --git a/vinagre/vinagre-options.c b/vinagre/vinagre-options.c index 67a27af..42604ac 100644 --- a/vinagre/vinagre-options.c +++ b/vinagre/vinagre-options.c @@ -44,7 +44,10 @@ const GOptionEntry all_options [] = /* Translators: this is a command line option (run vinagre --help) */ N_("Open a file recognized by Vinagre"), N_("filename")}, - { + { "help", '?', 0, G_OPTION_ARG_NONE, &optionstate.help, + N_("Show help"), NULL}, + + { G_OPTION_REMAINING, '\0', 0, G_OPTION_ARG_STRING_ARRAY, &optionstate.uris, /* Translators: this is a command line option (run vinagre --help) */ NULL, N_("[server:port]") }, diff --git a/vinagre/vinagre-options.h b/vinagre/vinagre-options.h index 5a858f6..c350d80 100644 --- a/vinagre/vinagre-options.h +++ b/vinagre/vinagre-options.h @@ -30,6 +30,7 @@ typedef struct { gboolean new_window; gboolean fullscreen; gchar *geometry; + gboolean help; } VinagreCmdLineOptions; extern const GOptionEntry all_options[]; -- 1.7.11.2 -- To unsubscribe, e-mail: opensuse-commit+unsubscribe@opensuse.org For additional commands, e-mail: opensuse-commit+help@opensuse.org