aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--ChangeLog4
-rw-r--r--shell/main.c70
2 files changed, 40 insertions, 34 deletions
diff --git a/ChangeLog b/ChangeLog
index 7dc056bef2..fa0ca7b4e8 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+2006-04-19 Philip Van Hoof <pvanhoof@gnome.org>
+
+ * shell/main.c: Replaced popt with GOption API
+
2006-04-17 Kjartan Maraas <kmaraas@gnome.org>
* configure.in: Remove obsolete entry for no_NO.
diff --git a/shell/main.c b/shell/main.c
index fae54d01fe..2937f10e86 100644
--- a/shell/main.c
+++ b/shell/main.c
@@ -103,6 +103,7 @@ static gint idle_cb (void *data);
static char *default_component_id = NULL;
static char *evolution_debug_log = NULL;
+static gchar **remaining_args;
static void
no_windows_left_cb (EShell *shell, gpointer data)
@@ -460,44 +461,45 @@ setup_segv_redirect (void)
#define setup_segv_redirect() 0
#endif
+static const GOptionEntry options[] = {
+ { "component", 'c', 0, G_OPTION_ARG_STRING, &default_component_id,
+ N_("Start Evolution activating the specified component"), NULL },
+ { "offline", '\0', 0, G_OPTION_ARG_NONE, &start_offline,
+ N_("Start in offline mode"), NULL },
+ { "online", '\0', 0, G_OPTION_ARG_NONE, &start_online,
+ N_("Start in online mode"), NULL },
+#ifdef KILL_PROCESS_CMD
+ { "force-shutdown", '\0', 0, G_OPTION_ARG_NONE, &killev,
+ N_("Forcibly shut down all Evolution components"), NULL },
+#endif
+#if DEVELOPMENT
+ { "force-migrate", '\0', 0, G_OPTION_ARG_NONE, &force_migrate,
+ N_("Forcibly re-migrate from Evolution 1.4"), NULL },
+#endif
+ { "debug", '\0', 0, G_OPTION_ARG_STRING, &evolution_debug_log,
+ N_("Send the debugging output of all components to a file."), NULL },
+ { "disable-eplugin", '\0', 0, G_OPTION_ARG_NONE, &disable_eplugin,
+ N_("Disable loading of any plugins."), NULL },
+ { "setup-only", '\0', G_OPTION_FLAG_HIDDEN, G_OPTION_ARG_NONE,
+ &setup_only, NULL, NULL },
+ { G_OPTION_REMAINING, 0, 0, G_OPTION_ARG_STRING_ARRAY, &remaining_args, NULL, NULL },
+ { NULL }
+};
+
int
main (int argc, char **argv)
{
#ifdef G_OS_WIN32
extern void link_shutdown (void);
#endif
- struct poptOption options[] = {
- { "component", 'c', POPT_ARG_STRING, &default_component_id, 0,
- N_("Start Evolution activating the specified component"), NULL },
- { "offline", '\0', POPT_ARG_NONE, &start_offline, 0,
- N_("Start in offline mode"), NULL },
- { "online", '\0', POPT_ARG_NONE, &start_online, 0,
- N_("Start in online mode"), NULL },
-#ifdef KILL_PROCESS_CMD
- { "force-shutdown", '\0', POPT_ARG_NONE, &killev, 0,
- N_("Forcibly shut down all Evolution components"), NULL },
-#endif
-#if DEVELOPMENT
- { "force-migrate", '\0', POPT_ARG_NONE, &force_migrate, 0,
- N_("Forcibly re-migrate from Evolution 1.4"), NULL },
-#endif
- { "debug", '\0', POPT_ARG_STRING, &evolution_debug_log, 0,
- N_("Send the debugging output of all components to a file."), NULL },
- { "disable-eplugin", '\0', POPT_ARG_NONE, &disable_eplugin, 0,
- N_("Disable loading of any plugins."), NULL },
- { "setup-only", '\0', POPT_ARG_NONE | POPT_ARGFLAG_DOC_HIDDEN,
- &setup_only, 0, NULL, NULL },
- { NULL, '\0', 0, NULL, 0, NULL, NULL }
- };
+
#if DEVELOPMENT
GConfClient *client;
gboolean skip_warning_dialog;
#endif
GSList *uri_list;
- GValue popt_context_value = { 0, };
GnomeProgram *program;
- poptContext popt_context;
- const char **args;
+ GOptionContext *context;
GList *icon_list;
char *filename;
@@ -508,9 +510,13 @@ main (int argc, char **argv)
bind_textdomain_codeset (GETTEXT_PACKAGE, "UTF-8");
textdomain (GETTEXT_PACKAGE);
+ context = g_option_context_new (_("- The Evolution PIM and Email Client"));
+
+ g_option_context_add_main_entries (context, options, GETTEXT_PACKAGE);
+
program = gnome_program_init (PACKAGE "-" BASE_VERSION, VERSION, LIBGNOMEUI_MODULE, argc, argv,
GNOME_PROGRAM_STANDARD_PROPERTIES,
- GNOME_PARAM_POPT_TABLE, options,
+ GNOME_PARAM_GOPTION_CONTEXT, context,
GNOME_PARAM_HUMAN_READABLE_NAME, _("Evolution"),
NULL);
@@ -570,18 +576,14 @@ main (int argc, char **argv)
uri_list = NULL;
- g_value_init (&popt_context_value, G_TYPE_POINTER);
- g_object_get_property (G_OBJECT (program), GNOME_PARAM_POPT_CONTEXT, &popt_context_value);
- popt_context = g_value_get_pointer (&popt_context_value);
- args = poptGetArgs (popt_context);
- if (args != NULL) {
+ if (remaining_args != NULL) {
const char **p;
- for (p = args; *p != NULL; p++)
+ for (p = (const char**)remaining_args; *p != NULL; p++)
uri_list = g_slist_prepend (uri_list, (char *) *p);
}
uri_list = g_slist_reverse (uri_list);
- g_value_unset (&popt_context_value);
+
gnome_sound_init ("localhost");