Commit e94bb0dd authored by Yoann Peronneau's avatar Yoann Peronneau

* modules/gui/ncurses.c: incremental search works now with tree playlist.

parent 5de2de98
...@@ -82,6 +82,7 @@ static int PlaylistChanged( vlc_object_t *, const char *, vlc_value_t, ...@@ -82,6 +82,7 @@ static int PlaylistChanged( vlc_object_t *, const char *, vlc_value_t,
vlc_value_t, void * ); vlc_value_t, void * );
static void FindIndex ( intf_thread_t * ); static void FindIndex ( intf_thread_t * );
static void SearchPlaylist ( intf_thread_t *, char * ); static void SearchPlaylist ( intf_thread_t *, char * );
static int SubSearchPlaylist( intf_thread_t *, char *, int, int );
static void ManageSlider ( intf_thread_t * ); static void ManageSlider ( intf_thread_t * );
static void ReadDir ( intf_thread_t * ); static void ReadDir ( intf_thread_t * );
...@@ -968,15 +969,16 @@ static void ManageSlider( intf_thread_t *p_intf ) ...@@ -968,15 +969,16 @@ static void ManageSlider( intf_thread_t *p_intf )
static void SearchPlaylist( intf_thread_t *p_intf, char *psz_searchstring ) static void SearchPlaylist( intf_thread_t *p_intf, char *psz_searchstring )
{ {
bool b_ok = false; int i_max;
int i_current;
int i_first = 0 ; int i_first = 0 ;
int i_item = -1; int i_item = -1;
intf_sys_t *p_sys = p_intf->p_sys; intf_sys_t *p_sys = p_intf->p_sys;
playlist_t *p_playlist = p_sys->p_playlist; playlist_t *p_playlist = p_sys->p_playlist;
if( p_sys->i_before_search >= 0 ) if( p_sys->i_before_search >= 0 )
{
i_first = p_sys->i_before_search; i_first = p_sys->i_before_search;
}
if( ( ! psz_searchstring ) || strlen( psz_searchstring ) <= 0 ) if( ( ! psz_searchstring ) || strlen( psz_searchstring ) <= 0 )
{ {
...@@ -984,38 +986,55 @@ static void SearchPlaylist( intf_thread_t *p_intf, char *psz_searchstring ) ...@@ -984,38 +986,55 @@ static void SearchPlaylist( intf_thread_t *p_intf, char *psz_searchstring )
return; return;
} }
for( i_current = i_first + 1; i_current < p_playlist->i_size; i_max = p_sys->i_current_view == VIEW_ALL ?
i_current++ ) p_playlist->i_size : p_sys->i_plist_entries;
i_item = SubSearchPlaylist( p_intf, psz_searchstring, i_first + 1, i_max );
if( i_item < 0 )
{ {
if( strcasestr( p_playlist->pp_items[i_current]->input.psz_name, i_item = SubSearchPlaylist( p_intf, psz_searchstring, 0, i_first );
psz_searchstring ) != NULL
|| strcasestr( p_playlist->pp_items[i_current]->input.psz_uri,
psz_searchstring ) != NULL )
{
i_item = i_current;
b_ok = true;
break;
}
} }
if( !b_ok )
if( i_item < 0 || i_item >= i_max ) return;
p_sys->i_box_plidx = i_item;
}
static int SubSearchPlaylist( intf_thread_t *p_intf, char *psz_searchstring,
int i_start, int i_stop )
{
intf_sys_t *p_sys = p_intf->p_sys;
playlist_t *p_playlist = p_sys->p_playlist;
int i, i_item = -1;
if( p_sys->i_current_view == VIEW_ALL )
{ {
for( i_current = 0; i_current < i_first; i_current++ ) for( i = i_start + 1; i < i_stop; i++ )
{ {
if( strcasestr( p_playlist->pp_items[i_current]->input.psz_name, if( strcasestr( p_playlist->pp_items[i]->input.psz_name,
psz_searchstring ) != NULL psz_searchstring ) != NULL
|| strcasestr( p_playlist->pp_items[i_current]->input.psz_uri, || strcasestr( p_playlist->pp_items[i]->input.psz_uri,
psz_searchstring ) != NULL ) psz_searchstring ) != NULL )
{ {
i_item = i_current; i_item = i;
b_ok = true; break;
}
}
}
else
{
for( i = i_start + 1; i < i_stop; i++ )
{
if( strcasestr( p_sys->pp_plist[i]->psz_display,
psz_searchstring ) != NULL )
{
i_item = i;
break; break;
} }
} }
} }
if( i_item < 0 || i_item >= p_playlist->i_size ) return; return i_item;
p_sys->i_box_plidx = i_item;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment