Commit 69731466 authored by David Fuhrmann's avatar David Fuhrmann

macosx: select currently played item

And expand outline view tree if necessary.
parent e11d1337
...@@ -80,6 +80,8 @@ typedef enum { ...@@ -80,6 +80,8 @@ typedef enum {
- (void)addItem:(int)i_item withParentNode:(int)i_node; - (void)addItem:(int)i_item withParentNode:(int)i_node;
- (void)removeItem:(int)i_item; - (void)removeItem:(int)i_item;
- (PLItem *)currentlyPlayingItem;
- (void)sortForColumn:(NSString *)o_column withMode:(int)i_mode; - (void)sortForColumn:(NSString *)o_column withMode:(int)i_mode;
- (void)searchUpdate:(NSString *)o_search; - (void)searchUpdate:(NSString *)o_search;
......
...@@ -199,6 +199,18 @@ ...@@ -199,6 +199,18 @@
[_outlineView reloadItem:o_parent reloadChildren:YES]; [_outlineView reloadItem:o_parent reloadChildren:YES];
} }
- (PLItem *)currentlyPlayingItem
{
PLItem *item = nil;
PL_LOCK;
playlist_item_t *p_current = playlist_CurrentPlayingItem(p_playlist);
if (p_current)
item = [self findItemByPlaylistId:p_current->i_id];
PL_UNLOCK;
return item;
}
- (void)sortForColumn:(NSString *)o_column withMode:(int)i_mode - (void)sortForColumn:(NSString *)o_column withMode:(int)i_mode
{ {
int i_column = 0; int i_column = 0;
......
...@@ -1356,6 +1356,8 @@ static bool f_appExit = false; ...@@ -1356,6 +1356,8 @@ static bool f_appExit = false;
p_input_changed = vlc_object_hold(p_current_input); p_input_changed = vlc_object_hold(p_current_input);
[[self playlist] currentlyPlayingItemChanged];
[[self playlist] continuePlaybackWhereYouLeftOff:p_current_input]; [[self playlist] continuePlaybackWhereYouLeftOff:p_current_input];
[[NSNotificationCenter defaultCenter] postNotificationName:VLCInputChangedNotification [[NSNotificationCenter defaultCenter] postNotificationName:VLCInputChangedNotification
...@@ -1363,7 +1365,6 @@ static bool f_appExit = false; ...@@ -1363,7 +1365,6 @@ static bool f_appExit = false;
} }
} }
[o_playlist updateRowSelection];
[o_mainwindow updateWindow]; [o_mainwindow updateWindow];
[self updateDelays]; [self updateDelays];
[self updateMainMenu]; [self updateMainMenu];
......
...@@ -91,7 +91,8 @@ ...@@ -91,7 +91,8 @@
- (void)playlistUpdated; - (void)playlistUpdated;
- (void)outlineViewSelectionDidChange:(NSNotification *)notification; - (void)outlineViewSelectionDidChange:(NSNotification *)notification;
- (void)sortNode:(int)i_mode; - (void)sortNode:(int)i_mode;
- (void)updateRowSelection;
- (void)currentlyPlayingItemChanged;
- (BOOL)isSelectionEmpty; - (BOOL)isSelectionEmpty;
......
...@@ -354,42 +354,36 @@ ...@@ -354,42 +354,36 @@
return [o_outline_view selectedRow] == -1; return [o_outline_view selectedRow] == -1;
} }
- (void)updateRowSelection - (void)currentlyPlayingItemChanged
{ {
// FIXME: unsafe PLItem *item = [[self model] currentlyPlayingItem];
playlist_t *p_playlist = pl_Get(VLCIntf); if (!item)
playlist_item_t *p_item, *p_temp_item; return;
NSMutableArray *o_array = [NSMutableArray array];
// TODO Rework [[[VLCMain sharedInstance] info] updatePanelWithItem: [item input]];
// PL_LOCK;
// p_item = playlist_CurrentPlayingItem(p_playlist); // select item
// if (p_item == NULL) { NSInteger itemIndex = [o_outline_view rowForItem:item];
// PL_UNLOCK; if (itemIndex < 0) {
// return; // expand if needed
// } while (item != nil) {
// PLItem *parent = [item parent];
// p_temp_item = p_item;
// while(p_temp_item->p_parent) { if (![o_outline_view isExpandable: parent])
// [o_array insertObject: [NSValue valueWithPointer: p_temp_item] atIndex: 0]; break;
// p_temp_item = p_temp_item->p_parent; if (![o_outline_view isItemExpanded: parent])
// } [o_outline_view expandItem: parent];
// PL_UNLOCK; item = parent;
// }
// NSUInteger count = [o_array count];
// for (NSUInteger j = 0; j < count - 1; j++) { // search for row again
// id o_item; itemIndex = [o_outline_view rowForItem:item];
// if ((o_item = [o_outline_dict objectForKey: if (itemIndex < 0) {
// [NSString stringWithFormat: @"%p", return;
// [[o_array objectAtIndex:j] pointerValue]]]) != nil) { }
// [o_outline_view expandItem: o_item]; }
// }
// } [o_outline_view selectRowIndexes: [NSIndexSet indexSetWithIndex: itemIndex] byExtendingSelection: NO];
//
// id o_item = [o_outline_dict objectForKey:[NSString stringWithFormat: @"%p", p_item]];
// NSInteger i_index = [o_outline_view rowForItem:o_item];
// [o_outline_view selectRowIndexes:[NSIndexSet indexSetWithIndex:i_index] byExtendingSelection:NO];
// [o_outline_view setNeedsDisplay:YES];
} }
- (IBAction)savePlaylist:(id)sender - (IBAction)savePlaylist:(id)sender
......
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