input_thread_t *p_input;
};
+/* pf_demux return values */
+#define VLC_DEMUXER_EOF 0
+#define VLC_DEMUXER_EGENERIC -1
+#define VLC_DEMUXER_SUCCESS 1
+
+/* demux_t.info.i_update field */
+#define INPUT_UPDATE_TITLE 0x0010
+#define INPUT_UPDATE_SEEKPOINT 0x0020
+#define INPUT_UPDATE_META 0x0040
+#define INPUT_UPDATE_TITLE_LIST 0x0100
/* demux_meta_t is returned by "meta reader" module to the demuxer */
typedef struct demux_meta_t
DEMUX_SET_TITLE, /* arg1= int can fail */
DEMUX_SET_SEEKPOINT, /* arg1= int can fail */
- /* DEMUX_SET_GROUP only a hint for demuxer (mainly DVB) to allow not
+ /* DEMUX_SET_GROUP/SET_ES only a hint for demuxer (mainly DVB) to allow not
* reading everything (you should not use this to call es_out_Control)
* if you don't know what to do with it, just IGNORE it, it is safe(r)
* -1 means all group, 0 default group (first es added) */
DEMUX_SET_GROUP, /* arg1= int, arg2=const vlc_list_t * can fail */
+ DEMUX_SET_ES, /* arg1= int can fail */
/* Ask the demux to demux until the given date at the next pf_demux call
* but not more (and not less, at the precision available of course).
DEMUX_CAN_SEEK, /* arg1= bool* can fail (assume false)*/
+ /* DEMUX_IS_PLAYLIST returns true if the demux is a playlist
+ * (an archive, a directory or a network share is also a playlist) */
+ DEMUX_IS_PLAYLIST, /* arg1= bool* can fail (assume false)*/
+
/* Navigation */
DEMUX_NAV_ACTIVATE, /* res=can fail */
DEMUX_NAV_UP, /* res=can fail */
&& title != (unsigned)demux->info.i_title )
{
demux->info.i_title = title;
- demux->info.i_update = INPUT_UPDATE_TITLE;
+ demux->info.i_update |= INPUT_UPDATE_TITLE;
}
if( stream_Control( s, STREAM_GET_SEEKPOINT, &seekpoint ) == VLC_SUCCESS
&& seekpoint != (unsigned)demux->info.i_seekpoint )
{
demux->info.i_seekpoint = seekpoint;
- demux->info.i_update = INPUT_UPDATE_SEEKPOINT;
+ demux->info.i_update |= INPUT_UPDATE_SEEKPOINT;
}
}