]> git.sesse.net Git - vlc/blob - include/vlc_vlm.h
* src/input/control.c: added INPUT_ADD_INFO/INPUT_SET_NAME to input_Control().
[vlc] / include / vlc_vlm.h
1 /*****************************************************************************
2  * vlc_vlm.h: VLM interface plugin
3  *****************************************************************************
4  * Copyright (C) 2000, 2001 VideoLAN
5  * $Id$
6  *
7  * Authors: Simon Latapie <garf@videolan.org>
8  *          Laurent Aimar <fenrir@videolan.org>
9  *
10  * This program is free software; you can redistribute it and/or modify
11  * it under the terms of the GNU General Public License as published by
12  * the Free Software Foundation; either version 2 of the License, or
13  * (at your option) any later version.
14  *
15  * This program is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18  * GNU General Public License for more details.
19  *
20  * You should have received a copy of the GNU General Public License
21  * along with this program; if not, write to the Free Software
22  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111, USA.
23  *****************************************************************************/
24
25 #ifndef _VLC_VLM_H
26 #define _VLC_VLM_H 1
27
28 /* VLM specific - structures and functions */
29 enum
30 {
31     VOD_TYPE = 0,
32     BROADCAST_TYPE = 1,
33 };
34
35 typedef struct
36 {
37     vlc_bool_t b_enabled;
38     int      i_type;
39
40     /* name "media" is reserved */
41     char    *psz_name;
42
43     int     i_input;
44     char    **input;
45
46     /* only for broadcast */
47     vlc_bool_t b_loop;
48
49     /* "playlist" index */
50     int     i_index;
51
52     char    *psz_output;
53
54     int     i_option;
55     char    **option;
56
57     /* global options for all inputs */
58     input_item_t    item;
59     input_thread_t  *p_input;
60
61 } vlm_media_t;
62
63
64 typedef struct
65 {
66     /* names "schedule" is reserved */
67     char    *psz_name;
68     vlc_bool_t b_enabled;
69     /* list of commands to execute on date */
70     int i_command;
71     char **command;
72
73     /* the date of 1st execution */
74     mtime_t i_date;
75
76     /* if != 0 repeat schedule every (period) */
77     mtime_t i_period;
78     /* number of times you have to repeat
79        i_repeat < 0 : endless repeat     */
80     int i_repeat;
81
82 } vlm_schedule_t;
83
84 /* ok, here is the structure of a vlm_message:
85    The parent node is ( name_of_the_command , NULL ), or
86    ( name_of_the_command , message_error ) on error.
87    If a node has children, it should not have a value (=NULL).*/
88 struct vlm_message_t
89 {
90     char *psz_name;
91     char *psz_value;
92
93     int           i_child;
94     vlm_message_t **child;
95 };
96
97
98 struct vlm_t
99 {
100     VLC_COMMON_MEMBERS
101
102     vlc_mutex_t lock;
103
104 #if 0
105     int         i_vod;
106     vlm_media_t **vod;
107
108     int         i_broadcast;
109     vlm_media_t **broadcast;
110 #endif
111
112     int            i_media;
113     vlm_media_t    **media;
114
115     int            i_schedule;
116     vlm_schedule_t **schedule;
117 };
118
119
120 #define vlm_New( a ) __vlm_New( VLC_OBJECT(a) )
121
122 VLC_EXPORT( vlm_t *, __vlm_New, ( vlc_object_t * ) );
123 VLC_EXPORT( void,    vlm_Delete, ( vlm_t * ) );
124
125 VLC_EXPORT( int,     vlm_ExecuteCommand, ( vlm_t *, char *, vlm_message_t **) );
126 VLC_EXPORT( void,    vlm_MessageDelete, ( vlm_message_t* ) );
127
128 #endif