#include <string.h>
#include <setjmp.h>
#include <unistd.h>
+
+#ifdef HAVE_GNOME
#include <libgnome/gnome-program.h>
#include <libgnomeui/gnome-ui-init.h>
+#endif
#include "main.h" /* self */
-#include "ui-gnome.h"
#include "ui-line.h"
#include "network.h"
+#include "configuration.h"
+
+#ifdef HAVE_GNOME
+#include "ui-gnome.h"
+#endif
/* Config: */
argDescrip: (argDescripP), \
}
+#ifdef HAVE_GNOME
+#define OPT_TEXT_IF_GNOME N_("Disable Gnome UI; --text must be first argument")
+#else /* HAVE_GNOME */
+#define OPT_TEXT_IF_GNOME N_("(no Gnome UI compiled - stub only); --text must be first argument")
+#endif /* HAVE_GNOME */
UDPGATE_POPT(0 ,"text" ,POPT_ARG_NONE ,&optarg_text ,0,
- N_("Disable Gnome UI; --text must be first argument"),NULL),
+ OPT_TEXT_IF_GNOME,NULL),
+#undef OPT_TEXT_IF_GNOME
UDPGATE_POPT('v',"verbose",POPT_ARG_NONE ,&optarg_verbose,0,
N_("Display additional debug information"),NULL),
UDPGATE_POPT('p',"port" ,POPT_ARG_INT |POPT_ARGFLAG_SHOW_DEFAULT,&optarg_port ,0,
};
+#ifdef HAVE_GNOME
static jmp_buf gnome_init_atexit_jmpbuf;
static gboolean gnome_init_atexit_disable;
gnome_init_g_log_handler_hit=TRUE;
g_log_default_handler(log_domain,log_level,message,user_data);
}
+#endif /* HAVE_GNOME */
int main(int argc,char **argv)
{
poptContext context;
int errint;
gboolean is_interactive;
+#ifdef HAVE_GNOME
gboolean no_gnome;
+#endif /* HAVE_GNOME */
#if 0
g_log_set_always_fatal(~(0
bindtextdomain(PACKAGE,LOCALEDIR);
textdomain(PACKAGE);
+ /* Read it before the command-line parsing to get the default value
+ * of 'optarg_port' displayable by 'POPT_ARGFLAG_SHOW_DEFAULT'.
+ */
+ configuration_read();
+
if (argv[1] && !strcmp(argv[1],"--text"))
optarg_text=1;
+#ifdef HAVE_GNOME
no_gnome=(optarg_text || !getenv("DISPLAY") || !*getenv("DISPLAY"));
- if (no_gnome) {
+ if (no_gnome)
+#endif /* HAVE_GNOME */
+ {
context=poptGetContext(
PACKAGE, /* name */
argc,(/*en-const*/const char **)argv, /* argc,argv */
return EXIT_FAILURE;
}
errint=poptGetNextOpt(context);
- if (errint!=-1) {
- g_assert_not_reached(); /* some non-callbacked argument reached */
- return EXIT_FAILURE;
- }
- if (poptPeekArg(context)) {
+ if (errint!=-1)
+ g_error(_("Specified option not expected"));
+ if (poptPeekArg(context))
g_error(_("No arguments expected"));
- return EXIT_FAILURE;
- }
}
+#ifdef HAVE_GNOME
else {
GnomeProgram *gnome_program;
guint handler_id;
NULL);
else {
no_gnome=TRUE;
- /* No message: (captive-install-acquire:3693): Gtk-WARNING **: cannot open display:
+ /* No message: (udpgate:3693): Gtk-WARNING **: cannot open display:
* was reported, probably only '--help' message was shown.
*/
if (!gnome_init_g_log_handler_hit)
"Gtk", /* log_domain */
handler_id); /* handler_id */
}
+#endif /* HAVE_GNOME */
is_interactive=(1
&& !optarg_start
/* Initialize UI here to catch all GLog errors below. */
if (is_interactive
+#ifdef HAVE_GNOME
&& (no_gnome || !ui_gnome_init())
+#endif /* HAVE_GNOME */
&& !ui_line_init())
g_error(_("No UI interface could be initialized"));
else
(*ui_interactive)();
+ configuration_write();
+
return EXIT_SUCCESS;
}