]> git.sesse.net Git - vlc/blob - include/vlc_vlm.h
* src/misc/vlm.c: started "vod server" integration (not much done yet).
[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     /* only for vod */
50     vod_media_t *vod_media;
51
52     /* "playlist" index */
53     int     i_index;
54
55     char    *psz_output;
56
57     int     i_option;
58     char    **option;
59
60     /* global options for all inputs */
61     input_item_t    item;
62     input_thread_t  *p_input;
63
64 } vlm_media_t;
65
66
67 typedef struct
68 {
69     /* names "schedule" is reserved */
70     char    *psz_name;
71     vlc_bool_t b_enabled;
72     /* list of commands to execute on date */
73     int i_command;
74     char **command;
75
76     /* the date of 1st execution */
77     mtime_t i_date;
78
79     /* if != 0 repeat schedule every (period) */
80     mtime_t i_period;
81     /* number of times you have to repeat
82        i_repeat < 0 : endless repeat     */
83     int i_repeat;
84
85 } vlm_schedule_t;
86
87 /* ok, here is the structure of a vlm_message:
88    The parent node is ( name_of_the_command , NULL ), or
89    ( name_of_the_command , message_error ) on error.
90    If a node has children, it should not have a value (=NULL).*/
91 struct vlm_message_t
92 {
93     char *psz_name;
94     char *psz_value;
95
96     int           i_child;
97     vlm_message_t **child;
98 };
99
100
101 struct vlm_t
102 {
103     VLC_COMMON_MEMBERS
104
105     vlc_mutex_t lock;
106
107     int            i_media;
108     vlm_media_t    **media;
109
110     int            i_vod;
111     vod_t          *vod;
112
113     int            i_schedule;
114     vlm_schedule_t **schedule;
115 };
116
117
118 #define vlm_New( a ) __vlm_New( VLC_OBJECT(a) )
119 VLC_EXPORT( vlm_t *, __vlm_New, ( vlc_object_t * ) );
120 VLC_EXPORT( void, vlm_Delete, ( vlm_t * ) );
121 VLC_EXPORT( int, vlm_ExecuteCommand, ( vlm_t *, char *, vlm_message_t ** ) );
122 VLC_EXPORT( void, vlm_MessageDelete, ( vlm_message_t* ) );
123
124 #endif