]> git.sesse.net Git - vlc/blob - modules/stream_out/description.c
stream_out/description.c: Add some debug msg to better track down an assertion failure.
[vlc] / modules / stream_out / description.c
1 /*****************************************************************************
2  * description.c: description stream output module (gathers ES info)
3  *****************************************************************************
4  * Copyright (C) 2003-2004 the VideoLAN team
5  * $Id$
6  *
7  * Authors: Gildas Bazin <gbazin@videolan.org>
8  *
9  * This program is free software; you can redistribute it and/or modify
10  * it under the terms of the GNU General Public License as published by
11  * the Free Software Foundation; either version 2 of the License, or
12  * (at your option) any later version.
13  *
14  * This program is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17  * GNU General Public License for more details.
18  *
19  * You should have received a copy of the GNU General Public License
20  * along with this program; if not, write to the Free Software
21  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
22  *****************************************************************************/
23
24 /*****************************************************************************
25  * Preamble
26  *****************************************************************************/
27
28 #ifdef HAVE_CONFIG_H
29 # include "config.h"
30 #endif
31
32 #include <vlc/vlc.h>
33 #include <vlc_input.h>
34 #include <vlc_block.h>
35 #include <vlc_sout.h>
36
37 /*****************************************************************************
38  * Exported prototypes
39  *****************************************************************************/
40 static int      Open    ( vlc_object_t * );
41 static void     Close   ( vlc_object_t * );
42
43 static sout_stream_id_t *Add ( sout_stream_t *, es_format_t * );
44 static int               Del ( sout_stream_t *, sout_stream_id_t * );
45 static int               Send( sout_stream_t *, sout_stream_id_t *, block_t* );
46
47 /*****************************************************************************
48  * Module descriptor
49  *****************************************************************************/
50 vlc_module_begin();
51     set_description( _("Description stream output") );
52     set_capability( "sout stream", 50 );
53     add_shortcut( "description" );
54     set_callbacks( Open, Close );
55 vlc_module_end();
56
57 struct sout_stream_sys_t
58 {
59     int            i_id;
60     input_thread_t *p_input;
61
62     mtime_t i_stream_start;
63 };
64
65 struct sout_stream_id_t
66 {
67     int i_d_u_m_m_y;
68 };
69
70 /*****************************************************************************
71  * Open:
72  *****************************************************************************/
73 static int Open( vlc_object_t *p_this )
74 {
75     sout_stream_t *p_stream = (sout_stream_t*)p_this;
76     sout_stream_sys_t *p_sys;
77
78     p_stream->pf_add  = Add;
79     p_stream->pf_del  = Del;
80     p_stream->pf_send = Send;
81     p_sys = p_stream->p_sys = malloc(sizeof(sout_stream_sys_t));
82
83     p_sys->i_id = 0;
84     p_sys->p_input = NULL;
85
86     p_sys->i_stream_start = 0;
87
88     return VLC_SUCCESS;
89 }
90
91 /*****************************************************************************
92  * Close:
93  *****************************************************************************/
94 static void Close( vlc_object_t *p_this )
95 {
96     sout_stream_t *p_stream = (sout_stream_t *)p_this;
97     sout_stream_sys_t *p_sys = p_stream->p_sys;
98
99     msg_Dbg( p_this, "description: Closing the module" );
100
101     /* It can happen only if buggy */
102     assert( !p_sys->p_input );
103
104     free( p_sys );
105 }
106
107 static sout_stream_id_t *Add( sout_stream_t *p_stream, es_format_t *p_fmt )
108 {
109     __msg_Dbg( NULL, "description: Adding a stream" );
110     sout_stream_sys_t *p_sys = p_stream->p_sys;
111     sout_stream_id_t *id;
112     es_format_t *p_fmt_copy;
113     input_item_t *p_item;
114
115     if( !p_sys->p_input )
116         p_sys->p_input = vlc_object_find( p_stream, VLC_OBJECT_INPUT, FIND_PARENT );
117     if( !p_sys->p_input )
118         return NULL;
119  
120     p_item = input_GetItem(p_sys->p_input);
121
122     p_fmt_copy = malloc(sizeof(es_format_t));
123     es_format_Copy( p_fmt_copy, p_fmt );
124
125     vlc_mutex_lock( &p_item->lock );
126     TAB_APPEND( p_item->i_es, p_item->es, p_fmt_copy );
127     vlc_mutex_unlock( &p_item->lock );
128
129     p_sys->i_id++;
130     if( p_sys->i_stream_start <= 0 )
131         p_sys->i_stream_start = mdate();
132
133     id = malloc( sizeof( sout_stream_id_t ) );
134     id->i_d_u_m_m_y = 0;
135     return id;
136 }
137
138 static int Del( sout_stream_t *p_stream, sout_stream_id_t *id )
139 {
140     sout_stream_sys_t *p_sys = p_stream->p_sys;
141
142     __msg_Dbg( NULL, "description: Removing a stream (id:%d)", p_sys->i_id );
143
144     p_sys->i_id--;
145     if( p_sys->i_id <= 0 )
146     {
147         vlc_object_release( p_sys->p_input );
148         p_sys->p_input = NULL;
149     }
150
151     free( id );
152     return VLC_SUCCESS;
153 }
154
155 static int Send( sout_stream_t *p_stream, sout_stream_id_t *id,
156                  block_t *p_buffer )
157 {
158     VLC_UNUSED(id);
159     sout_stream_sys_t *p_sys = p_stream->p_sys;
160
161     block_ChainRelease( p_buffer );
162
163     if( p_sys->p_input && p_sys->i_stream_start + 1500000 < mdate() )
164         p_sys->p_input->b_eof = true;
165
166     return VLC_SUCCESS;
167 }