Search
lxdream.org :: lxdream/src/gui.h
lxdream 0.9.1
released Jun 29
Download Now
filename src/gui.h
changeset 736:a02d1475ccfd
prev681:1755a126b109
next839:51f1c4195790
author nkeynes
date Fri Jul 18 11:08:30 2008 +0000 (15 years ago)
permissions -rw-r--r--
last change Fix old copy-n-paste error in INFO line
file annotate diff log raw
nkeynes@435
     1
/**
nkeynes@561
     2
 * $Id$
nkeynes@435
     3
 *
nkeynes@435
     4
 * Public GUI declarations (used from elsewhere in the system)
nkeynes@435
     5
 *
nkeynes@435
     6
 * Copyright (c) 2005 Nathan Keynes.
nkeynes@435
     7
 *
nkeynes@435
     8
 * This program is free software; you can redistribute it and/or modify
nkeynes@435
     9
 * it under the terms of the GNU General Public License as published by
nkeynes@435
    10
 * the Free Software Foundation; either version 2 of the License, or
nkeynes@435
    11
 * (at your option) any later version.
nkeynes@435
    12
 *
nkeynes@435
    13
 * This program is distributed in the hope that it will be useful,
nkeynes@435
    14
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
nkeynes@435
    15
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
nkeynes@435
    16
 * GNU General Public License for more details.
nkeynes@435
    17
 */
nkeynes@435
    18
nkeynes@736
    19
#ifndef lxdream_gui_H
nkeynes@736
    20
#define lxdream_gui_H
nkeynes@435
    21
nkeynes@435
    22
#include <glib/gtypes.h>
nkeynes@435
    23
nkeynes@736
    24
#ifdef __cplusplus
nkeynes@736
    25
extern "C" {
nkeynes@736
    26
#endif
nkeynes@736
    27
nkeynes@678
    28
/* Base GUI clock is 10ms */
nkeynes@678
    29
#define GUI_TICK_PERIOD 10000000
nkeynes@678
    30
nkeynes@435
    31
/**
nkeynes@435
    32
 * GUI-provided method to scan the command line for standard arguments,
nkeynes@435
    33
 * invoked prior to regular command line processing. The command line
nkeynes@435
    34
 * is modified to remove any arguments handled by the UI.
nkeynes@435
    35
 * @return TRUE on success, FALSE on failure.
nkeynes@435
    36
 */
nkeynes@435
    37
gboolean gui_parse_cmdline( int *argc, char **argv[] );
nkeynes@435
    38
nkeynes@435
    39
/**
nkeynes@435
    40
 * Initialize the GUI system and create any windows needed. This method
nkeynes@435
    41
 * should also register the GUI module with the module manager (if the
nkeynes@435
    42
 * GUI has one).
nkeynes@435
    43
 *
nkeynes@435
    44
 * @param debug TRUE if the system should start in debugging mode.
nkeynes@435
    45
 */
nkeynes@435
    46
gboolean gui_init( gboolean debug );
nkeynes@435
    47
nkeynes@435
    48
/**
nkeynes@435
    49
 * Enter the GUI main loop. If this method ever returns, the system will
nkeynes@435
    50
 * exit normally.
nkeynes@681
    51
 * 
nkeynes@681
    52
 * @param run TRUE if the system should start running immediately, otherwise
nkeynes@435
    53
 */
nkeynes@681
    54
void gui_main_loop( gboolean run );
nkeynes@435
    55
nkeynes@447
    56
gboolean gui_error_dialog( const char *fmt, ... );
nkeynes@447
    57
nkeynes@435
    58
typedef enum { IO_IDE, IO_NETWORK } io_activity_type;
nkeynes@435
    59
nkeynes@435
    60
/**
nkeynes@545
    61
 * Notify the GUI of state changes (eg binary was loaded and PC changed)
nkeynes@545
    62
 */
nkeynes@545
    63
void gui_update_state();
nkeynes@545
    64
nkeynes@545
    65
/**
nkeynes@435
    66
 * Notify the GUI of I/O activity. 
nkeynes@435
    67
 * @param activity the type of IO activity being reported.
nkeynes@435
    68
 * @param active TRUE if the I/O device is becoming active, FALSE if inactive.
nkeynes@435
    69
 */
nkeynes@435
    70
void gui_update_io_activity( io_activity_type activity, gboolean active );
nkeynes@435
    71
nkeynes@736
    72
#ifdef __cplusplus
nkeynes@736
    73
}
nkeynes@736
    74
#endif
nkeynes@736
    75
nkeynes@736
    76
#endif /* lxdream_gui_H */
.