diff --git a/modules/gui/macosx/main/VLCMain.m b/modules/gui/macosx/main/VLCMain.m index a141edaef7dc315a1ff356c2bd07acb4bd4701bb..06e67967b31a4a5f67b895ca10fdeef09450555c 100644 --- a/modules/gui/macosx/main/VLCMain.m +++ b/modules/gui/macosx/main/VLCMain.m @@ -295,14 +295,6 @@ static VLCMain *sharedInstance = nil; return self; } -- (void)dealloc -{ - msg_Dbg(getIntf(), "Deinitializing VLCMain object"); - - /* have the playlist controller explicitly unsubscribe from events prior to its deallocation */ - [_playlistController deinitialize]; -} - - (void)applicationWillFinishLaunching:(NSNotification *)aNotification { _clickerManager = [[VLCClickerManager alloc] init]; diff --git a/modules/gui/macosx/playlist/VLCPlayerController.h b/modules/gui/macosx/playlist/VLCPlayerController.h index ea06f8148211661b2264bdd957496649a9e73f1f..711f59e5dd9d4b9d9304bbe10684725c7e077f48 100644 --- a/modules/gui/macosx/playlist/VLCPlayerController.h +++ b/modules/gui/macosx/playlist/VLCPlayerController.h @@ -230,7 +230,6 @@ extern NSString *VLCPlayerMuteChanged; @interface VLCPlayerController : NSObject - (instancetype)initWithPlayer:(vlc_player_t *)player; -- (void)deinitialize; /** * Start playback of the current media diff --git a/modules/gui/macosx/playlist/VLCPlayerController.m b/modules/gui/macosx/playlist/VLCPlayerController.m index 49833a538cbe62478de17ee204fb052b57783ecc..d6526f25d1d4ab8fec17a05b66348e376c26c6e6 100644 --- a/modules/gui/macosx/playlist/VLCPlayerController.m +++ b/modules/gui/macosx/playlist/VLCPlayerController.m @@ -533,6 +533,10 @@ static const struct vlc_player_aout_cbs player_aout_callbacks = { self = [super init]; if (self) { _defaultNotificationCenter = [NSNotificationCenter defaultCenter]; + [_defaultNotificationCenter addObserver:self + selector:@selector(applicationWillTerminate:) + name:NSApplicationWillTerminateNotification + object:nil]; _position = -1.f; _time = VLC_TICK_INVALID; _p_player = player; @@ -557,7 +561,7 @@ static const struct vlc_player_aout_cbs player_aout_callbacks = { return self; } -- (void)deinitialize +- (void)applicationWillTerminate:(NSNotification *)aNotification { [self onPlaybackHasTruelyEnded:nil]; if (@available(macOS 10.12.2, *)) { @@ -581,6 +585,11 @@ static const struct vlc_player_aout_cbs player_aout_callbacks = { } } +- (void)dealloc +{ + [_defaultNotificationCenter removeObserver:self]; +} + #pragma mark - playback control methods - (int)start diff --git a/modules/gui/macosx/playlist/VLCPlaylistController.h b/modules/gui/macosx/playlist/VLCPlaylistController.h index 639e5f245939436f4d34b8f750f928fd69a7faa7..908aaafa5ad6458fb5bb5c007c39c7e95b95cdf7 100644 --- a/modules/gui/macosx/playlist/VLCPlaylistController.h +++ b/modules/gui/macosx/playlist/VLCPlaylistController.h @@ -41,7 +41,6 @@ extern NSString *VLCPlaylistItemsRemoved; @interface VLCPlaylistController : NSObject - (instancetype)initWithPlaylist:(vlc_playlist_t *)playlist; -- (void)deinitialize; /** * The vlc core playlist controlled by the instance of this class diff --git a/modules/gui/macosx/playlist/VLCPlaylistController.m b/modules/gui/macosx/playlist/VLCPlaylistController.m index 49b05714da0435c6b2b0160a19be491660e426b9..5b90df74c59a9feba651d9d87cecd4ec61c6d8a3 100644 --- a/modules/gui/macosx/playlist/VLCPlaylistController.m +++ b/modules/gui/macosx/playlist/VLCPlaylistController.m @@ -201,6 +201,10 @@ static const struct vlc_playlist_callbacks playlist_callbacks = { self = [super init]; if (self) { _defaultNotificationCenter = [NSNotificationCenter defaultCenter]; + [_defaultNotificationCenter addObserver:self + selector:@selector(applicationWillTerminate:) + name:NSApplicationWillTerminateNotification + object:nil]; _p_playlist = playlist; /* set initial values, further updates through callbacks */ @@ -219,12 +223,8 @@ static const struct vlc_playlist_callbacks playlist_callbacks = { return self; } -- (void)deinitialize +- (void)applicationWillTerminate:(NSNotification *)aNotification { - if (_playerController) { - [_playerController deinitialize]; - } - if (_p_playlist) { if (_playlistListenerID) { vlc_playlist_Lock(_p_playlist); @@ -234,6 +234,11 @@ static const struct vlc_playlist_callbacks playlist_callbacks = { } } +- (void)dealloc +{ + [_defaultNotificationCenter removeObserver:self]; +} + #pragma mark - callback forwarders - (void)playlistResetWithItems:(NSArray *)items