* intf_vlc_wrapper.h: BeOS plugin for vlc (derived from MacOS X port )
*****************************************************************************
* Copyright (C) 2001 VideoLAN
- * $Id: VlcWrapper.cpp,v 1.6 2002/10/14 20:09:17 titer Exp $
+ * $Id: VlcWrapper.cpp,v 1.11 2002/11/26 01:06:08 titer Exp $
*
* Authors: Florian G. Pflug <fgp@phlo.org>
* Jon Lech Johansen <jon-vl@nanocrew.net>
* Tony Casltey <tony@castley.net>
* Stephan Aßmus <stippi@yellowbites.com>
+ * Eric Petit <titer@videolan.org>
*
* This program is free software{} you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
#include "VlcWrapper.h"
-Intf_VLCWrapper *Intf_VLCWrapper::getVLCWrapper(intf_thread_t *p_interface)
-{
- static Intf_VLCWrapper *one_wrapper;
- if (one_wrapper == NULL )
- {
- one_wrapper = new Intf_VLCWrapper(p_interface);
- }
- return one_wrapper;
-}
-
+/* constructor */
Intf_VLCWrapper::Intf_VLCWrapper(intf_thread_t *p_interface)
{
p_intf = p_interface;
+ p_input = NULL;
+ p_aout = NULL;
+ p_playlist = (playlist_t *)vlc_object_find( p_intf, VLC_OBJECT_PLAYLIST,
+ FIND_ANYWHERE );
}
+/* destructor */
Intf_VLCWrapper::~Intf_VLCWrapper()
{
+ if( p_input )
+ {
+ vlc_object_release( p_input );
+ }
+ if( p_playlist )
+ {
+ vlc_object_release( p_playlist );
+ }
+ if( p_aout )
+ {
+ vlc_object_release( p_aout );
+ }
}
-#if 0
-bool Intf_VLCWrapper::manage()
+/* UpdateInputAndAOut: updates p_input and p_aout, returns true if the
+ interface needs to be updated */
+bool Intf_VLCWrapper::UpdateInputAndAOut()
{
- /* p_main->p_intf->pf_manage( p_intf ); */
-
- if ( p_intf->b_die )
- {
- // exit the lot
- return( 1 );
- }
-
- if ( p_intf->p_sys->p_input != NULL )
- {
- vlc_mutex_lock( &p_intf->p_sys->p_input->stream.stream_lock );
- if( !p_intf->p_sys->p_input->b_die )
+ if( p_input == NULL )
+ {
+ p_input = (input_thread_t *)vlc_object_find( p_intf, VLC_OBJECT_INPUT,
+ FIND_ANYWHERE );
+ }
+ if( p_aout == NULL )
+ {
+ p_aout = (aout_instance_t*)vlc_object_find( p_intf, VLC_OBJECT_AOUT,
+ FIND_ANYWHERE );
+ }
+
+ if( p_input != NULL )
+ {
+ if( p_input->b_dead )
{
- /* New input or stream map change */
- if( p_intf->p_sys->p_input->stream.b_changed ||
- p_intf->p_sys->i_part !=
- p_intf->p_sys->p_input->stream.p_selected_area->i_part )
+ vlc_object_release( p_input );
+ p_input = NULL;
+
+ if( p_aout )
{
- setupMenus();
- p_intf->p_sys->b_disabled_menus = 0;
+ vlc_object_release( p_aout );
+ p_aout = NULL;
}
}
- vlc_mutex_unlock( &p_intf->p_sys->p_input->stream.stream_lock );
+ return true;
}
- else if ( !p_intf->p_sys->b_disabled_menus )
+ return false;
+}
+
+int Intf_VLCWrapper::InputStatus()
+{
+ return p_input->stream.control.i_status;
+}
+
+int Intf_VLCWrapper::InputRate()
+{
+ return p_input->stream.control.i_rate;
+}
+
+int Intf_VLCWrapper::InputTell()
+{
+ return p_input->stream.p_selected_area->i_tell;
+}
+
+int Intf_VLCWrapper::InputSize()
+{
+ return p_input->stream.p_selected_area->i_size;
+}
+
+int Intf_VLCWrapper::PlaylistSize()
+{
+ return p_playlist->i_size;
+}
+
+char *Intf_VLCWrapper::PlaylistItemName( int i )
+{
+ return p_playlist->pp_items[i]->psz_name;
+}
+
+int Intf_VLCWrapper::PlaylistCurrent()
+{
+ return p_playlist->i_index;
+}
+
+bool Intf_VLCWrapper::HasTitles()
+{
+ return ( p_input->stream.i_area_nb > 1 );
+}
+
+void Intf_VLCWrapper::PrevTitle()
+{
+ int i_id;
+ i_id = p_input->stream.p_selected_area->i_id - 1;
+ if( i_id > 0 )
{
- setupMenus();
- p_intf->p_sys->b_disabled_menus = 1;
+ toggleTitle(i_id);
}
- return( 0 );
}
-#endif
-void Intf_VLCWrapper::quit()
+void Intf_VLCWrapper::NextTitle()
{
- p_intf->b_die = 1;
+ int i_id;
+ i_id = p_input->stream.p_selected_area->i_id + 1;
+ if( i_id < p_input->stream.i_area_nb )
+ {
+ toggleTitle(i_id);
+ }
}
-
+
+bool Intf_VLCWrapper::HasChapters()
+{
+ return ( p_input->stream.p_selected_area->i_part_nb > 1 );
+}
+
+void Intf_VLCWrapper::PrevChapter()
+{
+ int i_id;
+ i_id = p_input->stream.p_selected_area->i_part - 1;
+ if( i_id >= 0 )
+ {
+ toggleChapter(i_id);
+ }
+}
+
+void Intf_VLCWrapper::NextChapter()
+{
+ int i_id;
+ i_id = p_input->stream.p_selected_area->i_part + 1;
+ if( i_id >= 0 )
+ {
+ toggleChapter(i_id);
+ }
+}
+
/* playlist control */
bool Intf_VLCWrapper::playlistPlay()
{
- playlist_t *p_playlist =
- (playlist_t *)vlc_object_find( p_intf, VLC_OBJECT_PLAYLIST,
- FIND_ANYWHERE );
-
vlc_mutex_lock( &p_playlist->object_lock );
if( p_playlist->i_size )
{
vlc_mutex_unlock( &p_playlist->object_lock );
playlist_Play( p_playlist );
- vlc_object_release( p_playlist );
}
else
{
vlc_mutex_unlock( &p_playlist->object_lock );
- vlc_object_release( p_playlist );
}
-
return( true );
}
void Intf_VLCWrapper::playlistPause()
{
- toggle_mute( );
- playlist_t *p_playlist =
- (playlist_t *)vlc_object_find( p_intf, VLC_OBJECT_PLAYLIST,
- FIND_ANYWHERE );
- playlist_Pause( p_playlist );
- vlc_object_release( p_playlist );
+ toggle_mute();
+ if( p_input )
+ {
+ input_SetStatus( p_input, INPUT_STATUS_PAUSE );
+ }
}
void Intf_VLCWrapper::playlistStop()
{
- playlist_t *p_playlist =
- (playlist_t *)vlc_object_find( p_intf, VLC_OBJECT_PLAYLIST,
- FIND_ANYWHERE );
-
+ volume_mute();
playlist_Stop( p_playlist );
- vlc_object_release( p_playlist );
}
void Intf_VLCWrapper::playlistNext()
{
- playlist_t *p_playlist =
- (playlist_t *)vlc_object_find( p_intf, VLC_OBJECT_PLAYLIST,
- FIND_ANYWHERE );
-
playlist_Next( p_playlist );
- vlc_object_release( p_playlist );
}
void Intf_VLCWrapper::playlistPrev()
{
- playlist_t *p_playlist =
- (playlist_t *)vlc_object_find( p_intf, VLC_OBJECT_PLAYLIST,
- FIND_ANYWHERE );
-
playlist_Prev( p_playlist );
- vlc_object_release( p_playlist );
}
void Intf_VLCWrapper::playlistSkip(int i)
{
- playlist_t *p_playlist =
- (playlist_t *)vlc_object_find( p_intf, VLC_OBJECT_PLAYLIST,
- FIND_ANYWHERE );
-
playlist_Skip( p_playlist, i );
- vlc_object_release( p_playlist );
}
void Intf_VLCWrapper::playlistGoto(int i)
{
- playlist_t *p_playlist =
- (playlist_t *)vlc_object_find( p_intf, VLC_OBJECT_PLAYLIST,
- FIND_ANYWHERE );
-
playlist_Goto( p_playlist, i );
- vlc_object_release( p_playlist );
}
void Intf_VLCWrapper::playlistJumpTo( int pos )
int Intf_VLCWrapper::playlistCurrentPos()
{
playlistLock();
- int pos = p_intf->p_sys->p_playlist->i_index;
+ int pos = p_playlist->i_index;
playlistUnlock();
return pos;
}
int Intf_VLCWrapper::playlistSize()
{
playlistLock();
- int size = p_intf->p_sys->p_playlist->i_size;
+ int size = p_playlist->i_size;
playlistUnlock();
return size;
}
void Intf_VLCWrapper::playlistLock()
{
- vlc_mutex_lock( &p_intf->p_sys->p_playlist->object_lock );
+ vlc_mutex_lock( &p_playlist->object_lock );
}
void Intf_VLCWrapper::playlistUnlock()
{
- vlc_mutex_unlock( &p_intf->p_sys->p_playlist->object_lock );
+ vlc_mutex_unlock( &p_playlist->object_lock );
}
void Intf_VLCWrapper::getNavCapabilities( bool* canSkipPrev,
*canSkipNext = false;
// get playlist info
playlistLock();
- int pos = p_intf->p_sys->p_playlist->i_index;
- int size = p_intf->p_sys->p_playlist->i_size;
+ int pos = p_playlist->i_index;
+ int size = p_playlist->i_size;
playlistUnlock();
- /* input_thread_t* input = p_input_bank->pp_input[0]; */
- input_thread_t* input = p_intf->p_sys->p_input;
// see if we have got a stream going
- if ( input )
+ if ( p_input )
{
- vlc_mutex_lock( &input->stream.stream_lock );
+ vlc_mutex_lock( &p_input->stream.stream_lock );
- bool hasTitles = input->stream.i_area_nb > 1;
- int numChapters = input->stream.p_selected_area->i_part_nb;
+ bool hasTitles = p_input->stream.i_area_nb > 1;
+ int numChapters = p_input->stream.p_selected_area->i_part_nb;
bool hasChapters = numChapters > 1;
// first, look for chapters
if ( hasChapters )
{
- *canSkipPrev = input->stream.p_selected_area->i_part > 0;
- *canSkipNext = input->stream.p_selected_area->i_part <
- input->stream.p_selected_area->i_part_nb - 1;
+ *canSkipPrev = p_input->stream.p_selected_area->i_part > 0;
+ *canSkipNext = p_input->stream.p_selected_area->i_part <
+ p_input->stream.p_selected_area->i_part_nb - 1;
}
// if one of the skip capabilities is false,
// make it depend on titles instead
if ( !*canSkipPrev && hasTitles )
- *canSkipPrev = input->stream.p_selected_area->i_id > 1;
+ *canSkipPrev = p_input->stream.p_selected_area->i_id > 1;
if ( !*canSkipNext && hasTitles )
- *canSkipNext = input->stream.p_selected_area->i_id < input->stream.i_area_nb - 1;
+ *canSkipNext = p_input->stream.p_selected_area->i_id <
+ p_input->stream.i_area_nb - 1;
- vlc_mutex_unlock( &input->stream.stream_lock );
+ vlc_mutex_unlock( &p_input->stream.stream_lock );
}
// last but not least, make capabilities depend on playlist
if ( !*canSkipPrev )
{
if ( p_intf->p_sys->b_loop )
{
- playlist_Delete( p_intf->p_sys->p_playlist,
- p_intf->p_sys->p_playlist->i_size - 1 );
+ playlist_Delete( p_playlist, p_playlist->i_size - 1 );
}
else
{
- playlist_Add( p_intf->p_sys->p_playlist, "vlc:loop",
+ playlist_Add( p_playlist, "vlc:loop",
PLAYLIST_APPEND | PLAYLIST_GO,
PLAYLIST_END );
}
/* playback control */
void Intf_VLCWrapper::playSlower()
{
- if( p_intf->p_sys->p_input != NULL )
+ if( p_input != NULL )
{
- input_SetStatus( p_intf->p_sys->p_input, INPUT_STATUS_SLOWER );
+ input_SetStatus( p_input, INPUT_STATUS_SLOWER );
}
- if (p_intf->p_sys->p_input->stream.control.i_rate == DEFAULT_RATE)
+ if( p_input->stream.control.i_rate == DEFAULT_RATE)
{
toggle_mute( );
}
void Intf_VLCWrapper::playFaster()
{
- if( p_intf->p_sys->p_input != NULL )
+ if( p_input != NULL )
{
- input_SetStatus( p_intf->p_sys->p_input, INPUT_STATUS_FASTER );
+ input_SetStatus( p_input, INPUT_STATUS_FASTER );
}
- if (p_intf->p_sys->p_input->stream.control.i_rate == DEFAULT_RATE)
+ if( p_input->stream.control.i_rate == DEFAULT_RATE)
{
toggle_mute( );
}
void Intf_VLCWrapper::volume_mute()
{
- p_intf->p_sys->p_aout =
- (aout_instance_t *)vlc_object_find( p_intf, VLC_OBJECT_AOUT,
- FIND_ANYWHERE );
- if( p_intf->p_sys->p_aout != NULL )
+ if( p_aout != NULL )
{
if( !p_intf->p_sys->b_mute )
{
- p_intf->p_sys->i_saved_volume = p_intf->p_sys->p_aout->output.i_volume;
- p_intf->p_sys->p_aout->output.i_volume = 0;
+ p_intf->p_sys->i_saved_volume = p_aout->output.i_volume;
+ p_aout->output.i_volume = 0;
p_intf->p_sys->b_mute = 1;
}
}
void Intf_VLCWrapper::volume_restore()
{
- p_intf->p_sys->p_aout =
- (aout_instance_t *)vlc_object_find( p_intf, VLC_OBJECT_AOUT,
- FIND_ANYWHERE );
- if( p_intf->p_sys->p_aout != NULL )
+ if( p_aout != NULL )
{
- p_intf->p_sys->p_aout->output.i_volume = p_intf->p_sys->i_saved_volume;
+ p_aout->output.i_volume = p_intf->p_sys->i_saved_volume;
p_intf->p_sys->i_saved_volume = 0;
p_intf->p_sys->b_mute = 0;
}
void Intf_VLCWrapper::set_volume(int value)
{
- p_intf->p_sys->p_aout =
- (aout_instance_t *)vlc_object_find( p_intf, VLC_OBJECT_AOUT,
- FIND_ANYWHERE );
- if( p_intf->p_sys->p_aout != NULL )
+ if( p_aout != NULL )
{
// make sure value is within bounds
if (value < 0)
value = 0;
if (value > AOUT_VOLUME_MAX)
value = AOUT_VOLUME_MAX;
- vlc_mutex_lock( &p_intf->p_sys->p_aout->mixer_lock );
+ vlc_mutex_lock( &p_aout->mixer_lock );
// unmute volume if muted
if ( p_intf->p_sys->b_mute )
{
p_intf->p_sys->b_mute = 0;
- p_intf->p_sys->p_aout->output.i_volume = value;
+ p_aout->output.i_volume = value;
}
- vlc_mutex_unlock( &p_intf->p_sys->p_aout->mixer_lock );
+ vlc_mutex_unlock( &p_aout->mixer_lock );
}
}
void Intf_VLCWrapper::toggle_mute()
{
- p_intf->p_sys->p_aout =
- (aout_instance_t *)vlc_object_find( p_intf, VLC_OBJECT_AOUT,
- FIND_ANYWHERE );
- if( p_intf->p_sys->p_aout != NULL )
+ if( p_aout != NULL )
{
if ( p_intf->p_sys->b_mute )
{
{
bool muted = true;
- p_intf->p_sys->p_aout =
- (aout_instance_t *)vlc_object_find( p_intf, VLC_OBJECT_AOUT,
- FIND_ANYWHERE );
- if( p_intf->p_sys->p_aout != NULL )
+ if( p_aout != NULL )
{
- vlc_mutex_lock( &p_intf->p_sys->p_aout->mixer_lock );
- if( p_intf->p_sys->p_aout->output.i_volume > 0 )
+ vlc_mutex_lock( &p_aout->mixer_lock );
+ if( p_aout->output.i_volume > 0 )
{
muted = false;
}
- vlc_mutex_unlock( &p_intf->p_sys->p_aout->mixer_lock );
+ vlc_mutex_unlock( &p_aout->mixer_lock );
// unfortunately, this is not reliable!
// return p_main->p_intf->p_sys->b_mute;
}
{
bool playing = false;
- if ( p_intf->p_sys->p_input )
+ if ( p_input )
{
- switch ( p_intf->p_sys->p_input->stream.control.i_status )
+ switch ( p_input->stream.control.i_status )
{
case PLAYING_S:
case FORWARD_S:
void Intf_VLCWrapper::maxvolume()
{
- p_intf->p_sys->p_aout =
- (aout_instance_t *)vlc_object_find( p_intf, VLC_OBJECT_AOUT,
- FIND_ANYWHERE );
- if( p_intf->p_sys->p_aout != NULL )
+ if( p_aout != NULL )
{
if( p_intf->p_sys->b_mute )
{
}
else
{
- p_intf->p_sys->p_aout->output.i_volume = AOUT_VOLUME_MAX;
+ p_aout->output.i_volume = AOUT_VOLUME_MAX;
}
}
}
bool Intf_VLCWrapper::has_audio()
{
- p_intf->p_sys->p_aout =
- (aout_instance_t *)vlc_object_find( p_intf, VLC_OBJECT_AOUT,
- FIND_ANYWHERE );
- return( p_intf->p_sys->p_aout != NULL );
+ return( p_aout != NULL );
}
-//void Intf_VLCWrapper::fullscreen()
-//{
-// if( p_vout_bank->pp_vout[0] != NULL )
-// {
-// p_vout_bank->pp_vout[0]->i_changes |= VOUT_FULLSCREEN_CHANGE;
-// }
-//}
-
-void Intf_VLCWrapper::eject(){}
-
/* playback info */
-BString* Intf_VLCWrapper::getTimeAsString()
+const char* Intf_VLCWrapper::getTimeAsString()
{
static char psz_currenttime[ OFFSETTOTIME_MAX_SIZE ];
- if( p_intf->p_sys->p_input == NULL )
+ if( p_input == NULL )
{
- return (new BString("00:00:00"));
+ return ("-:--:--");
}
- input_OffsetToTime( p_intf->p_sys->p_input,
+ input_OffsetToTime( p_input,
psz_currenttime,
- p_intf->p_sys->p_input->stream.p_selected_area->i_tell );
+ p_input->stream.p_selected_area->i_tell );
- return(new BString(psz_currenttime));
+ return(psz_currenttime);
}
float Intf_VLCWrapper::getTimeAsFloat()
{
float f_time = 0.0;
- if( p_intf->p_sys->p_input != NULL )
+ if( p_input != NULL )
{
- f_time = (float)p_intf->p_sys->p_input->stream.p_selected_area->i_tell /
- (float)p_intf->p_sys->p_input->stream.p_selected_area->i_size;
+ f_time = (float)p_input->stream.p_selected_area->i_tell /
+ (float)p_input->stream.p_selected_area->i_size;
}
else
{
void Intf_VLCWrapper::setTimeAsFloat(float f_position)
{
- if( p_intf->p_sys->p_input != NULL )
+ if( p_input != NULL )
{
- input_Seek( p_intf->p_sys->p_input,
- (long long int)(p_intf->p_sys->p_input->stream.p_selected_area->i_size
+ input_Seek( p_input,
+ (long long int)(p_input->stream.p_selected_area->i_size
* f_position / SEEKSLIDER_RANGE ),
INPUT_SEEK_SET);
}
BList *Intf_VLCWrapper::playlistAsArray()
{
int i;
- playlist_t *p_playlist =
- (playlist_t *)vlc_object_find( p_intf, VLC_OBJECT_PLAYLIST,
- FIND_ANYWHERE );
-
BList* p_list = new BList(p_playlist->i_size);
vlc_mutex_lock( &p_playlist->object_lock );
}
vlc_mutex_unlock( &p_playlist->object_lock );
- vlc_object_release( p_playlist );
return( p_list );
}
+// getPlaylistInfo
+void
+Intf_VLCWrapper::getPlaylistInfo( int32& currentIndex, int32& maxIndex )
+{
+ currentIndex = -1;
+ maxIndex = -1;
+ if ( p_playlist )
+ {
+ maxIndex = p_playlist->i_size;
+ if ( maxIndex > 0 )
+ currentIndex = p_playlist->i_index + 1;
+ else
+ maxIndex = -1;
+ }
+}
+
+// getTitleInfo
+void
+Intf_VLCWrapper::getTitleInfo( int32& currentIndex, int32& maxIndex )
+{
+ currentIndex = -1;
+ maxIndex = -1;
+ if ( p_input )
+ {
+ vlc_mutex_lock( &p_input->stream.stream_lock );
+
+ maxIndex = p_input->stream.i_area_nb - 1;
+ if ( maxIndex > 0)
+ currentIndex = p_input->stream.p_selected_area->i_id;
+ else
+ maxIndex = -1;
+
+ vlc_mutex_unlock( &p_input->stream.stream_lock );
+ }
+}
+
+// getChapterInfo
+void
+Intf_VLCWrapper::getChapterInfo( int32& currentIndex, int32& maxIndex )
+{
+ currentIndex = -1;
+ maxIndex = -1;
+ if ( p_input )
+ {
+ vlc_mutex_lock( &p_input->stream.stream_lock );
+
+ maxIndex = p_input->stream.p_selected_area->i_part_nb - 1;
+ if ( maxIndex > 0)
+ currentIndex = p_input->stream.p_selected_area->i_part;
+ else
+ maxIndex = -1;
+
+ vlc_mutex_unlock( &p_input->stream.stream_lock );
+ }
+}
+
/* open file/disc/network */
void Intf_VLCWrapper::openFiles( BList* o_files, bool replace )
{
BString *o_file;
- playlist_t *p_playlist = p_intf->p_sys->p_playlist;
while( ( o_file = (BString *)o_files->LastItem() ) )
{
PLAYLIST_APPEND | PLAYLIST_GO, PLAYLIST_END );
delete o_file;
}
-
- vlc_object_release( p_playlist );
}
void Intf_VLCWrapper::openDisc(BString o_type, BString o_device, int i_title, int i_chapter)
BString o_source("");
o_source << o_type << ":" << o_device ;
- playlist_t *p_playlist =
- (playlist_t *)vlc_object_find( p_intf, VLC_OBJECT_PLAYLIST,
- FIND_ANYWHERE );
playlist_Add( p_playlist, o_source.String(),
PLAYLIST_APPEND | PLAYLIST_GO, PLAYLIST_END );
- vlc_object_release( p_playlist );
}
void Intf_VLCWrapper::openNet(BString o_addr, int i_port)
void Intf_VLCWrapper::toggleTitle(int i_title)
{
- if( p_intf->p_sys->p_input != NULL )
+ if( p_input != NULL )
{
- input_ChangeArea( p_intf->p_sys->p_input,
- p_intf->p_sys->p_input->stream.pp_areas[i_title] );
+ input_ChangeArea( p_input,
+ p_input->stream.pp_areas[i_title] );
- vlc_mutex_lock( &p_intf->p_sys->p_input->stream.stream_lock );
- //setupMenus();
+ vlc_mutex_lock( &p_input->stream.stream_lock );
- vlc_mutex_unlock( &p_intf->p_sys->p_input->stream.stream_lock );
+ vlc_mutex_unlock( &p_input->stream.stream_lock );
}
}
void Intf_VLCWrapper::toggleChapter(int i_chapter)
{
- if( p_intf->p_sys->p_input != NULL )
+ if( p_input != NULL )
{
- p_intf->p_sys->p_input->stream.p_selected_area->i_part = i_chapter;
- input_ChangeArea( p_intf->p_sys->p_input,
- p_intf->p_sys->p_input->stream.p_selected_area );
+ p_input->stream.p_selected_area->i_part = i_chapter;
+ input_ChangeArea( p_input,
+ p_input->stream.p_selected_area );
- vlc_mutex_lock( &p_intf->p_sys->p_input->stream.stream_lock );
-// setupMenus();
- vlc_mutex_unlock( &p_intf->p_sys->p_input->stream.stream_lock );
+ vlc_mutex_lock( &p_input->stream.stream_lock );
+ vlc_mutex_unlock( &p_input->stream.stream_lock );
}
}
int32 i_old = -1;
int i_cat = AUDIO_ES;
- vlc_mutex_lock( &p_intf->p_sys->p_input->stream.stream_lock );
- for( int i = 0; i < p_intf->p_sys->p_input->stream.i_selected_es_number ; i++ )
+ vlc_mutex_lock( &p_input->stream.stream_lock );
+ for( int i = 0; i < p_input->stream.i_selected_es_number ; i++ )
{
- if( p_intf->p_sys->p_input->stream.pp_selected_es[i]->i_cat == i_cat )
+ if( p_input->stream.pp_selected_es[i]->i_cat == i_cat )
{
i_old = i;
break;
}
}
- vlc_mutex_unlock( &p_intf->p_sys->p_input->stream.stream_lock );
+ vlc_mutex_unlock( &p_input->stream.stream_lock );
msg_Info( p_intf, "Old: %d, New: %d", i_old, i_language);
if( i_language != -1 )
{
- input_ToggleES( p_intf->p_sys->p_input,
- p_intf->p_sys->p_input->stream.pp_selected_es[i_language],
+ input_ToggleES( p_input,
+ p_input->stream.pp_selected_es[i_language],
VLC_TRUE );
}
if( (i_old != -1) && (i_old != i_language) )
{
- input_ToggleES( p_intf->p_sys->p_input,
- p_intf->p_sys->p_input->stream.pp_selected_es[i_old],
+ input_ToggleES( p_input,
+ p_input->stream.pp_selected_es[i_old],
VLC_FALSE );
}
}
int32 i_old = -1;
int i_cat = SPU_ES;
- vlc_mutex_lock( &p_intf->p_sys->p_input->stream.stream_lock );
- for( int i = 0; i < p_intf->p_sys->p_input->stream.i_selected_es_number ; i++ )
+ vlc_mutex_lock( &p_input->stream.stream_lock );
+ for( int i = 0; i < p_input->stream.i_selected_es_number ; i++ )
{
- if( p_intf->p_sys->p_input->stream.pp_selected_es[i]->i_cat == i_cat )
+ if( p_input->stream.pp_selected_es[i]->i_cat == i_cat )
{
i_old = i;
break;
}
}
- vlc_mutex_unlock( &p_intf->p_sys->p_input->stream.stream_lock );
+ vlc_mutex_unlock( &p_input->stream.stream_lock );
msg_Info( p_intf, "Old: %d, New: %d", i_old, i_subtitle);
if( i_subtitle != -1 )
{
- input_ToggleES( p_intf->p_sys->p_input,
- p_intf->p_sys->p_input->stream.pp_selected_es[i_subtitle],
+ input_ToggleES( p_input,
+ p_input->stream.pp_selected_es[i_subtitle],
VLC_TRUE );
}
if( (i_old != -1) && (i_old != i_subtitle) )
{
- input_ToggleES( p_intf->p_sys->p_input,
- p_intf->p_sys->p_input->stream.pp_selected_es[i_old],
+ input_ToggleES( p_input,
+ p_input->stream.pp_selected_es[i_old],
VLC_FALSE );
}
}
-
-void Intf_VLCWrapper::setupMenus(){}
-int Intf_VLCWrapper::inputGetStatus() {}
+int Intf_VLCWrapper::inputGetStatus()
+{
+ return p_playlist->i_status;
+}