2 * $Id: gui.h,v 1.3 2007-10-31 11:53:35 nkeynes Exp $
4 * Public GUI declarations (used from elsewhere in the system)
6 * Copyright (c) 2005 Nathan Keynes.
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
19 #ifndef __lxdream_gui_H
20 #define __lxdream_gui_H
22 #include <glib/gtypes.h>
25 * GUI-provided method to scan the command line for standard arguments,
26 * invoked prior to regular command line processing. The command line
27 * is modified to remove any arguments handled by the UI.
28 * @return TRUE on success, FALSE on failure.
30 gboolean gui_parse_cmdline( int *argc, char **argv[] );
33 * Initialize the GUI system and create any windows needed. This method
34 * should also register the GUI module with the module manager (if the
37 * @param debug TRUE if the system should start in debugging mode.
39 gboolean gui_init( gboolean debug );
42 * Enter the GUI main loop. If this method ever returns, the system will
45 void gui_main_loop(void);
47 gboolean gui_error_dialog( const char *fmt, ... );
49 typedef enum { IO_IDE, IO_NETWORK } io_activity_type;
52 * Notify the GUI of I/O activity.
53 * @param activity the type of IO activity being reported.
54 * @param active TRUE if the I/O device is becoming active, FALSE if inactive.
56 void gui_update_io_activity( io_activity_type activity, gboolean active );
59 * Open a gdrom filename via the menu. FIXME: Should be generic
61 gboolean gdrom_menu_open_file( const char *filename );
63 #endif /* __lxdream_gui_H */
.