1 /*****************************************************************************
2 * interface.h: interface access for other threads
3 * This library provides basic functions for threads to interact with user
4 * interface, such as message output.
5 *****************************************************************************
6 * Copyright (C) 1999, 2000 VideoLAN
7 * $Id: interface.h,v 1.27 2002/02/19 00:50:18 sam Exp $
9 * Authors: Vincent Seguin <seguin@via.ecp.fr>
11 * This program is free software; you can redistribute it and/or modify
12 * it under the terms of the GNU General Public License as published by
13 * the Free Software Foundation; either version 2 of the License, or
14 * (at your option) any later version.
16 * This program is distributed in the hope that it will be useful,
17 * but WITHOUT ANY WARRANTY; without even the implied warranty of
18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 * GNU General Public License for more details.
21 * You should have received a copy of the GNU General Public License
22 * along with this program; if not, write to the Free Software
23 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111, USA.
24 *****************************************************************************/
26 /*****************************************************************************
27 * intf_thread_t: describe an interface thread
28 *****************************************************************************
29 * This structe describes all interface-specific data of the main (interface)
31 *****************************************************************************/
32 typedef struct intf_thread_s
34 boolean_t b_die
; /* `die' flag */
36 /* Specific interfaces */
37 p_intf_console_t p_console
; /* console */
38 p_intf_sys_t p_sys
; /* system interface */
40 /* Plugin used and shortcuts to access its capabilities */
41 struct module_s
* p_module
;
42 int ( *pf_open
) ( struct intf_thread_s
* );
43 void ( *pf_close
) ( struct intf_thread_s
* );
44 void ( *pf_run
) ( struct intf_thread_s
* );
46 /* Interface callback */
47 void ( *pf_manage
) ( struct intf_thread_s
* );
49 /* XXX: new message passing stuff will go here */
50 vlc_mutex_t change_lock
;
51 boolean_t b_menu_change
;
56 /*****************************************************************************
58 *****************************************************************************
59 * Store a single message. Messages have a maximal size of INTF_MSG_MSGSIZE.
60 *****************************************************************************/
63 int i_type
; /* message type, see below */
64 char * psz_msg
; /* the message itself */
67 mtime_t date
; /* date of the message */
68 char * psz_file
; /* file in which the function was called */
69 char * psz_function
; /* function from which the function was called */
70 int i_line
; /* line at which the function was called */
75 #define INTF_MSG_STD 0 /* standard message */
76 #define INTF_MSG_ERR 1 /* error message */
77 #define INTF_MSG_WARN 2 /* warning message */
78 #define INTF_MSG_STAT 3 /* statistic message */
80 /*****************************************************************************
82 *****************************************************************************
83 * Used by interface plugins which subscribe to the message queue.
84 *****************************************************************************/
85 typedef struct intf_subscription_s
92 } intf_subscription_t
;
94 /*****************************************************************************
96 *****************************************************************************/
97 intf_thread_t
* intf_Create ( void );
98 void intf_Destroy ( intf_thread_t
* p_intf
);
100 void intf_MsgCreate ( void );
101 void intf_MsgDestroy ( void );
104 intf_subscription_t
* intf_MsgSub ( void );
105 void intf_MsgUnsub ( intf_subscription_t
* );
107 # define intf_MsgSub p_symbols->intf_MsgSub
108 # define intf_MsgUnsub p_symbols->intf_MsgUnsub