diff --git a/extras/package/macosx/VLC.xcodeproj/project.pbxproj b/extras/package/macosx/VLC.xcodeproj/project.pbxproj
index a8b5713f7dce3290dab35cee075e09ae18529b60..fc497df09a2bd26c3ab25f06d84b8919728c1550 100644
--- a/extras/package/macosx/VLC.xcodeproj/project.pbxproj
+++ b/extras/package/macosx/VLC.xcodeproj/project.pbxproj
@@ -36,8 +36,6 @@
 		1C3113C51E508C6900D4DD76 /* misc.m in Sources */ = {isa = PBXBuildFile; fileRef = 8ED6C28003E2EB1C0059A3A7 /* misc.m */; };
 		1C3113C71E508C6900D4DD76 /* VLCOpenWindowController.m in Sources */ = {isa = PBXBuildFile; fileRef = 8ED6C28203E2EB1C0059A3A7 /* VLCOpenWindowController.m */; };
 		1C3113C91E508C6900D4DD76 /* VLCOutput.m in Sources */ = {isa = PBXBuildFile; fileRef = 8E55FB800459B0FD00FB3317 /* VLCOutput.m */; };
-		1C3113CB1E508C6900D4DD76 /* VLCPLItem.m in Sources */ = {isa = PBXBuildFile; fileRef = 7DF812F21B5599E40052293C /* VLCPLItem.m */; };
-		1C3113CD1E508C6900D4DD76 /* VLCPLModel.m in Sources */ = {isa = PBXBuildFile; fileRef = 7DF812F41B5599E40052293C /* VLCPLModel.m */; };
 		1C3113CF1E508C6900D4DD76 /* prefs_widgets.m in Sources */ = {isa = PBXBuildFile; fileRef = 8E9CA1A406D7DEE800B7186C /* prefs_widgets.m */; };
 		1C3113D11E508C6900D4DD76 /* prefs.m in Sources */ = {isa = PBXBuildFile; fileRef = 8ED6C28603E2EB1C0059A3A7 /* prefs.m */; };
 		1C3113D31E508C6900D4DD76 /* VLCResumeDialogController.m in Sources */ = {isa = PBXBuildFile; fileRef = 633121CB1B51122700E636DA /* VLCResumeDialogController.m */; };
@@ -47,9 +45,7 @@
 		1C3113DD1E508C6900D4DD76 /* VLCTrackSynchronizationWindowController.m in Sources */ = {isa = PBXBuildFile; fileRef = CC707EC4137464CD0003010A /* VLCTrackSynchronizationWindowController.m */; };
 		1C3113DF1E508C6900D4DD76 /* VLCVideoEffectsWindowController.m in Sources */ = {isa = PBXBuildFile; fileRef = CCCE366E13817E4500694F2A /* VLCVideoEffectsWindowController.m */; };
 		1C3113E11E508C6900D4DD76 /* VLCVoutView.m in Sources */ = {isa = PBXBuildFile; fileRef = CCCCDCA11413E1C000FE3DE1 /* VLCVoutView.m */; };
-		1C3113E31E508C6900D4DD76 /* VLCPlaylist.m in Sources */ = {isa = PBXBuildFile; fileRef = 8ED6C28403E2EB1C0059A3A7 /* VLCPlaylist.m */; };
 		1C3113E51E508C6900D4DD76 /* VLCPlaylistInfo.m in Sources */ = {isa = PBXBuildFile; fileRef = 8E49720106417F6800370C9F /* VLCPlaylistInfo.m */; };
-		1C3113E71E508C6900D4DD76 /* VLCPlaylistView.m in Sources */ = {isa = PBXBuildFile; fileRef = 7DA481231B5FC13700917FD7 /* VLCPlaylistView.m */; };
 		1C3113E91E508C6900D4DD76 /* VLCScrollingClipView.m in Sources */ = {isa = PBXBuildFile; fileRef = 6B13E2A71BC67678001AD24A /* VLCScrollingClipView.m */; };
 		1C3113ED1E508C6900D4DD76 /* VLCTimeSelectionPanelController.m in Sources */ = {isa = PBXBuildFile; fileRef = 1CD3667A1B7A242E0054E39F /* VLCTimeSelectionPanelController.m */; };
 		1C3113EF1E508C7600D4DD76 /* VLCRendererDiscovery.m in Sources */ = {isa = PBXBuildFile; fileRef = 6BBBB8B61D114628001BD9BA /* VLCRendererDiscovery.m */; };
@@ -78,7 +74,6 @@
 		1CCC88FC2078A3D500E5626F /* LogMessageWindow.xib in Sources */ = {isa = PBXBuildFile; fileRef = 6B8224081E4D2A9000833BE1 /* LogMessageWindow.xib */; };
 		1CCC88FD2078A3D500E5626F /* Open.xib in Sources */ = {isa = PBXBuildFile; fileRef = 6B82240C1E4D2A9000833BE1 /* Open.xib */; };
 		1CCC88FE2078A3D500E5626F /* PlaylistAccessoryView.xib in Sources */ = {isa = PBXBuildFile; fileRef = 6B82240D1E4D2A9000833BE1 /* PlaylistAccessoryView.xib */; };
-		1CCC88FF2078A3D500E5626F /* PlaylistMenu.xib in Sources */ = {isa = PBXBuildFile; fileRef = 6B82240E1E4D2A9000833BE1 /* PlaylistMenu.xib */; };
 		1CCC89002078A3D500E5626F /* PopupPanel.xib in Sources */ = {isa = PBXBuildFile; fileRef = 6B82240F1E4D2A9000833BE1 /* PopupPanel.xib */; };
 		1CCC89012078A3D500E5626F /* Preferences.xib in Sources */ = {isa = PBXBuildFile; fileRef = 6B8224101E4D2A9000833BE1 /* Preferences.xib */; };
 		1CCC89022078A3D500E5626F /* ResumeDialog.xib in Sources */ = {isa = PBXBuildFile; fileRef = 6B8224111E4D2A9000833BE1 /* ResumeDialog.xib */; };
@@ -239,7 +234,6 @@
 		6B82240B1E4D2A9000833BE1 /* MediaInfo.xib */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.xib; path = MediaInfo.xib; sourceTree = "<group>"; };
 		6B82240C1E4D2A9000833BE1 /* Open.xib */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.xib; path = Open.xib; sourceTree = "<group>"; };
 		6B82240D1E4D2A9000833BE1 /* PlaylistAccessoryView.xib */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.xib; path = PlaylistAccessoryView.xib; sourceTree = "<group>"; };
-		6B82240E1E4D2A9000833BE1 /* PlaylistMenu.xib */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.xib; path = PlaylistMenu.xib; sourceTree = "<group>"; };
 		6B82240F1E4D2A9000833BE1 /* PopupPanel.xib */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.xib; path = PopupPanel.xib; sourceTree = "<group>"; };
 		6B8224101E4D2A9000833BE1 /* Preferences.xib */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.xib; path = Preferences.xib; sourceTree = "<group>"; };
 		6B8224111E4D2A9000833BE1 /* ResumeDialog.xib */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.xib; path = ResumeDialog.xib; sourceTree = "<group>"; };
@@ -484,8 +478,6 @@
 		7D871D391B5E684D000B56C0 /* helpers.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = helpers.h; sourceTree = "<group>"; };
 		7D8BB0B318302AC000FAE9B7 /* VLCLogWindowController.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = VLCLogWindowController.h; sourceTree = "<group>"; };
 		7D8BB0B418302AC000FAE9B7 /* VLCLogWindowController.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = VLCLogWindowController.m; sourceTree = "<group>"; };
-		7DA481221B5FC13700917FD7 /* VLCPlaylistView.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = VLCPlaylistView.h; sourceTree = "<group>"; };
-		7DA481231B5FC13700917FD7 /* VLCPlaylistView.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = VLCPlaylistView.m; sourceTree = "<group>"; };
 		7DB40D2820CBCEB500F63173 /* VLCMainMenu.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = VLCMainMenu.h; sourceTree = "<group>"; };
 		7DB40D2920CBCEB500F63173 /* VLCMainMenu.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = VLCMainMenu.m; sourceTree = "<group>"; };
 		7DB40D2B20CBCEC200F63173 /* VLCStatusBarIcon.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = VLCStatusBarIcon.m; sourceTree = "<group>"; };
@@ -520,10 +512,6 @@
 		7DF812EE1B555A340052293C /* VLCInputManager.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = VLCInputManager.m; sourceTree = "<group>"; };
 		7DF812EF1B555C8E0052293C /* VLCKeyboardBacklightControl.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = VLCKeyboardBacklightControl.h; sourceTree = "<group>"; };
 		7DF812F01B555C8E0052293C /* VLCKeyboardBacklightControl.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = VLCKeyboardBacklightControl.m; sourceTree = "<group>"; };
-		7DF812F11B5599E40052293C /* VLCPLItem.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = VLCPLItem.h; sourceTree = "<group>"; };
-		7DF812F21B5599E40052293C /* VLCPLItem.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = VLCPLItem.m; sourceTree = "<group>"; };
-		7DF812F31B5599E40052293C /* VLCPLModel.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = VLCPLModel.h; sourceTree = "<group>"; };
-		7DF812F41B5599E40052293C /* VLCPLModel.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = VLCPLModel.m; sourceTree = "<group>"; };
 		8E49720006417F6800370C9F /* VLCPlaylistInfo.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = VLCPlaylistInfo.h; sourceTree = "<group>"; };
 		8E49720106417F6800370C9F /* VLCPlaylistInfo.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = VLCPlaylistInfo.m; sourceTree = "<group>"; };
 		8E55FB7F0459B0FD00FB3317 /* VLCOutput.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = VLCOutput.h; sourceTree = "<group>"; };
@@ -539,8 +527,6 @@
 		8ED6C28003E2EB1C0059A3A7 /* misc.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = misc.m; sourceTree = "<group>"; };
 		8ED6C28103E2EB1C0059A3A7 /* VLCOpenWindowController.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = VLCOpenWindowController.h; sourceTree = "<group>"; };
 		8ED6C28203E2EB1C0059A3A7 /* VLCOpenWindowController.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = VLCOpenWindowController.m; sourceTree = "<group>"; };
-		8ED6C28303E2EB1C0059A3A7 /* VLCPlaylist.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = VLCPlaylist.h; sourceTree = "<group>"; };
-		8ED6C28403E2EB1C0059A3A7 /* VLCPlaylist.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = VLCPlaylist.m; sourceTree = "<group>"; };
 		8ED6C28503E2EB1C0059A3A7 /* prefs.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = prefs.h; sourceTree = "<group>"; };
 		8ED6C28603E2EB1C0059A3A7 /* prefs.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = prefs.m; sourceTree = "<group>"; };
 		CC0663341566C34C003A411C /* VLCConvertAndSaveWindowController.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; lineEnding = 0; path = VLCConvertAndSaveWindowController.h; sourceTree = "<group>"; };
@@ -1195,8 +1181,6 @@
 		7D349C9520CBC823003359A1 /* Playlist */ = {
 			isa = PBXGroup;
 			children = (
-				7DB317A320CBCA9500673FB8 /* Controller */,
-				7DB317A120CBCA8500673FB8 /* Model */,
 				7DB317A220CBCA8B00673FB8 /* View */,
 			);
 			name = Playlist;
@@ -1360,37 +1344,15 @@
 			name = "Library Window";
 			sourceTree = "<group>";
 		};
-		7DB317A120CBCA8500673FB8 /* Model */ = {
-			isa = PBXGroup;
-			children = (
-				7DF812F11B5599E40052293C /* VLCPLItem.h */,
-				7DF812F21B5599E40052293C /* VLCPLItem.m */,
-				7DF812F31B5599E40052293C /* VLCPLModel.h */,
-				7DF812F41B5599E40052293C /* VLCPLModel.m */,
-			);
-			name = Model;
-			sourceTree = "<group>";
-		};
 		7DB317A220CBCA8B00673FB8 /* View */ = {
 			isa = PBXGroup;
 			children = (
 				8E49720006417F6800370C9F /* VLCPlaylistInfo.h */,
 				8E49720106417F6800370C9F /* VLCPlaylistInfo.m */,
-				7DA481221B5FC13700917FD7 /* VLCPlaylistView.h */,
-				7DA481231B5FC13700917FD7 /* VLCPlaylistView.m */,
 			);
 			name = View;
 			sourceTree = "<group>";
 		};
-		7DB317A320CBCA9500673FB8 /* Controller */ = {
-			isa = PBXGroup;
-			children = (
-				8ED6C28303E2EB1C0059A3A7 /* VLCPlaylist.h */,
-				8ED6C28403E2EB1C0059A3A7 /* VLCPlaylist.m */,
-			);
-			name = Controller;
-			sourceTree = "<group>";
-		};
 		7DB317A420CBCAAD00673FB8 /* Advanced */ = {
 			isa = PBXGroup;
 			children = (
@@ -1597,7 +1559,6 @@
 				6B8224081E4D2A9000833BE1 /* LogMessageWindow.xib */,
 				6B82240C1E4D2A9000833BE1 /* Open.xib */,
 				6B82240D1E4D2A9000833BE1 /* PlaylistAccessoryView.xib */,
-				6B82240E1E4D2A9000833BE1 /* PlaylistMenu.xib */,
 				6B82240F1E4D2A9000833BE1 /* PopupPanel.xib */,
 				6B8224101E4D2A9000833BE1 /* Preferences.xib */,
 				6B8224111E4D2A9000833BE1 /* ResumeDialog.xib */,
@@ -1694,7 +1655,6 @@
 				1CCC88FC2078A3D500E5626F /* LogMessageWindow.xib in Sources */,
 				1CCC88FD2078A3D500E5626F /* Open.xib in Sources */,
 				1CCC88FE2078A3D500E5626F /* PlaylistAccessoryView.xib in Sources */,
-				1CCC88FF2078A3D500E5626F /* PlaylistMenu.xib in Sources */,
 				1CCC89002078A3D500E5626F /* PopupPanel.xib in Sources */,
 				1CCC89012078A3D500E5626F /* Preferences.xib in Sources */,
 				7DC21A7422049A6600F98A02 /* VLCOpenInputMetadata.m in Sources */,
@@ -1769,10 +1729,8 @@
 				1C3113C91E508C6900D4DD76 /* VLCOutput.m in Sources */,
 				1C1C62011F8260A90052DD4F /* VLCWrappableTextField.m in Sources */,
 				6BBB05DA1EEFEA29003A1019 /* VLCHUDOutlineView.m in Sources */,
-				1C3113CB1E508C6900D4DD76 /* VLCPLItem.m in Sources */,
 				6B8A6B0B2128697E00DC29F3 /* VLCSourceListTableCellView.m in Sources */,
 				7D445D842202524D00263D34 /* VLCPlaylistItem.m in Sources */,
-				1C3113CD1E508C6900D4DD76 /* VLCPLModel.m in Sources */,
 				1C3113CF1E508C6900D4DD76 /* prefs_widgets.m in Sources */,
 				7D0F63FF2201F63400FDB91F /* VLCPlaylistTableCellView.m in Sources */,
 				1C3113D11E508C6900D4DD76 /* prefs.m in Sources */,
@@ -1794,9 +1752,7 @@
 				6B6FFF701EF9EC350001CEB1 /* CompatibilityFixes.m in Sources */,
 				1C3113DF1E508C6900D4DD76 /* VLCVideoEffectsWindowController.m in Sources */,
 				1C3113E11E508C6900D4DD76 /* VLCVoutView.m in Sources */,
-				1C3113E31E508C6900D4DD76 /* VLCPlaylist.m in Sources */,
 				1C3113E51E508C6900D4DD76 /* VLCPlaylistInfo.m in Sources */,
-				1C3113E71E508C6900D4DD76 /* VLCPlaylistView.m in Sources */,
 				6B7F1FDF1F07DA920002BDD8 /* VLCHexNumberFormatter.m in Sources */,
 				7DB40D2A20CBCEB500F63173 /* VLCMainMenu.m in Sources */,
 				1C3113E91E508C6900D4DD76 /* VLCScrollingClipView.m in Sources */,
diff --git a/modules/gui/macosx/Makefile.am b/modules/gui/macosx/Makefile.am
index 920135187652a6ac1e746168d7e3a8aa37c84b91..98e0e24f54bdc7e4104ef3426e23a6aab59bcc33 100644
--- a/modules/gui/macosx/Makefile.am
+++ b/modules/gui/macosx/Makefile.am
@@ -57,11 +57,7 @@ libmacosx_plugin_la_SOURCES = \
 	gui/macosx/VLCOpenWindowController.h gui/macosx/VLCOpenWindowController.m \
 	gui/macosx/VLCOpenInputMetadata.h gui/macosx/VLCOpenInputMetadata.m \
 	gui/macosx/VLCOutput.h gui/macosx/VLCOutput.m \
-	gui/macosx/VLCPlaylistView.h gui/macosx/VLCPlaylistView.m \
-	gui/macosx/VLCPlaylist.h gui/macosx/VLCPlaylist.m \
 	gui/macosx/VLCPlaylistInfo.h gui/macosx/VLCPlaylistInfo.m \
-	gui/macosx/VLCPLItem.h gui/macosx/VLCPLItem.m \
-	gui/macosx/VLCPLModel.h gui/macosx/VLCPLModel.m \
 	gui/macosx/prefs.h gui/macosx/prefs.m \
 	gui/macosx/prefs_widgets.h gui/macosx/prefs_widgets.m \
 	gui/macosx/VLCPopupPanelController.h gui/macosx/VLCPopupPanelController.m \
@@ -165,7 +161,6 @@ libmacosx_plugin_la_XIB_SOURCES = \
 	gui/macosx/UI/MediaInfo.xib \
 	gui/macosx/UI/Open.xib \
 	gui/macosx/UI/PlaylistAccessoryView.xib \
-	gui/macosx/UI/PlaylistMenu.xib \
 	gui/macosx/UI/PopupPanel.xib \
 	gui/macosx/UI/Preferences.xib \
 	gui/macosx/UI/ResumeDialog.xib \
diff --git a/modules/gui/macosx/UI/MainWindow.xib b/modules/gui/macosx/UI/MainWindow.xib
index c0823b2ffc3bf03220a0f87687d0b0a55d4b3c8d..e6b2f1b09e65078d0ea19158514ac1b950b60b50 100644
--- a/modules/gui/macosx/UI/MainWindow.xib
+++ b/modules/gui/macosx/UI/MainWindow.xib
@@ -1,8 +1,8 @@
 <?xml version="1.0" encoding="UTF-8"?>
-<document type="com.apple.InterfaceBuilder3.Cocoa.XIB" version="3.0" toolsVersion="14313.13.2" targetRuntime="MacOSX.Cocoa" propertyAccessControl="none" useAutolayout="YES">
+<document type="com.apple.InterfaceBuilder3.Cocoa.XIB" version="3.0" toolsVersion="14460.31" targetRuntime="MacOSX.Cocoa" propertyAccessControl="none" useAutolayout="YES">
     <dependencies>
         <deployment identifier="macosx"/>
-        <plugIn identifier="com.apple.InterfaceBuilder.CocoaPlugin" version="14313.13.2"/>
+        <plugIn identifier="com.apple.InterfaceBuilder.CocoaPlugin" version="14460.31"/>
         <capability name="documents saved in the Xcode 8 format" minToolsVersion="8.0"/>
     </dependencies>
     <objects>
@@ -270,55 +270,11 @@
                                                             <constraint firstAttribute="bottom" secondItem="5605" secondAttribute="bottom" id="fdA-1r-rKk"/>
                                                         </constraints>
                                                     </customView>
-                                                    <scrollView focusRingType="none" autohidesScrollers="YES" horizontalLineScroll="17" horizontalPageScroll="10" verticalLineScroll="17" verticalPageScroll="10" usesPredominantAxisScrolling="NO" translatesAutoresizingMaskIntoConstraints="NO" id="4372">
-                                                        <rect key="frame" x="0.0" y="0.0" width="477" height="274"/>
-                                                        <clipView key="contentView" id="wTX-wO-asx">
-                                                            <rect key="frame" x="1" y="0.0" width="475" height="273"/>
-                                                            <autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/>
-                                                            <subviews>
-                                                                <outlineView focusRingType="none" verticalHuggingPriority="750" allowsExpansionToolTips="YES" columnAutoresizingStyle="reverseSequential" alternatingRowBackgroundColors="YES" autosaveColumns="NO" rowHeight="15" headerView="4373" indentationPerLevel="16" autoresizesOutlineColumn="YES" outlineTableColumn="4380" id="4376" customClass="VLCPlaylistView">
-                                                                    <rect key="frame" x="0.0" y="0.0" width="475" height="250"/>
-                                                                    <autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/>
-                                                                    <size key="intercellSpacing" width="3" height="2"/>
-                                                                    <color key="backgroundColor" name="controlBackgroundColor" catalog="System" colorSpace="catalog"/>
-                                                                    <tableViewGridLines key="gridStyleMask" vertical="YES"/>
-                                                                    <color key="gridColor" name="gridColor" catalog="System" colorSpace="catalog"/>
-                                                                    <tableColumns>
-                                                                        <tableColumn identifier="status" width="18" minWidth="18" maxWidth="18" id="4380">
-                                                                            <tableHeaderCell key="headerCell" lineBreakMode="truncatingTail" borderStyle="border" alignment="left">
-                                                                                <font key="font" metaFont="smallSystem"/>
-                                                                                <color key="textColor" name="headerTextColor" catalog="System" colorSpace="catalog"/>
-                                                                                <color key="backgroundColor" name="headerColor" catalog="System" colorSpace="catalog"/>
-                                                                            </tableHeaderCell>
-                                                                            <imageCell key="dataCell" controlSize="small" refusesFirstResponder="YES" alignment="left" imageScaling="proportionallyDown" id="4381"/>
-                                                                            <tableColumnResizingMask key="resizingMask" resizeWithTable="YES" userResizable="YES"/>
-                                                                        </tableColumn>
-                                                                    </tableColumns>
-                                                                </outlineView>
-                                                            </subviews>
-                                                        </clipView>
-                                                        <scroller key="horizontalScroller" hidden="YES" wantsLayer="YES" verticalHuggingPriority="750" horizontal="YES" id="4374">
-                                                            <rect key="frame" x="1" y="234" width="0.0" height="16"/>
-                                                            <autoresizingMask key="autoresizingMask"/>
-                                                        </scroller>
-                                                        <scroller key="verticalScroller" hidden="YES" wantsLayer="YES" verticalHuggingPriority="750" horizontal="NO" id="4375">
-                                                            <rect key="frame" x="386" y="23" width="16" height="0.0"/>
-                                                            <autoresizingMask key="autoresizingMask"/>
-                                                        </scroller>
-                                                        <tableHeaderView key="headerView" id="4373">
-                                                            <rect key="frame" x="0.0" y="0.0" width="475" height="23"/>
-                                                            <autoresizingMask key="autoresizingMask"/>
-                                                        </tableHeaderView>
-                                                    </scrollView>
                                                 </subviews>
                                                 <constraints>
-                                                    <constraint firstAttribute="bottom" secondItem="4372" secondAttribute="bottom" id="7nB-oh-n2V"/>
                                                     <constraint firstItem="4722" firstAttribute="leading" secondItem="U2A-0F-udY" secondAttribute="leading" id="FCe-Dh-MEG"/>
                                                     <constraint firstAttribute="trailing" secondItem="4722" secondAttribute="trailing" id="G8U-K8-Aao"/>
-                                                    <constraint firstItem="4372" firstAttribute="top" secondItem="U2A-0F-udY" secondAttribute="top" id="TzQ-ic-Og9"/>
                                                     <constraint firstAttribute="bottom" secondItem="4722" secondAttribute="bottom" id="dSW-Uh-nP9"/>
-                                                    <constraint firstItem="4372" firstAttribute="leading" secondItem="U2A-0F-udY" secondAttribute="leading" id="fZe-5h-83L"/>
-                                                    <constraint firstAttribute="trailing" secondItem="4372" secondAttribute="trailing" id="ozJ-dU-Qw7"/>
                                                     <constraint firstItem="4722" firstAttribute="top" secondItem="U2A-0F-udY" secondAttribute="top" id="tIs-Fh-Jsd"/>
                                                 </constraints>
                                             </customView>
@@ -711,8 +667,6 @@
                 <outlet property="dropzoneImageView" destination="4725" id="Ck9-vp-aDM"/>
                 <outlet property="dropzoneLabel" destination="4727" id="HkS-xv-7B6"/>
                 <outlet property="dropzoneView" destination="4722" id="a41-TD-aJs"/>
-                <outlet property="outlineView" destination="4376" id="92d-4j-4PK"/>
-                <outlet property="playlistScrollView" destination="4372" id="QDP-7m-wKJ"/>
                 <outlet property="podcastAddButton" destination="5263" id="Rg8-kX-6dU"/>
                 <outlet property="podcastRemoveButton" destination="5302" id="T6b-Y8-Usc"/>
                 <outlet property="podcastSubscribeCancelButton" destination="5268" id="nSd-2J-TCb"/>
diff --git a/modules/gui/macosx/UI/PlaylistAccessoryView.xib b/modules/gui/macosx/UI/PlaylistAccessoryView.xib
index e75cab4d187fed6cca1eeb531c5877d4b04e971b..9fb68d0fea15ba6e648b1c23001876a3dd8147e7 100644
--- a/modules/gui/macosx/UI/PlaylistAccessoryView.xib
+++ b/modules/gui/macosx/UI/PlaylistAccessoryView.xib
@@ -1,8 +1,9 @@
 <?xml version="1.0" encoding="UTF-8"?>
-<document type="com.apple.InterfaceBuilder3.Cocoa.XIB" version="3.0" toolsVersion="10117" systemVersion="16G29" targetRuntime="MacOSX.Cocoa" propertyAccessControl="none" useAutolayout="YES">
+<document type="com.apple.InterfaceBuilder3.Cocoa.XIB" version="3.0" toolsVersion="14460.31" targetRuntime="MacOSX.Cocoa" propertyAccessControl="none" useAutolayout="YES">
     <dependencies>
-        <development version="7000" identifier="xcode"/>
-        <plugIn identifier="com.apple.InterfaceBuilder.CocoaPlugin" version="10117"/>
+        <deployment identifier="macosx"/>
+        <plugIn identifier="com.apple.InterfaceBuilder.CocoaPlugin" version="14460.31"/>
+        <capability name="documents saved in the Xcode 8 format" minToolsVersion="8.0"/>
     </dependencies>
     <objects>
         <customObject id="-2" userLabel="File's Owner" customClass="VLCMainMenu">
@@ -14,14 +15,14 @@
         </customObject>
         <customObject id="-1" userLabel="First Responder" customClass="FirstResponder"/>
         <customObject id="-3" userLabel="Application" customClass="NSObject"/>
-        <customView id="efm-sw-3Se">
+        <customView misplaced="YES" id="efm-sw-3Se">
             <rect key="frame" x="0.0" y="0.0" width="369" height="39"/>
             <autoresizingMask key="autoresizingMask" flexibleMaxX="YES" flexibleMinY="YES"/>
             <subviews>
-                <customView translatesAutoresizingMaskIntoConstraints="NO" id="1" userLabel="SaveAccessoryView">
+                <customView misplaced="YES" translatesAutoresizingMaskIntoConstraints="NO" id="1" userLabel="SaveAccessoryView">
                     <rect key="frame" x="0.0" y="0.0" width="369" height="39"/>
                     <subviews>
-                        <popUpButton verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="3">
+                        <popUpButton verticalHuggingPriority="750" misplaced="YES" translatesAutoresizingMaskIntoConstraints="NO" id="3">
                             <rect key="frame" x="91" y="6" width="267" height="26"/>
                             <popUpButtonCell key="cell" type="push" bezelStyle="rounded" alignment="left" lineBreakMode="truncatingTail" borderStyle="borderAndBezel" inset="2" arrowPosition="arrowAtCenter" preferredEdge="maxY" id="4">
                                 <behavior key="behavior" lightByBackground="YES" lightByGray="YES"/>
diff --git a/modules/gui/macosx/UI/PlaylistMenu.xib b/modules/gui/macosx/UI/PlaylistMenu.xib
deleted file mode 100644
index 2387fb187ec6dd99f744e676115eae8395239a9d..0000000000000000000000000000000000000000
--- a/modules/gui/macosx/UI/PlaylistMenu.xib
+++ /dev/null
@@ -1,76 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<document type="com.apple.InterfaceBuilder3.Cocoa.XIB" version="3.0" toolsVersion="10117" systemVersion="16G1036" targetRuntime="MacOSX.Cocoa" propertyAccessControl="none" useAutolayout="YES">
-    <dependencies>
-        <development version="7000" identifier="xcode"/>
-        <plugIn identifier="com.apple.InterfaceBuilder.CocoaPlugin" version="10117"/>
-    </dependencies>
-    <objects>
-        <customObject id="-2" userLabel="File's Owner" customClass="VLCPlaylist">
-            <connections>
-                <outlet property="addFilesToPlaylistMenuItem" destination="lGc-nc-8Yq" id="joN-zx-w8u"/>
-                <outlet property="deletePlaylistMenuItem" destination="13" id="Qwn-a7-On0"/>
-                <outlet property="infoPlaylistMenuItem" destination="9" id="uIr-Np-fpB"/>
-                <outlet property="playPlaylistMenuItem" destination="12" id="Dv9-jX-Q4W"/>
-                <outlet property="playlistMenu" destination="1" id="i0k-dj-ZpJ"/>
-                <outlet property="recursiveCollapsePlaylistMenuItem" destination="4xC-4n-AL0" id="xSX-gh-auF"/>
-                <outlet property="recursiveExpandPlaylistMenuItem" destination="5" id="vFK-br-qmx"/>
-                <outlet property="revealInFinderPlaylistMenuItem" destination="3" id="IrJ-gR-Zqp"/>
-                <outlet property="selectAllPlaylistMenuItem" destination="14" id="drx-ij-QhT"/>
-            </connections>
-        </customObject>
-        <customObject id="-1" userLabel="First Responder" customClass="FirstResponder"/>
-        <customObject id="-3" userLabel="Application" customClass="NSObject"/>
-        <menu title="Menu" id="1" userLabel="PlaylistMenu">
-            <items>
-                <menuItem title="Play" id="12">
-                    <connections>
-                        <action selector="playItem:" target="-2" id="26"/>
-                    </connections>
-                </menuItem>
-                <menuItem title="Delete" id="13">
-                    <connections>
-                        <action selector="deleteItem:" target="-2" id="27"/>
-                    </connections>
-                </menuItem>
-                <menuItem isSeparatorItem="YES" id="11">
-                    <modifierMask key="keyEquivalentModifierMask" command="YES"/>
-                </menuItem>
-                <menuItem title="Select All" id="14">
-                    <connections>
-                        <action selector="selectAll:" target="-2" id="28"/>
-                    </connections>
-                </menuItem>
-                <menuItem isSeparatorItem="YES" id="8">
-                    <modifierMask key="keyEquivalentModifierMask" command="YES"/>
-                </menuItem>
-                <menuItem title="Expand All" id="5">
-                    <connections>
-                        <action selector="recursiveExpandOrCollapseNode:" target="-2" id="eXQ-bT-oYi"/>
-                    </connections>
-                </menuItem>
-                <menuItem title="Collapse All" id="4xC-4n-AL0">
-                    <connections>
-                        <action selector="recursiveExpandOrCollapseNode:" target="-2" id="uUM-ci-hOU"/>
-                    </connections>
-                </menuItem>
-                <menuItem title="Media Information..." id="9">
-                    <connections>
-                        <action selector="showInfoPanel:" target="-2" id="36"/>
-                    </connections>
-                </menuItem>
-                <menuItem title="Reveal in Finder" id="3">
-                    <connections>
-                        <action selector="revealItemInFinder:" target="-2" id="4WU-rm-69M"/>
-                    </connections>
-                </menuItem>
-                <menuItem isSeparatorItem="YES" id="sUF-9g-Rxq"/>
-                <menuItem title="Add Files" id="lGc-nc-8Yq">
-                    <modifierMask key="keyEquivalentModifierMask"/>
-                    <connections>
-                        <action selector="addFilesToPlaylist:" target="-2" id="r6Z-KP-ovf"/>
-                    </connections>
-                </menuItem>
-            </items>
-        </menu>
-    </objects>
-</document>
diff --git a/modules/gui/macosx/VLCClickerManager.m b/modules/gui/macosx/VLCClickerManager.m
index 2682d066b538cba5e681d6ae4f336144e870961a..e81c23fbe905cdd3863c637a7554026e3f451ef3 100644
--- a/modules/gui/macosx/VLCClickerManager.m
+++ b/modules/gui/macosx/VLCClickerManager.m
@@ -24,10 +24,11 @@
 #import "SPMediaKeyTap.h"
 #import "AppleRemote.h"
 #import "VLCMain.h"
-#import "VLCPlaylist.h"
 #import "VLCInputManager.h"
 #import "VLCCoreInteraction.h"
 #import "NSSound+VLCAdditions.h"
+#import "VLCPlaylistController.h"
+#import "VLCPlaylistModel.h"
 #import <vlc_actions.h>
 
 @interface VLCClickerManager()
@@ -107,7 +108,7 @@
         _mediaKeyController = [[SPMediaKeyTap alloc] initWithDelegate:self];
 
     VLCMain *main = [VLCMain sharedInstance];
-    if (b_mediaKeySupport && ([[[main playlist] model] hasChildren] ||
+    if (b_mediaKeySupport && ([[[main playlistController] playlistModel] numberOfPlaylistItems] > 0 ||
                               [[main inputManager] hasInput])) {
         if (!b_mediaKeyTrapEnabled) {
             msg_Dbg(p_intf, "Enabling media key support");
diff --git a/modules/gui/macosx/VLCControlsBarCommon.m b/modules/gui/macosx/VLCControlsBarCommon.m
index 436899a02894ec2c8867523905377058c80014a3..6951de8409a195eb710ab17ff71f3b41587c1843 100644
--- a/modules/gui/macosx/VLCControlsBarCommon.m
+++ b/modules/gui/macosx/VLCControlsBarCommon.m
@@ -25,7 +25,6 @@
 #import "VLCMain.h"
 #import "VLCCoreInteraction.h"
 #import "VLCMainMenu.h"
-#import "VLCPlaylist.h"
 #import "CompatibilityFixes.h"
 #import "NSString+Helpers.h"
 
diff --git a/modules/gui/macosx/VLCConvertAndSaveWindowController.m b/modules/gui/macosx/VLCConvertAndSaveWindowController.m
index 781e47a24d36cc706c16bab067ccd2e93de933d9..4ac37b19ac8c14ffe89e7baef82073e3f297e5cd 100644
--- a/modules/gui/macosx/VLCConvertAndSaveWindowController.m
+++ b/modules/gui/macosx/VLCConvertAndSaveWindowController.m
@@ -23,7 +23,6 @@
 #import "VLCConvertAndSaveWindowController.h"
 
 #import "VLCMain.h"
-#import "VLCPlaylist.h"
 #import "misc.h"
 #import "VLCPopupPanelController.h"
 #import "VLCTextfieldPanelController.h"
@@ -642,7 +641,11 @@
             [self updateDropView];
             return YES;
         }
-    } else if ([desired_type isEqualToString:@"VLCPlaylistItemPboardType"]) {
+    }
+
+#if 0
+    // FIXME: re-implement drag-n-drop from the new playlist
+    else if ([desired_type isEqualToString:@"VLCPlaylistItemPboardType"]) {
         NSArray *draggedItems = [[[VLCMain sharedInstance] playlist] draggedItems];
 
         // Return early to prevent unnecessary playlist access/locking
@@ -674,6 +677,7 @@
 
         return (p_item != NULL) ? YES : NO;
     }
+#endif
     return NO;
 }
 
diff --git a/modules/gui/macosx/VLCCoreInteraction.m b/modules/gui/macosx/VLCCoreInteraction.m
index 4918259d417a18004580e36f40fee8e788d8eb38..290fe05aeede75dc94293e9ce059b7919c0c96d4 100644
--- a/modules/gui/macosx/VLCCoreInteraction.m
+++ b/modules/gui/macosx/VLCCoreInteraction.m
@@ -23,7 +23,6 @@
 #import "VLCCoreInteraction.h"
 #import "VLCMain.h"
 #import "VLCOpenWindowController.h"
-#import "VLCPlaylist.h"
 #import <vlc_strings.h>
 #import <vlc_url.h>
 #import <vlc_modules.h>
@@ -31,6 +30,7 @@
 #import <vlc_actions.h>
 #import "VLCClickerManager.h"
 #import "VLCPlaylistController.h"
+#import "VLCPlaylistModel.h"
 
 static int BossCallback(vlc_object_t *p_this, const char *psz_var,
                         vlc_value_t oldval, vlc_value_t new_val, void *param)
@@ -121,12 +121,11 @@ static int BossCallback(vlc_object_t *p_this, const char *psz_var,
         playlist_TogglePause(p_playlist);
         vlc_object_release(p_input);
     } else {
-        PLRootType root = [[[[VLCMain sharedInstance] playlist] model] currentRootType];
         VLCMain *mainInstance = [VLCMain sharedInstance];
-        if ([[mainInstance playlist] isSelectionEmpty] && (root == ROOT_TYPE_PLAYLIST))
+        if (mainInstance.playlistController.playlistModel.numberOfPlaylistItems == 0)
             [[mainInstance open] openFileGeneric];
         else
-            [[mainInstance playlist] playItem:nil];
+            [mainInstance.playlistController startPlaylist];
     }
 }
 
diff --git a/modules/gui/macosx/VLCInputManager.m b/modules/gui/macosx/VLCInputManager.m
index 115212bcb204e0a22a7b9b2e808b50038e9ebd9e..4a645a7cd5ad24ced0bb2e9da502cd6343b9c00e 100644
--- a/modules/gui/macosx/VLCInputManager.m
+++ b/modules/gui/macosx/VLCInputManager.m
@@ -28,7 +28,6 @@
 #import "VLCMain.h"
 #import "VLCMainMenu.h"
 #import "VLCMainWindow.h"
-#import "VLCPlaylist.h"
 #import "VLCPlaylistInfo.h"
 #import "VLCResumeDialogController.h"
 #import "VLCTrackSynchronizationWindowController.h"
@@ -259,7 +258,7 @@ static int InputEvent(vlc_object_t *p_this, const char *psz_var,
 
         p_input_changed = vlc_object_hold(p_current_input);
 
-        [[o_main playlist] currentlyPlayingItemChanged];
+//        [[o_main playlist] currentlyPlayingItemChanged];
 
         [self continuePlaybackWhereYouLeftOff:p_current_input];
 
@@ -516,7 +515,8 @@ static int InputEvent(vlc_object_t *p_this, const char *psz_var,
 
     input_item_t *p_input_item = input_GetItem(p_current_input);
 
-    [[[o_main playlist] model] updateItem:p_input_item];
+    // FIXME: update metadata in playlist model if needed
+//    [[[o_main playlist] model] updateItem:p_input_item];
     [[[VLCMain sharedInstance] currentMediaInfoPanel] updatePanelWithItem:p_input_item];
 
     if (!p_input_item) {
diff --git a/modules/gui/macosx/VLCMain.h b/modules/gui/macosx/VLCMain.h
index 5b55a59de6ef45513ea8a7b727ec05f30efa589d..99d06d226dc81dd53aa03354c3a793ecc5a81251 100644
--- a/modules/gui/macosx/VLCMain.h
+++ b/modules/gui/macosx/VLCMain.h
@@ -60,7 +60,6 @@ static NSString * VLCAppleRemoteSettingChangedNotification = @"VLCAppleRemoteSet
 @class AppleRemote;
 @class VLCInfo;
 @class VLCMainMenu;
-@class VLCPlaylist;
 @class VLCInputManager;
 @class VLCResumeDialogController;
 @class VLCSimplePrefsController;
@@ -96,7 +95,6 @@ static NSString * VLCAppleRemoteSettingChangedNotification = @"VLCAppleRemoteSet
 - (VLCOpenWindowController *)open;
 - (VLCSimplePrefsController *)simplePreferences;
 - (VLCPrefs *)preferences;
-- (VLCPlaylist *)playlist;
 - (VLCCoreDialogProvider *)coreDialogProvider;
 - (VLCResumeDialogController *)resumeDialog;
 - (VLCInputManager *)inputManager;
diff --git a/modules/gui/macosx/VLCMain.m b/modules/gui/macosx/VLCMain.m
index 87d24588a373cfba1e9239261f4b35a3cbcaae9f..3972c251a051b12634d5176d4e02ae19cbfcd748 100644
--- a/modules/gui/macosx/VLCMain.m
+++ b/modules/gui/macosx/VLCMain.m
@@ -47,8 +47,6 @@
 #import "VLCMainMenu.h"
 #import "VLCVoutView.h"
 #import "prefs.h"
-#import "VLCPlaylist.h"
-#import "VLCPlaylistInfo.h"
 #import "VLCPlaylistInfo.h"
 #import "VLCOpenWindowController.h"
 #import "VLCBookmarksWindowController.h"
@@ -174,7 +172,6 @@ static int ShowController(vlc_object_t *p_this, const char *psz_variable,
     VLCBookmarksWindowController *_bookmarks;
     VLCResumeDialogController *_resume_dialog;
     VLCInputManager *_input_manager;
-    VLCPlaylist *_playlist;
     VLCLogWindowController *_messagePanelController;
     VLCStatusBarIcon *_statusBarIcon;
     VLCTrackSynchronizationWindowController *_trackSyncPanel;
@@ -235,7 +232,6 @@ static VLCMain *sharedInstance = nil;
         _statusBarIcon = [[VLCStatusBarIcon  alloc] init];
 
         _voutProvider = [[VLCVideoOutputProvider alloc] init];
-        _playlist = [[VLCPlaylist alloc] init];
 
         _mainWindowController = [[NSWindowController alloc] initWithWindowNibName:@"MainWindow"];
         _libraryWindowController = [[VLCLibraryWindowController alloc] initWithLibraryWindow];
@@ -561,11 +557,6 @@ static VLCMain *sharedInstance = nil;
     return _prefs;
 }
 
-- (VLCPlaylist *)playlist
-{
-    return _playlist;
-}
-
 - (VLCCoreDialogProvider *)coreDialogProvider
 {
     return _coredialogs;
diff --git a/modules/gui/macosx/VLCMainMenu.m b/modules/gui/macosx/VLCMainMenu.m
index 70e0ca79f158de094ea4f30dada3fe429bea70ed..c3984d48022e05f3aa7660c7bc749274f0797a36 100644
--- a/modules/gui/macosx/VLCMainMenu.m
+++ b/modules/gui/macosx/VLCMainMenu.m
@@ -36,7 +36,6 @@
 #import "VLCVideoEffectsWindowController.h"
 #import "VLCBookmarksWindowController.h"
 #import "VLCSimplePrefsController.h"
-#import "VLCPlaylist.h"
 #import "VLCPlaylistController.h"
 #import "VLCPlaylistInfo.h"
 #import "VLCVoutView.h"
diff --git a/modules/gui/macosx/VLCMainWindow.m b/modules/gui/macosx/VLCMainWindow.m
index 1339a5d860809aba87ae6aa469a5f747c39280d0..d5ced4fc6a6f153174cb4e1a3a2f7f1283794a98 100644
--- a/modules/gui/macosx/VLCMainWindow.m
+++ b/modules/gui/macosx/VLCMainWindow.m
@@ -32,14 +32,12 @@
 #import "VLCAudioEffectsWindowController.h"
 #import "VLCMainMenu.h"
 #import "VLCOpenWindowController.h"
-#import "VLCPlaylist.h"
 #import "VLCSourceListItem.h"
 #import <math.h>
 #import <vlc_playlist_legacy.h>
 #import <vlc_url.h>
 #import <vlc_strings.h>
 #import <vlc_services_discovery.h>
-#import "VLCPLModel.h"
 
 #import "PXSourceList/PXSourceList.h"
 #import "PXSourceList/PXSourceListDataSource.h"
@@ -157,12 +155,6 @@ static const float f_min_window_height = 307.;
     _nativeFullscreenMode = var_InheritBool(getIntf(), "macosx-nativefullscreenmode");
     b_dropzone_active = YES;
 
-    // Playlist setup
-    VLCPlaylist *playlist = [[VLCMain sharedInstance] playlist];
-    [playlist setOutlineView:(VLCPlaylistView *)_outlineView];
-    [playlist setPlaylistHeaderView:_outlineView.headerView];
-    [self setNextResponder:playlist];
-
     // (Re)load sidebar for the first time and select first item
     [self reloadSidebar];
     [_sidebarView selectRowIndexes:[NSIndexSet indexSetWithIndex:1] byExtendingSelection:NO];
@@ -670,13 +662,7 @@ static const float f_min_window_height = 307.;
     if ([self.fspanel respondsToSelector:@selector(setSeekable:)])
         [self.fspanel setSeekable: b_seekable];
 
-    PL_LOCK;
-    if ([[[[VLCMain sharedInstance] playlist] model] currentRootType] != ROOT_TYPE_PLAYLIST ||
-        [[[[VLCMain sharedInstance] playlist] model] hasChildren])
-        [self hideDropZone];
-    else
-        [self showDropZone];
-    PL_UNLOCK;
+    [self showDropZone];
     [_sidebarView setNeedsDisplay:YES];
 
     [self _updatePlaylistTitle];
@@ -826,14 +812,6 @@ static const float f_min_window_height = 307.;
 #pragma mark private playlist magic
 - (void)_updatePlaylistTitle
 {
-    PLRootType root = [[[[VLCMain sharedInstance] playlist] model] currentRootType];
-    playlist_t *p_playlist = pl_Get(getIntf());
-
-    PL_LOCK;
-    if (root == ROOT_TYPE_PLAYLIST)
-        [_categoryLabel setStringValue: [_NS("Playlist") stringByAppendingString:[self _playbackDurationOfNode:p_playlist->p_playing]]];
-
-    PL_UNLOCK;
 }
 
 - (NSString *)_playbackDurationOfNode:(playlist_item_t*)node
@@ -841,9 +819,6 @@ static const float f_min_window_height = 307.;
     if (!node)
         return @"";
 
-    playlist_t * p_playlist = pl_Get(getIntf());
-    PL_ASSERT_LOCKED;
-
     vlc_tick_t mt_duration = playlist_GetNodeDuration( node );
 
     if (mt_duration < 1)
@@ -859,7 +834,6 @@ static const float f_min_window_height = 307.;
 
 - (IBAction)searchItem:(id)sender
 {
-    [[[[VLCMain sharedInstance] playlist] model] searchUpdate:[_searchField stringValue]];
 }
 
 - (IBAction)highlightSearchField:(id)sender
@@ -962,22 +936,7 @@ static const float f_min_window_height = 307.;
     [_categoryLabel setStringValue:[item title]];
 
     if ([[item identifier] isEqualToString:@"playlist"]) {
-        PL_LOCK;
-        [[[[VLCMain sharedInstance] playlist] model] changeRootItem:p_playlist->p_playing];
-        PL_UNLOCK;
-
         [self _updatePlaylistTitle];
-
-    } else {
-        PL_LOCK;
-        const char *title = [[item title] UTF8String];
-        playlist_item_t *pl_item = playlist_ChildSearchName(&p_playlist->root, title);
-        if (pl_item)
-            [[[[VLCMain sharedInstance] playlist] model] changeRootItem:pl_item];
-        else
-            msg_Err(getIntf(), "Could not find playlist entry with name %s", title);
-
-        PL_UNLOCK;
     }
 
     // Note the order: first hide the podcast controls, then show the drop zone
@@ -986,13 +945,7 @@ static const float f_min_window_height = 307.;
     else
         [self hidePodcastControls];
 
-    PL_LOCK;
-    if ([[[[VLCMain sharedInstance] playlist] model] currentRootType] != ROOT_TYPE_PLAYLIST ||
-        [[[[VLCMain sharedInstance] playlist] model] hasChildren])
-        [self hideDropZone];
-    else
-        [self showDropZone];
-    PL_UNLOCK;
+    [self showDropZone];
 
     [[NSNotificationCenter defaultCenter] postNotificationName: VLCMediaKeySupportSettingChangedNotification
                                                         object: nil
@@ -1036,7 +989,7 @@ static const float f_min_window_height = 307.;
 {
     if ([[item identifier] isEqualToString:@"playlist"]) {
         NSPasteboard *o_pasteboard = [info draggingPasteboard];
-        if ([[o_pasteboard types] containsObject: VLCPLItemPasteboadType] || [[o_pasteboard types] containsObject: NSFilenamesPboardType])
+        if ([[o_pasteboard types] containsObject: NSFilenamesPboardType])
             return NSDragOperationGeneric;
     }
     return NSDragOperationNone;
@@ -1044,44 +997,7 @@ static const float f_min_window_height = 307.;
 
 - (BOOL)sourceList:(PXSourceList *)aSourceList acceptDrop:(id <NSDraggingInfo>)info item:(id)item childIndex:(NSInteger)index
 {
-    NSPasteboard *o_pasteboard = [info draggingPasteboard];
-
-    playlist_t * p_playlist = pl_Get(getIntf());
-    playlist_item_t *p_node;
-
-    if ([[item identifier] isEqualToString:@"playlist"])
-        p_node = p_playlist->p_playing;
-    else {
-        msg_Warn(p_playlist, "dragging non-playlist items is not supported");
-        return NO;
-    }
-
-    if ([[o_pasteboard types] containsObject: @"VLCPlaylistItemPboardType"]) {
-        NSArray * array = [[[VLCMain sharedInstance] playlist] draggedItems];
-
-        NSUInteger count = [array count];
-
-        PL_LOCK;
-        for(NSUInteger i = 0; i < count; i++) {
-            playlist_item_t *p_item = playlist_ItemGetById(p_playlist, [[array objectAtIndex:i] plItemId]);
-            if (!p_item) continue;
-            playlist_NodeAddCopy(p_playlist, p_item, p_node, PLAYLIST_END);
-        }
-        PL_UNLOCK;
-
-        return YES;
-    }
-
-    // check if dropped item is a file
-    NSArray *items = [[[VLCMain sharedInstance] playlist] createItemsFromExternalPasteboard:o_pasteboard];
-    if (items.count == 0)
-        return NO;
-
-    [[[VLCMain sharedInstance] playlist] addPlaylistItems:items
-                                         withParentItemId:p_node->i_id
-                                                    atPos:-1
-                                            startPlayback:NO];
-    return YES;
+    return NO;
 }
 
 - (id)sourceList:(PXSourceList *)aSourceList persistentObjectForItem:(id)item
@@ -1162,7 +1078,6 @@ static const float f_min_window_height = 307.;
 
         /* update playlist table */
         if (playlist_IsServicesDiscoveryLoaded(p_playlist, "podcast")) {
-            [[[VLCMain sharedInstance] playlist] playlistUpdated];
         }
     }
 }
diff --git a/modules/gui/macosx/VLCMainWindowControlsBar.m b/modules/gui/macosx/VLCMainWindowControlsBar.m
index 90a89b92470b76ab190393eb72259352af339e8e..081b933f545e3e12a8868b75dff891cb564084e5 100644
--- a/modules/gui/macosx/VLCMainWindowControlsBar.m
+++ b/modules/gui/macosx/VLCMainWindowControlsBar.m
@@ -26,7 +26,6 @@
 #import "VLCMain.h"
 #import "VLCCoreInteraction.h"
 #import "VLCMainMenu.h"
-#import "VLCPlaylist.h"
 #import "CompatibilityFixes.h"
 #import <vlc_aout.h>
 
@@ -140,8 +139,7 @@
     if (!var_InheritBool(getIntf(), "macosx-show-playback-buttons"))
         [self removeJumpButtons:NO];
 
-    [[[VLCMain sharedInstance] playlist] playbackModeUpdated];
-
+    // FIXME: make sure that buttons appear in the correct state
 }
 
 #pragma mark -
diff --git a/modules/gui/macosx/VLCPLItem.h b/modules/gui/macosx/VLCPLItem.h
deleted file mode 100644
index a8243e84898bc43881023dbba180d92685ece418..0000000000000000000000000000000000000000
--- a/modules/gui/macosx/VLCPLItem.h
+++ /dev/null
@@ -1,40 +0,0 @@
-/*****************************************************************************
- * VLCPLItem.h: MacOS X interface module
- *****************************************************************************
- * Copyright (C) 2014 VLC authors and VideoLAN
- *
- * 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
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
- *****************************************************************************/
-
-#import <Cocoa/Cocoa.h>
-
-#include <vlc_common.h>
-
-@interface VLCPLItem : NSObject
-
-@property(readonly, copy) NSMutableArray *children;
-@property(readonly) int plItemId;
-@property(readonly) input_item_t *input;
-@property(readwrite, weak) VLCPLItem *parent;
-
-- (id)initWithPlaylistItem:(playlist_item_t *)p_item;
-
-- (BOOL)isLeaf;
-
-- (void)clear;
-- (void)addChild:(VLCPLItem *)item atPos:(int)pos;
-- (void)deleteChild:(VLCPLItem *)child;
-
-@end
diff --git a/modules/gui/macosx/VLCPLItem.m b/modules/gui/macosx/VLCPLItem.m
deleted file mode 100644
index 803a577a5cf5f8f2db8d504192cccb7711db8981..0000000000000000000000000000000000000000
--- a/modules/gui/macosx/VLCPLItem.m
+++ /dev/null
@@ -1,88 +0,0 @@
-/*****************************************************************************
- * VLCPLItem.m: MacOS X interface module
- *****************************************************************************
- * Copyright (C) 2014 VLC authors and VideoLAN
- *
- * 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
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
- *****************************************************************************/
-
-#import "VLCPLItem.h"
-
-#include <vlc_playlist_legacy.h>
-#include <vlc_input_item.h>
-
-#pragma mark -
-
-@implementation VLCPLItem
-
-- (id)initWithPlaylistItem:(playlist_item_t *)p_item;
-{
-    self = [super init];
-    if(self) {
-        _plItemId = p_item->i_id;
-
-        _input = p_item->p_input;
-        input_item_Hold(_input);
-        _children = [[NSMutableArray alloc] init];
-    }
-
-    return self;
-}
-
-- (void)dealloc
-{
-    input_item_Release(_input);
-}
-
-// own hash and isEqual methods are important to retain expandable state
-// when items are moved / recreated
-- (NSUInteger)hash
-{
-    return (NSUInteger)[self plItemId];
-}
-
-- (BOOL)isEqual:(id)other
-{
-    if (other == self)
-        return YES;
-    if (!other || ![other isKindOfClass:[self class]])
-        return NO;
-    return [self plItemId] == [other plItemId];
-}
-
-- (BOOL)isLeaf
-{
-    return [_children count] == 0;
-}
-
-- (void)clear
-{
-    [_children removeAllObjects];
-}
-
-- (void)addChild:(VLCPLItem *)item atPos:(int)pos
-{
-    [_children insertObject:item atIndex:pos];
-    [item setParent: self];
-
-}
-
-- (void)deleteChild:(VLCPLItem *)child
-{
-    [child setParent:nil];
-    [_children removeObject:child];
-}
-
-@end
diff --git a/modules/gui/macosx/VLCPLModel.h b/modules/gui/macosx/VLCPLModel.h
deleted file mode 100644
index 52586b65e408a3ffeea21d7d823201533d6a5362..0000000000000000000000000000000000000000
--- a/modules/gui/macosx/VLCPLModel.h
+++ /dev/null
@@ -1,79 +0,0 @@
-/*****************************************************************************
- * PLItem.h: MacOS X interface module
- *****************************************************************************
- * Copyright (C) 2014 VLC authors and VideoLAN
- *
- * 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
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
- *****************************************************************************/
-
-#import <Cocoa/Cocoa.h>
-
-#import "VLCPLItem.h"
-
-#include <vlc_common.h>
-
-#define VLCPLItemPasteboadType @"VLCPlaylistItemPboardType"
-
-/* playlist column definitions */
-#define STATUS_COLUMN @"status"
-#define TRACKNUM_COLUMN @"tracknumber"
-#define TITLE_COLUMN @"name"
-#define ARTIST_COLUMN @"artist"
-#define DURATION_COLUMN @"duration"
-#define GENRE_COLUMN @"genre"
-#define ALBUM_COLUMN @"album"
-#define DESCRIPTION_COLUMN @"description"
-#define DATE_COLUMN @"date"
-#define LANGUAGE_COLUMN @"language"
-#define URI_COLUMN @"uri"
-#define FILESIZE_COLUMN @"file-size"
-
-typedef enum {
-    ROOT_TYPE_PLAYLIST,
-    ROOT_TYPE_OTHER
-} PLRootType;
-
-@interface VLCPLModel : NSObject<NSOutlineViewDataSource>
-
-@property(readonly) VLCPLItem *rootItem;
-@property(readonly, copy) NSArray *draggedItems;
-
-- (id)initWithOutlineView:(NSOutlineView *)outlineView playlist:(playlist_t *)pl rootItem:(playlist_item_t *)root;
-
-- (void)changeRootItem:(playlist_item_t *)p_root;
-
-- (BOOL)hasChildren;
-
-- (PLRootType)currentRootType;
-
-- (BOOL)editAllowed;
-- (void)deleteSelectedItem;
-
-// updates from core
-- (void)addItem:(int)i_item withParentNode:(int)i_node;
-- (void)removeItem:(int)i_item;
-
-- (void)updateItem:(input_item_t *)p_input_item;
-
-- (VLCPLItem *)currentlyPlayingItem;
-
-- (void)playbackModeUpdated;
-
-// sorting / searching
-- (void)sortForColumn:(NSString *)o_column withMode:(int)i_mode;
-
-- (void)searchUpdate:(NSString *)o_search;
-
-@end
diff --git a/modules/gui/macosx/VLCPLModel.m b/modules/gui/macosx/VLCPLModel.m
deleted file mode 100644
index f199a394ee2efbb75455c1b206dc2d42705f6c01..0000000000000000000000000000000000000000
--- a/modules/gui/macosx/VLCPLModel.m
+++ /dev/null
@@ -1,763 +0,0 @@
-/*****************************************************************************
- * VLCPLItem.m: MacOS X interface module
- *****************************************************************************
- * Copyright (C) 2014 VLC authors and VideoLAN
- *
- * 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
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
- *****************************************************************************/
-
-#import "VLCPLModel.h"
-
-#import "misc.h"    /* VLCByteCountFormatter */
-
-#import "VLCPlaylist.h"
-#import "NSString+Helpers.h"
-#import "VLCMain.h"
-#import "VLCMainWindowControlsBar.h"
-#import "VLCMainMenu.h"
-#import "VLCPlaylistInfo.h"
-#import "VLCMainWindow.h"
-
-#ifdef HAVE_CONFIG_H
-# import "config.h"
-#endif
-#include <assert.h>
-
-#include <vlc_playlist_legacy.h>
-#include <vlc_input_item.h>
-#include <vlc_input.h>
-#include <vlc_url.h>
-
-@interface VLCPLModel ()
-{
-    playlist_t *p_playlist;
-    __weak NSOutlineView *_outlineView;
-
-    NSUInteger _retainedRowSelection;
-}
-
-- (void)VLCPLItemAppended:(NSArray *)valueArray;
-- (void)VLCPLItemRemoved:(NSNumber *)value;
-- (void)VLCPLItemUpdated;
-
-@end
-
-#pragma mark -
-
-static int VLCPLItemUpdated(vlc_object_t *p_this, const char *psz_var,
-                         vlc_value_t oldval, vlc_value_t new_val, void *param)
-{
-    @autoreleasepool {
-        VLCPLModel *model = (__bridge VLCPLModel*)param;
-        [model performSelectorOnMainThread:@selector(VLCPLItemUpdated) withObject:nil waitUntilDone:NO];
-
-        return VLC_SUCCESS;
-    }
-}
-
-static int VLCPLItemAppended(vlc_object_t *p_this, const char *psz_var,
-                          vlc_value_t oldval, vlc_value_t new_val, void *param)
-{
-    @autoreleasepool {
-        playlist_item_t *p_item = new_val.p_address;
-        int i_node = p_item->p_parent ? p_item->p_parent->i_id : -1;
-        NSArray *o_val = [NSArray arrayWithObjects:[NSNumber numberWithInt:i_node], [NSNumber numberWithInt:p_item->i_id], nil];
-        VLCPLModel *model = (__bridge VLCPLModel*)param;
-        [model performSelectorOnMainThread:@selector(VLCPLItemAppended:) withObject:o_val waitUntilDone:NO];
-
-        return VLC_SUCCESS;
-    }
-}
-
-static int VLCPLItemRemoved(vlc_object_t *p_this, const char *psz_var,
-                         vlc_value_t oldval, vlc_value_t new_val, void *param)
-{
-    @autoreleasepool {
-        playlist_item_t *p_item = new_val.p_address;
-        NSNumber *o_val = [NSNumber numberWithInt:p_item->i_id];
-        VLCPLModel *model = (__bridge VLCPLModel*)param;
-        [model performSelectorOnMainThread:@selector(VLCPLItemRemoved:) withObject:o_val waitUntilDone:NO];
-
-        return VLC_SUCCESS;
-    }
-}
-
-static int PlaybackModeUpdated(vlc_object_t *p_this, const char *psz_var,
-                               vlc_value_t oldval, vlc_value_t new_val, void *param)
-{
-    @autoreleasepool {
-        VLCPLModel *model = (__bridge VLCPLModel*)param;
-        [model performSelectorOnMainThread:@selector(playbackModeUpdated) withObject:nil waitUntilDone:NO];
-
-        return VLC_SUCCESS;
-    }
-}
-
-static int VolumeUpdated(vlc_object_t *p_this, const char *psz_var,
-                         vlc_value_t oldval, vlc_value_t new_val, void *param)
-{
-    @autoreleasepool {
-        dispatch_async(dispatch_get_main_queue(), ^{
-            [[[VLCMain sharedInstance] mainWindow] updateVolumeSlider];
-        });
-
-        return VLC_SUCCESS;
-    }
-}
-
-#pragma mark -
-
-@implementation VLCPLModel
-
-#pragma mark -
-#pragma mark Init and Stuff
-
-- (id)initWithOutlineView:(NSOutlineView *)outlineView playlist:(playlist_t *)pl rootItem:(playlist_item_t *)root;
-{
-    self = [super init];
-    if (self) {
-        p_playlist = pl;
-        _outlineView = outlineView;
-
-        msg_Dbg(getIntf(), "Initializing playlist model");
-        var_AddCallback(p_playlist, "item-change", VLCPLItemUpdated, (__bridge void *)self);
-        var_AddCallback(p_playlist, "playlist-item-append", VLCPLItemAppended, (__bridge void *)self);
-        var_AddCallback(p_playlist, "playlist-item-deleted", VLCPLItemRemoved, (__bridge void *)self);
-        var_AddCallback(p_playlist, "random", PlaybackModeUpdated, (__bridge void *)self);
-        var_AddCallback(p_playlist, "repeat", PlaybackModeUpdated, (__bridge void *)self);
-        var_AddCallback(p_playlist, "loop", PlaybackModeUpdated, (__bridge void *)self);
-        var_AddCallback(p_playlist, "volume", VolumeUpdated, (__bridge void *)self);
-        var_AddCallback(p_playlist, "mute", VolumeUpdated, (__bridge void *)self);
-
-        PL_LOCK;
-        _rootItem = [[VLCPLItem alloc] initWithPlaylistItem:root];
-        [self rebuildVLCPLItem:_rootItem];
-        PL_UNLOCK;
-    }
-
-    return self;
-}
-
-- (void)dealloc
-{
-    msg_Dbg(getIntf(), "Deinitializing playlist model");
-    var_DelCallback(p_playlist, "item-change", VLCPLItemUpdated, (__bridge void *)self);
-    var_DelCallback(p_playlist, "playlist-item-append", VLCPLItemAppended, (__bridge void *)self);
-    var_DelCallback(p_playlist, "playlist-item-deleted", VLCPLItemRemoved, (__bridge void *)self);
-    var_DelCallback(p_playlist, "random", PlaybackModeUpdated, (__bridge void *)self);
-    var_DelCallback(p_playlist, "repeat", PlaybackModeUpdated, (__bridge void *)self);
-    var_DelCallback(p_playlist, "loop", PlaybackModeUpdated, (__bridge void *)self);
-    var_DelCallback(p_playlist, "volume", VolumeUpdated, (__bridge void *)self);
-    var_DelCallback(p_playlist, "mute", VolumeUpdated, (__bridge void *)self);
-}
-
-- (void)changeRootItem:(playlist_item_t *)p_root;
-{
-    PL_ASSERT_LOCKED;
-    _rootItem = [[VLCPLItem alloc] initWithPlaylistItem:p_root];
-    [self rebuildVLCPLItem:_rootItem];
-
-    [_outlineView reloadData];
-    [_outlineView selectRowIndexes:[NSIndexSet indexSetWithIndex:0] byExtendingSelection:NO];
-}
-
-- (BOOL)hasChildren
-{
-    return [[_rootItem children] count] > 0;
-}
-
-- (PLRootType)currentRootType
-{
-    int i_root_id = [_rootItem plItemId];
-    if (i_root_id == p_playlist->p_playing->i_id)
-        return ROOT_TYPE_PLAYLIST;
-
-    return ROOT_TYPE_OTHER;
-}
-
-- (BOOL)editAllowed
-{
-    return [self currentRootType] == ROOT_TYPE_PLAYLIST;
-}
-
-- (void)deleteSelectedItem
-{
-    // check if deletion is allowed
-    if (![self editAllowed])
-        return;
-
-    NSIndexSet *selectedIndexes = [_outlineView selectedRowIndexes];
-    _retainedRowSelection = [selectedIndexes firstIndex];
-    if (_retainedRowSelection == NSNotFound)
-        _retainedRowSelection = 0;
-
-    [selectedIndexes enumerateIndexesUsingBlock:^(NSUInteger idx, BOOL *stop) {
-        VLCPLItem *item = [self->_outlineView itemAtRow: idx];
-        if (!item)
-            return;
-
-        // model deletion is done via callback
-        playlist_Lock( self->p_playlist );
-        playlist_item_t *p_root = playlist_ItemGetById(self->p_playlist, [item plItemId]);
-        if( p_root != NULL )
-            playlist_NodeDelete(self->p_playlist, p_root);
-        playlist_Unlock( self->p_playlist );
-    }];
-}
-
-- (void)rebuildVLCPLItem:(VLCPLItem *)item
-{
-    [item clear];
-    playlist_item_t *p_item = playlist_ItemGetById(p_playlist, [item plItemId]);
-    if (p_item) {
-        int currPos = 0;
-        for(int i = 0; i < p_item->i_children; ++i) {
-            playlist_item_t *p_child = p_item->pp_children[i];
-
-            if (p_child->i_flags & PLAYLIST_DBL_FLAG)
-                continue;
-
-            VLCPLItem *child = [[VLCPLItem alloc] initWithPlaylistItem:p_child];
-            [item addChild:child atPos:currPos++];
-
-            if (p_child->i_children >= 0) {
-                [self rebuildVLCPLItem:child];
-            }
-
-        }
-    }
-
-}
-
-- (VLCPLItem *)findItemByPlaylistId:(int)i_pl_id
-{
-    return [self findItemInnerByPlaylistId:i_pl_id node:_rootItem];
-}
-
-- (VLCPLItem *)findItemInnerByPlaylistId:(int)i_pl_id node:(VLCPLItem *)node
-{
-    if ([node plItemId] == i_pl_id) {
-        return node;
-    }
-
-    for (NSUInteger i = 0; i < [[node children] count]; ++i) {
-        VLCPLItem *o_sub_item = [[node children] objectAtIndex:i];
-        if ([o_sub_item plItemId] == i_pl_id) {
-            return o_sub_item;
-        }
-
-        if (![o_sub_item isLeaf]) {
-            VLCPLItem *o_returned = [self findItemInnerByPlaylistId:i_pl_id node:o_sub_item];
-            if (o_returned)
-                return o_returned;
-        }
-    }
-
-    return nil;
-}
-
-#pragma mark -
-#pragma mark Core events
-
-
-- (void)VLCPLItemAppended:(NSArray *)valueArray
-{
-    int i_node = [[valueArray firstObject] intValue];
-    int i_item = [[valueArray objectAtIndex:1] intValue];
-
-    [self addItem:i_item withParentNode:i_node];
-
-    // update badge in sidebar
-    [[[VLCMain sharedInstance] mainWindow] updateWindow];
-
-    [[NSNotificationCenter defaultCenter] postNotificationName: VLCMediaKeySupportSettingChangedNotification
-                                                        object: nil
-                                                      userInfo: nil];
-}
-
-- (void)VLCPLItemRemoved:(NSNumber *)value
-{
-    int i_item = [value intValue];
-
-    [self removeItem:i_item];
-    // retain selection before deletion
-    [_outlineView selectRowIndexes:[NSIndexSet indexSetWithIndex:_retainedRowSelection] byExtendingSelection:NO];
-
-    // update badge in sidebar
-    [[[VLCMain sharedInstance] mainWindow] updateWindow];
-
-    [[NSNotificationCenter defaultCenter] postNotificationName: VLCMediaKeySupportSettingChangedNotification
-                                                        object: nil
-                                                      userInfo: nil];
-}
-
-- (void)VLCPLItemUpdated
-{
-    VLCMain *instance = [VLCMain sharedInstance];
-    [[instance mainWindow] updateName];
-
-    [[instance currentMediaInfoPanel] updateMetadata];
-}
-
-- (void)addItem:(int)i_item withParentNode:(int)i_node
-{
-    VLCPLItem *o_parent = [self findItemByPlaylistId:i_node];
-    if (!o_parent) {
-        return;
-    }
-
-    PL_LOCK;
-    playlist_item_t *p_item = playlist_ItemGetById(p_playlist, i_item);
-    if (!p_item || p_item->i_flags & PLAYLIST_DBL_FLAG)
-    {
-        PL_UNLOCK;
-        return;
-    }
-
-    int pos;
-    for(pos = p_item->p_parent->i_children - 1; pos >= 0; pos--)
-        if(p_item->p_parent->pp_children[pos] == p_item)
-            break;
-
-    VLCPLItem *o_new_item = [[VLCPLItem alloc] initWithPlaylistItem:p_item];
-    PL_UNLOCK;
-    if (pos < 0)
-        return;
-
-    [o_parent addChild:o_new_item atPos:pos];
-
-    if ([o_parent plItemId] == [_rootItem plItemId])
-        [_outlineView reloadData];
-    else // only reload leafs this way, doing it with nil collapses width of title column
-        [_outlineView reloadItem:o_parent reloadChildren:YES];
-}
-
-- (void)removeItem:(int)i_item
-{
-    VLCPLItem *o_item = [self findItemByPlaylistId:i_item];
-    if (!o_item) {
-        return;
-    }
-
-    VLCPLItem *o_parent = [o_item parent];
-    [o_parent deleteChild:o_item];
-
-    if ([o_parent plItemId] == [_rootItem plItemId])
-        [_outlineView reloadData];
-    else
-        [_outlineView reloadItem:o_parent reloadChildren:YES];
-}
-
-- (void)updateItem:(input_item_t *)p_input_item
-{
-    PL_LOCK;
-    playlist_item_t *pl_item = playlist_ItemGetByInput(p_playlist, p_input_item);
-    if (!pl_item) {
-        PL_UNLOCK;
-        return;
-    }
-    VLCPLItem *item = [self findItemByPlaylistId:pl_item->i_id];
-    PL_UNLOCK;
-
-    if (!item)
-        return;
-
-    NSInteger row = [_outlineView rowForItem:item];
-    if (row == -1)
-        return;
-
-    [_outlineView reloadDataForRowIndexes:[NSIndexSet indexSetWithIndex:row]
-                            columnIndexes:[NSIndexSet indexSetWithIndexesInRange:NSMakeRange(0, [[_outlineView tableColumns] count])]];
-
-}
-
-- (VLCPLItem *)currentlyPlayingItem
-{
-    VLCPLItem *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)playbackModeUpdated
-{
-    bool loop = var_GetBool(p_playlist, "loop");
-    bool repeat = var_GetBool(p_playlist, "repeat");
-
-    VLCMainWindowControlsBar *controlsBar = (VLCMainWindowControlsBar *)[[[VLCMain sharedInstance] mainWindow] controlsBar];
-    VLCMainMenu *mainMenu = [[VLCMain sharedInstance] mainMenu];
-    if (repeat) {
-        [controlsBar setRepeatOne];
-        [mainMenu setRepeatOne];
-    } else if (loop) {
-        [controlsBar setRepeatAll];
-        [mainMenu setRepeatAll];
-    } else {
-        [controlsBar setRepeatOff];
-        [mainMenu setRepeatOff];
-    }
-
-    [controlsBar setShuffle];
-    [mainMenu setShuffle];
-}
-
-#pragma mark -
-#pragma mark Sorting / Searching
-
-- (void)sortForColumn:(NSString *)o_column withMode:(int)i_mode
-{
-    int i_column = 0;
-    if ([o_column isEqualToString:TRACKNUM_COLUMN])
-        i_column = SORT_TRACK_NUMBER;
-    else if ([o_column isEqualToString:TITLE_COLUMN])
-        i_column = SORT_TITLE;
-    else if ([o_column isEqualToString:ARTIST_COLUMN])
-        i_column = SORT_ARTIST;
-    else if ([o_column isEqualToString:GENRE_COLUMN])
-        i_column = SORT_GENRE;
-    else if ([o_column isEqualToString:DURATION_COLUMN])
-        i_column = SORT_DURATION;
-    else if ([o_column isEqualToString:ALBUM_COLUMN])
-        i_column = SORT_ALBUM;
-    else if ([o_column isEqualToString:DESCRIPTION_COLUMN])
-        i_column = SORT_DESCRIPTION;
-    else if ([o_column isEqualToString:URI_COLUMN])
-        i_column = SORT_URI;
-    else
-        return;
-
-    PL_LOCK;
-    playlist_item_t *p_root = playlist_ItemGetById(p_playlist, [_rootItem plItemId]);
-    if (!p_root) {
-        PL_UNLOCK;
-        return;
-    }
-
-    playlist_RecursiveNodeSort(p_playlist, p_root, i_column, i_mode);
-
-    [self rebuildVLCPLItem:_rootItem];
-    [_outlineView reloadData];
-    PL_UNLOCK;
-}
-
-- (void)searchUpdate:(NSString *)o_search
-{
-    PL_LOCK;
-    playlist_item_t *p_root = playlist_ItemGetById(p_playlist, [_rootItem plItemId]);
-    if (!p_root) {
-        PL_UNLOCK;
-        return;
-    }
-    playlist_LiveSearchUpdate(p_playlist, p_root, [o_search UTF8String],
-                              true);
-    [self rebuildVLCPLItem:_rootItem];
-    [_outlineView reloadData];
-    PL_UNLOCK;
-}
-
-@end
-
-#pragma mark -
-#pragma mark Outline view data source
-
-@implementation VLCPLModel(NSOutlineViewDataSource)
-
-- (NSInteger)outlineView:(NSOutlineView *)outlineView numberOfChildrenOfItem:(id)item
-{
-    return !item ? [[_rootItem children] count] : [[item children] count];
-}
-
-- (BOOL)outlineView:(NSOutlineView *)outlineView isItemExpandable:(id)item
-{
-    return !item ? YES : [[item children] count] > 0;
-}
-
-- (id)outlineView:(NSOutlineView *)outlineView child:(NSInteger)index ofItem:(id)item
-{
-    id obj = !item ? _rootItem : item;
-    return [[obj children] objectAtIndex:index];
-}
-
-- (id)outlineView:(NSOutlineView *)outlineView objectValueForTableColumn:(NSTableColumn *)tableColumn byItem:(id)item
-{
-    id o_value = nil;
-    char *psz_value;
-
-    input_item_t *p_input = [item input];
-
-    NSString * o_identifier = [tableColumn identifier];
-
-    if ([o_identifier isEqualToString:TRACKNUM_COLUMN]) {
-        psz_value = input_item_GetTrackNumber(p_input);
-        o_value = toNSStr(psz_value);
-        free(psz_value);
-
-    } else if ([o_identifier isEqualToString:TITLE_COLUMN]) {
-        psz_value = input_item_GetTitleFbName(p_input);
-        o_value = toNSStr(psz_value);
-        free(psz_value);
-
-    } else if ([o_identifier isEqualToString:ARTIST_COLUMN]) {
-        psz_value = input_item_GetArtist(p_input);
-        o_value = toNSStr(psz_value);
-        free(psz_value);
-
-    } else if ([o_identifier isEqualToString:DURATION_COLUMN]) {
-        char psz_duration[MSTRTIME_MAX_SIZE];
-        vlc_tick_t dur = input_item_GetDuration(p_input);
-        if (dur != -1) {
-            secstotimestr(psz_duration, (int32_t)SEC_FROM_VLC_TICK(dur));
-            o_value = toNSStr(psz_duration);
-        }
-        else
-            o_value = @"--:--";
-
-    } else if ([o_identifier isEqualToString:GENRE_COLUMN]) {
-        psz_value = input_item_GetGenre(p_input);
-        o_value = toNSStr(psz_value);
-        free(psz_value);
-
-    } else if ([o_identifier isEqualToString:ALBUM_COLUMN]) {
-        psz_value = input_item_GetAlbum(p_input);
-        o_value = toNSStr(psz_value);
-        free(psz_value);
-
-    } else if ([o_identifier isEqualToString:DESCRIPTION_COLUMN]) {
-        psz_value = input_item_GetDescription(p_input);
-        o_value = toNSStr(psz_value);
-        free(psz_value);
-
-    } else if ([o_identifier isEqualToString:DATE_COLUMN]) {
-        psz_value = input_item_GetDate(p_input);
-        o_value = toNSStr(psz_value);
-        free(psz_value);
-
-    } else if ([o_identifier isEqualToString:LANGUAGE_COLUMN]) {
-        psz_value = input_item_GetLanguage(p_input);
-        o_value = toNSStr(psz_value);
-        free(psz_value);
-
-    } else if ([o_identifier isEqualToString:URI_COLUMN]) {
-        psz_value = vlc_uri_decode(input_item_GetURI(p_input));
-        o_value = toNSStr(psz_value);
-        free(psz_value);
-
-    } else if ([o_identifier isEqualToString:FILESIZE_COLUMN]) {
-        psz_value = input_item_GetURI(p_input);
-        if (!psz_value)
-            return @"";
-        NSURL *url = [NSURL URLWithString:toNSStr(psz_value)];
-        free(psz_value);
-        if (![url isFileURL])
-            return @"";
-
-        NSFileManager *fileManager = [NSFileManager defaultManager];
-        BOOL b_isDir;
-        if (![fileManager fileExistsAtPath:[url path] isDirectory:&b_isDir] || b_isDir)
-            return @"";
-
-        NSDictionary *attributes = [fileManager attributesOfItemAtPath:[url path] error:nil];
-        if (!attributes)
-            return @"";
-
-        o_value = [VLCByteCountFormatter stringFromByteCount:[attributes fileSize] countStyle:NSByteCountFormatterCountStyleDecimal];
-
-    } else if ([o_identifier isEqualToString:STATUS_COLUMN]) {
-        if (input_item_HasErrorWhenReading(p_input)) {
-            o_value = [[NSWorkspace sharedWorkspace] iconForFileType:NSFileTypeForHFSTypeCode(kAlertCautionIcon)];
-            [o_value setSize: NSMakeSize(16,16)];
-        }
-    }
-
-    return o_value;
-}
-
-#pragma mark -
-#pragma mark Drag and Drop support
-
-- (BOOL)isItem: (VLCPLItem *)p_item inNode: (VLCPLItem *)p_node
-{
-    while(p_item) {
-        if ([p_item plItemId] == [p_node plItemId]) {
-            return YES;
-        }
-
-        p_item = [p_item parent];
-    }
-
-    return NO;
-}
-
-- (BOOL)outlineView:(NSOutlineView *)outlineView writeItems:(NSArray *)items toPasteboard:(NSPasteboard *)pboard
-{
-    _draggedItems = [[NSMutableArray alloc] initWithArray:items];
-
-    /* Add the data to the pasteboard object. */
-    [pboard declareTypes: [NSArray arrayWithObject:VLCPLItemPasteboadType] owner: self];
-    [pboard setData:[NSData data] forType:VLCPLItemPasteboadType];
-
-    return YES;
-}
-
-- (NSDragOperation)outlineView:(NSOutlineView *)outlineView validateDrop:(id <NSDraggingInfo>)info proposedItem:(id)item proposedChildIndex:(NSInteger)index
-{
-    NSPasteboard *o_pasteboard = [info draggingPasteboard];
-
-    /* Dropping ON items is not allowed if item is not a node */
-    if (item) {
-        if (index == NSOutlineViewDropOnItemIndex && [item isLeaf]) {
-            return NSDragOperationNone;
-        }
-    }
-
-    if (![self editAllowed])
-        return NSDragOperationNone;
-
-    /* Drop from the Playlist */
-    if ([[o_pasteboard types] containsObject:VLCPLItemPasteboadType]) {
-        NSUInteger count = [_draggedItems count];
-        for (NSUInteger i = 0 ; i < count ; i++) {
-            /* We refuse to Drop in a child of an item we are moving */
-            if ([self isItem: item inNode: [_draggedItems objectAtIndex:i]]) {
-                return NSDragOperationNone;
-            }
-        }
-        return NSDragOperationMove;
-    }
-    /* Drop from the Finder */
-    else if ([[o_pasteboard types] containsObject: NSFilenamesPboardType]) {
-        return NSDragOperationGeneric;
-    }
-    return NSDragOperationNone;
-}
-
-- (BOOL)outlineView:(NSOutlineView *)outlineView acceptDrop:(id <NSDraggingInfo>)info item:(id)targetItem childIndex:(NSInteger)index
-{
-    NSPasteboard *o_pasteboard = [info draggingPasteboard];
-
-    if (targetItem == nil) {
-        targetItem = _rootItem;
-    }
-
-    /* Drag & Drop inside the playlist */
-    if ([[o_pasteboard types] containsObject:VLCPLItemPasteboadType]) {
-
-        NSMutableArray *o_filteredItems = [NSMutableArray arrayWithArray:_draggedItems];
-        const NSUInteger draggedItemsCount = [_draggedItems count];
-        for (NSInteger i = 0; i < [o_filteredItems count]; i++) {
-            for (NSUInteger j = 0; j < draggedItemsCount; j++) {
-                VLCPLItem *itemToCheck = [o_filteredItems objectAtIndex:i];
-                VLCPLItem *nodeToTest = [_draggedItems objectAtIndex:j];
-                if ([itemToCheck plItemId] == [nodeToTest plItemId])
-                    continue;
-
-                if ([self isItem:itemToCheck inNode:nodeToTest]) {
-                    [o_filteredItems removeObjectAtIndex:i];
-                    --i;
-                    break;
-                }
-            }
-        }
-
-        NSUInteger count = [o_filteredItems count];
-        if (count == 0)
-            return NO;
-
-        playlist_item_t **pp_items = (playlist_item_t **)calloc(count, sizeof(playlist_item_t*));
-        if (!pp_items)
-            return NO;
-
-        PL_LOCK;
-        playlist_item_t *p_new_parent = playlist_ItemGetById(p_playlist, [targetItem plItemId]);
-        if (!p_new_parent) {
-            PL_UNLOCK;
-            free(pp_items);
-            return NO;
-        }
-
-        int j = 0;
-        for (int i = 0; i < count; i++) {
-            playlist_item_t *p_item = playlist_ItemGetById(p_playlist, [[o_filteredItems objectAtIndex:i] plItemId]);
-            if (p_item)
-                pp_items[j++] = p_item;
-        }
-
-        // drop on a node itself will append entries at the end
-        if (index == NSOutlineViewDropOnItemIndex)
-            index = p_new_parent->i_children;
-
-        if (playlist_TreeMoveMany(p_playlist, j, pp_items, p_new_parent, (int)index) != VLC_SUCCESS) {
-            PL_UNLOCK;
-            free(pp_items);
-            return NO;
-        }
-
-        PL_UNLOCK;
-        free(pp_items);
-
-        // FIXME: Fix below code to avoid rebuilding the whole model
-        // rebuild our model
-//        NSUInteger filteredItemsCount = [o_filteredItems count];
-//        for(int i = 0; i < filteredItemsCount; ++i) {
-//            VLCPLItem *o_item = [o_filteredItems objectAtIndex:i];
-//            NSLog(@"delete child from parent %p", [o_item parent]);
-//            [[o_item parent] deleteChild:o_item];
-//            [targetItem addChild:o_item atPos:(int)index + i];
-//        }
-
-        PL_LOCK;
-        [self rebuildVLCPLItem:_rootItem];
-        PL_UNLOCK;
-
-        [_outlineView reloadData];
-
-        NSMutableIndexSet *selectedIndexes = [[NSMutableIndexSet alloc] init];
-        for(NSUInteger i = 0; i < draggedItemsCount; ++i) {
-            NSInteger row = [_outlineView rowForItem:[_draggedItems objectAtIndex:i]];
-            if (row < 0)
-                continue;
-
-            [selectedIndexes addIndex:row];
-        }
-
-        if ([selectedIndexes count] == 0)
-            [selectedIndexes addIndex:[_outlineView rowForItem:targetItem]];
-
-        [_outlineView selectRowIndexes:selectedIndexes byExtendingSelection:NO];
-
-        return YES;
-    }
-
-    // try file drop
-
-    // drop on a node itself will append entries at the end
-    static_assert(NSOutlineViewDropOnItemIndex == -1, "Expect NSOutlineViewDropOnItemIndex to be -1");
-
-    NSArray *items = [[[VLCMain sharedInstance] playlist] createItemsFromExternalPasteboard:o_pasteboard];
-    if (items.count == 0)
-        return NO;
-
-    [[[VLCMain sharedInstance] playlist] addPlaylistItems:items
-                                         withParentItemId:[targetItem plItemId]
-                                                    atPos:(int)index
-                                            startPlayback:NO];
-    return YES;
-}
-
-@end
diff --git a/modules/gui/macosx/VLCPlaylist.h b/modules/gui/macosx/VLCPlaylist.h
deleted file mode 100644
index e499bfe3323c99217842a66fbe7a98befeca1adf..0000000000000000000000000000000000000000
--- a/modules/gui/macosx/VLCPlaylist.h
+++ /dev/null
@@ -1,100 +0,0 @@
-/*****************************************************************************
- * VLCPlaylist.h: MacOS X interface module
- *****************************************************************************
- * Copyright (C) 2002-2015 VLC authors and VideoLAN
- *
- * Authors: Benjamin Pracht <bigben at videolab dot org>
- *          Felix Paul Kühne <fkuehne at videolan dot org>
- *          David Fuhrmann <david dot fuhrmann at googlemail dot com>
- *
- * 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
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
- *****************************************************************************/
-
-#import "VLCPLModel.h"
-#import "VLCPlaylistView.h"
-
-@interface VLCPlaylist : NSResponder<NSOutlineViewDelegate>
-
-@property (readwrite, strong) IBOutlet NSMenu *playlistMenu;
-@property (readwrite, weak) IBOutlet NSMenuItem *playPlaylistMenuItem;
-@property (readwrite, weak) IBOutlet NSMenuItem *deletePlaylistMenuItem;
-@property (readwrite, weak) IBOutlet NSMenuItem *infoPlaylistMenuItem;
-@property (readwrite, weak) IBOutlet NSMenuItem *revealInFinderPlaylistMenuItem;
-@property (readwrite, weak) IBOutlet NSMenuItem *selectAllPlaylistMenuItem;
-@property (readwrite, weak) IBOutlet NSMenuItem *recursiveExpandPlaylistMenuItem;
-@property (readwrite, weak) IBOutlet NSMenuItem *recursiveCollapsePlaylistMenuItem;
-@property (readwrite, weak) IBOutlet NSMenuItem *addFilesToPlaylistMenuItem;
-
-@property (nonatomic, readwrite, weak) VLCPlaylistView *outlineView;
-@property (nonatomic, readwrite, weak) NSTableHeaderView *playlistHeaderView;
-
-- (VLCPLModel *)model;
-
-- (void)reloadStyles;
-
-- (NSMenu *)menuForEvent:(NSEvent *)o_event;
-
-- (void)playlistUpdated;
-- (void)playbackModeUpdated;
-
-- (void)currentlyPlayingItemChanged;
-
-- (BOOL)isSelectionEmpty;
-
-- (IBAction)playItem:(id)sender;
-- (IBAction)revealItemInFinder:(id)sender;
-- (IBAction)deleteItem:(id)sender;
-- (IBAction)selectAll:(id)sender;
-- (IBAction)recursiveExpandOrCollapseNode:(id)sender;
-- (IBAction)showInfoPanel:(id)sender;
-- (IBAction)addFilesToPlaylist:(id)sender;
-
-- (NSArray *)draggedItems;
-
-- (BOOL)performDragOperation:(id <NSDraggingInfo>)sender;
-
-/**
- * Prepares an array of playlist items for all suitable pasteboard types.
- *
- * This function checks external pasteboard objects (like files). If suitable,
- * an array of all objects is prepared.
- */
-- (NSArray *)createItemsFromExternalPasteboard:(NSPasteboard *)pasteboard;
-
-/**
- * Simplified version to add new items at the end of the current playlist
- * @param array array of items. Each item is a Dictionary with meta info.
- */
-- (void)addPlaylistItems:(NSArray*)array;
-
-/**
- * Add new items to playlist, with the possibility to check if an item can be added
- * to the currently playing media as subtitle.
- *
- * @param array array of items. Each item is a Dictionary with meta info.
- * @param isSubtitle if YES, method tries to add the item as a subtitle
- */
-- (void)addPlaylistItems:(NSArray*)array tryAsSubtitle:(BOOL)isSubtitle;
-
-/**
- * Adds new items to the playlist, at specified parent node and index.
- * @param o_array array of items. Each item is a Dictionary with meta info.
- * @param i_plItemId parent playlist node id, -1 for default playlist
- * @param i_position index for new items, -1 for appending at end
- * @param b_start starts playback of first item if true
- */
-- (void)addPlaylistItems:(NSArray*)o_array withParentItemId:(int)i_plItemId atPos:(int)i_position startPlayback:(BOOL)b_start;
-
-@end
diff --git a/modules/gui/macosx/VLCPlaylist.m b/modules/gui/macosx/VLCPlaylist.m
deleted file mode 100644
index af526615b0eb9b46b958f8565e4622cfc4db4966..0000000000000000000000000000000000000000
--- a/modules/gui/macosx/VLCPlaylist.m
+++ /dev/null
@@ -1,777 +0,0 @@
-/*****************************************************************************
- * VLCPlaylist.m: MacOS X interface module
- *****************************************************************************
-* Copyright (C) 2002-2015 VLC authors and VideoLAN
- *
- * Authors: Derk-Jan Hartman <hartman at videola/n dot org>
- *          Benjamin Pracht <bigben at videolan dot org>
- *          Felix Paul Kühne <fkuehne at videolan dot org>
- *          David Fuhrmann <david dot fuhrmann at googlemail dot com>
- *
- * 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
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
- *****************************************************************************/
-
-/* TODO
- * add 'icons' for different types of nodes? (http://www.cocoadev.com/index.pl?IconAndTextInTableCell)
- * reimplement enable/disable item
- */
-
-
-/*****************************************************************************
- * Preamble
- *****************************************************************************/
-#include <stdlib.h>                                      /* malloc(), free() */
-#include <sys/param.h>                                    /* for MAXPATHLEN */
-#include <string.h>
-#include <math.h>
-#include <sys/mount.h>
-
-#import "CompatibilityFixes.h"
-
-#import "VLCMain.h"
-#import "VLCPlaylist.h"
-#import "VLCMainMenu.h"
-#import "VLCPlaylistInfo.h"
-#import "VLCResumeDialogController.h"
-#import "VLCOpenWindowController.h"
-
-#import "PXSourceList/PXSourceList.h"
-
-#include <vlc_actions.h>
-#import <vlc_interface.h>
-#include <vlc_url.h>
-
-@interface VLCPlaylist ()
-{
-    NSImage *_descendingSortingImage;
-    NSImage *_ascendingSortingImage;
-
-    BOOL b_selected_item_met;
-    BOOL b_isSortDescending;
-    NSTableColumn *_sortTableColumn;
-
-    BOOL b_playlistmenu_nib_loaded;
-
-    VLCPLModel *_model;
-
-    // information for playlist table columns menu
-
-    NSDictionary *_translationsForPlaylistTableColumns;
-    NSArray *_menuOrderOfPlaylistTableColumns;
-}
-
-- (void)saveTableColumns;
-@end
-
-@implementation VLCPlaylist
-
-- (id)init
-{
-    self = [super init];
-    if (self) {
-        _ascendingSortingImage = [NSImage imageNamed:@"NSAscendingSortIndicator"];
-        _descendingSortingImage = [NSImage imageNamed:@"NSDescendingSortIndicator"];
-
-        [[NSNotificationCenter defaultCenter] addObserver: self selector: @selector(applicationWillTerminate:) name: NSApplicationWillTerminateNotification object: nil];
-
-
-        _translationsForPlaylistTableColumns = [[NSDictionary alloc] initWithObjectsAndKeys:
-                                                _NS("Track Number"),  TRACKNUM_COLUMN,
-                                                _NS("Title"),         TITLE_COLUMN,
-                                                _NS("Author"),        ARTIST_COLUMN,
-                                                _NS("Duration"),      DURATION_COLUMN,
-                                                _NS("Genre"),         GENRE_COLUMN,
-                                                _NS("Album"),         ALBUM_COLUMN,
-                                                _NS("Description"),   DESCRIPTION_COLUMN,
-                                                _NS("Date"),          DATE_COLUMN,
-                                                _NS("Language"),      LANGUAGE_COLUMN,
-                                                _NS("URI"),           URI_COLUMN,
-                                                _NS("File Size"),     FILESIZE_COLUMN,
-                                                nil];
-        // this array also assigns tags (index) to type of menu item
-        _menuOrderOfPlaylistTableColumns = [[NSArray alloc] initWithObjects: TRACKNUM_COLUMN, TITLE_COLUMN,
-                                            ARTIST_COLUMN, DURATION_COLUMN, GENRE_COLUMN, ALBUM_COLUMN,
-                                            DESCRIPTION_COLUMN, DATE_COLUMN, LANGUAGE_COLUMN, URI_COLUMN,
-                                            FILESIZE_COLUMN,nil];
-
-    }
-    return self;
-}
-
-+ (void)initialize
-{
-    NSUserDefaults *defaults = [NSUserDefaults standardUserDefaults];
-    NSMutableArray *columnArray = [[NSMutableArray alloc] init];
-    [columnArray addObject: [NSArray arrayWithObjects:TITLE_COLUMN, [NSNumber numberWithFloat:190.], nil]];
-    [columnArray addObject: [NSArray arrayWithObjects:ARTIST_COLUMN, [NSNumber numberWithFloat:95.], nil]];
-    [columnArray addObject: [NSArray arrayWithObjects:DURATION_COLUMN, [NSNumber numberWithFloat:95.], nil]];
-
-    NSDictionary *appDefaults = [NSDictionary dictionaryWithObjectsAndKeys:
-                                 [NSArray arrayWithArray:columnArray], @"PlaylistColumnSelection", nil];
-
-    [defaults registerDefaults:appDefaults];
-}
-
-- (VLCPLModel *)model
-{
-    return _model;
-}
-
-- (void)reloadStyles
-{
-    NSFont *fontToUse;
-    CGFloat rowHeight;
-    if (var_InheritBool(getIntf(), "macosx-large-text")) {
-        fontToUse = [NSFont systemFontOfSize:13.];
-        rowHeight = 21.;
-    } else {
-        fontToUse = [NSFont systemFontOfSize:11.];
-        rowHeight = 16.;
-    }
-
-    NSArray *columns = [_outlineView tableColumns];
-    NSUInteger count = columns.count;
-    for (NSUInteger x = 0; x < count; x++)
-        [[[columns objectAtIndex:x] dataCell] setFont:fontToUse];
-    [_outlineView setRowHeight:rowHeight];
-}
-
-- (void)awakeFromNib
-{
-    // This is only called for the playlist popup menu
-    [self initStrings];
-}
-
-- (void)setOutlineView:(VLCPlaylistView * __nullable)outlineView
-{
-    _outlineView = outlineView;
-    [_outlineView setDelegate:self];
-
-    playlist_t * p_playlist = pl_Get(getIntf());
-
-    _model = [[VLCPLModel alloc] initWithOutlineView:_outlineView playlist:p_playlist rootItem:p_playlist->p_playing];
-    [_outlineView setDataSource:_model];
-    [_outlineView reloadData];
-
-    [_outlineView setTarget: self];
-    [_outlineView setDoubleAction: @selector(playItem:)];
-
-    [_outlineView setAllowsEmptySelection: NO];
-    [_outlineView registerForDraggedTypes: [NSArray arrayWithObjects:NSFilenamesPboardType, @"VLCPlaylistItemPboardType", nil]];
-    [_outlineView setIntercellSpacing: NSMakeSize (0.0, 1.0)];
-
-    [self reloadStyles];
-}
-
-- (void)setPlaylistHeaderView:(NSTableHeaderView * __nullable)playlistHeaderView
-{
-    _playlistHeaderView = playlistHeaderView;
-
-    // Setup playlist table column selection for both context and main menu
-    NSMenu *contextMenu = [[NSMenu alloc] init];
-    [self setupPlaylistTableColumnsForMenu:contextMenu];
-    [_playlistHeaderView setMenu:contextMenu];
-    [self setupPlaylistTableColumnsForMenu:[[[VLCMain sharedInstance] mainMenu] playlistTableColumnsMenu]];
-
-    NSArray *columnArray = [[NSUserDefaults standardUserDefaults] arrayForKey:@"PlaylistColumnSelection"];
-
-    BOOL hasTitleItem = NO;
-
-    for (NSArray *column in columnArray) {
-        NSString *columnName = column[0];
-        NSNumber *columnWidth = column[1];
-
-        if ([columnName isEqualToString:STATUS_COLUMN])
-            continue;
-
-        // Memorize if we custom set always-enabled title item
-        if ([columnName isEqualToString:TITLE_COLUMN]) {
-            hasTitleItem = YES;
-        }
-
-        if(![self setPlaylistColumnTableState: NSOnState forColumn:columnName])
-            continue;
-
-        [[_outlineView tableColumnWithIdentifier:columnName] setWidth:[columnWidth floatValue]];
-    }
-
-    // Set the always enabled title item if not already done
-    if (!hasTitleItem)
-        [self setPlaylistColumnTableState:NSOnState forColumn:TITLE_COLUMN];
-}
-
-- (void)applicationWillTerminate:(NSNotification *)notification
-{
-    /* let's make sure we save the correct widths and positions, since this likely changed since the last time the user played with the column selection */
-    [self saveTableColumns];
-}
-
-- (void)initStrings
-{
-    [_playPlaylistMenuItem setTitle: _NS("Play")];
-    [_deletePlaylistMenuItem setTitle: _NS("Delete")];
-    [_recursiveExpandPlaylistMenuItem setTitle: _NS("Expand All")];
-    [_recursiveCollapsePlaylistMenuItem setTitle: _NS("Collapse All")];
-    [_selectAllPlaylistMenuItem setTitle: _NS("Select All")];
-    [_infoPlaylistMenuItem setTitle: _NS("Media Information...")];
-    [_revealInFinderPlaylistMenuItem setTitle: _NS("Reveal in Finder")];
-    [_addFilesToPlaylistMenuItem setTitle: _NS("Add File...")];
-}
-
-- (void)playlistUpdated
-{
-    [_outlineView reloadData];
-}
-
-- (void)playbackModeUpdated
-{
-    [_model playbackModeUpdated];
-}
-
-
-- (BOOL)isSelectionEmpty
-{
-    return [_outlineView selectedRow] == -1;
-}
-
-- (void)currentlyPlayingItemChanged
-{
-    VLCPLItem *item = [[self model] currentlyPlayingItem];
-    if (!item)
-        return;
-
-    // Search for item row for selection
-    NSInteger itemIndex = [_outlineView rowForItem:item];
-    if (itemIndex < 0) {
-        // Expand if needed. This must be done from root to child
-        // item in order to work
-        NSMutableArray *itemsToExpand = [NSMutableArray array];
-        VLCPLItem *tmpItem = [item parent];
-        while (tmpItem != nil) {
-            [itemsToExpand addObject:tmpItem];
-            tmpItem = [tmpItem parent];
-        }
-
-        for(int i = (int)itemsToExpand.count - 1; i >= 0; i--) {
-            VLCPLItem *currentItem = [itemsToExpand objectAtIndex:i];
-            [_outlineView expandItem: currentItem];
-        }
-    }
-
-    // Update highlight for currently playing item
-    [_outlineView reloadData];
-
-    // Search for row again
-    itemIndex = [_outlineView rowForItem:item];
-    if (itemIndex < 0) {
-        return;
-    }
-
-    [_outlineView selectRowIndexes: [NSIndexSet indexSetWithIndex: itemIndex] byExtendingSelection: NO];
-    [_outlineView scrollRowToVisible: itemIndex];
-}
-
-#pragma mark -
-#pragma mark Playlist actions
-
-/* When called retrieves the selected outlineview row and plays that node or item */
-- (IBAction)playItem:(id)sender
-{
-    playlist_t *p_playlist = pl_Get(getIntf());
-
-    // ignore clicks on column header when handling double action
-    if (sender == _outlineView && [_outlineView clickedRow] == -1)
-        return;
-
-    VLCPLItem *o_item = [_outlineView itemAtRow:[_outlineView selectedRow]];
-    if (!o_item)
-        return;
-
-    PL_LOCK;
-    playlist_item_t *p_item = playlist_ItemGetById(p_playlist, [o_item plItemId]);
-    playlist_item_t *p_node = playlist_ItemGetById(p_playlist, [[[self model] rootItem] plItemId]);
-
-    if (p_item && p_node) {
-        playlist_ViewPlay(p_playlist, p_node, p_item);
-    }
-    PL_UNLOCK;
-}
-
-- (IBAction)revealItemInFinder:(id)sender
-{
-    NSIndexSet *selectedRows = [_outlineView selectedRowIndexes];
-    if (selectedRows.count < 1)
-        return;
-
-    VLCPLItem *o_item = [_outlineView itemAtRow:selectedRows.firstIndex];
-
-    char *psz_url = input_item_GetURI([o_item input]);
-    if (!psz_url)
-        return;
-    char *psz_path = vlc_uri2path(psz_url);
-    NSString *path = toNSStr(psz_path);
-    free(psz_url);
-    free(psz_path);
-
-    msg_Dbg(getIntf(), "Reveal url %s in finder", [path UTF8String]);
-    [[NSWorkspace sharedWorkspace] selectFile: path inFileViewerRootedAtPath: path];
-}
-
-- (IBAction)selectAll:(id)sender
-{
-    [_outlineView selectAll: nil];
-}
-
-- (IBAction)showInfoPanel:(id)sender
-{
-    [[[VLCMain sharedInstance] currentMediaInfoPanel] toggleWindow:sender];
-}
-
-- (IBAction)addFilesToPlaylist:(id)sender
-{
-    NSIndexSet *selectedRows = [_outlineView selectedRowIndexes];
-
-    int position = -1;
-    VLCPLItem *parentItem = [[self model] rootItem];
-
-    if (selectedRows.count >= 1) {
-        position = (int)selectedRows.firstIndex + 1;
-        parentItem = [_outlineView itemAtRow:selectedRows.firstIndex];
-        if ([parentItem parent] != nil)
-            parentItem = [parentItem parent];
-    }
-
-    [[[VLCMain sharedInstance] open] openFileWithAction:^(NSArray *files) {
-        [self addPlaylistItems:files
-              withParentItemId:[parentItem plItemId]
-                         atPos:position
-                 startPlayback:NO];
-    }];
-}
-
-- (IBAction)deleteItem:(id)sender
-{
-    [_model deleteSelectedItem];
-    [[[[VLCMain sharedInstance] mainWindow] sidebarView] performSelector:@selector(reloadData) withObject:nil afterDelay:0.15];
-}
-
-// Actions for playlist column selections
-
-
-- (void)togglePlaylistColumnTable:(id)sender
-{
-    NSInteger i_new_state = ![sender state];
-    NSInteger i_tag = [sender tag];
-
-    NSString *column = [_menuOrderOfPlaylistTableColumns objectAtIndex:i_tag];
-
-    [self setPlaylistColumnTableState:i_new_state forColumn:column];
-}
-
-- (BOOL)setPlaylistColumnTableState:(NSInteger)i_state forColumn:(NSString *)columnId
-{
-    NSUInteger i_tag = [_menuOrderOfPlaylistTableColumns indexOfObject: columnId];
-    // prevent setting unknown columns
-    if(i_tag == NSNotFound)
-        return NO;
-
-    // update state of menu items
-    [[[_playlistHeaderView menu] itemWithTag: i_tag] setState: i_state];
-    [[[[[VLCMain sharedInstance] mainMenu] playlistTableColumnsMenu] itemWithTag: i_tag] setState: i_state];
-
-    // Change outline view
-    if (i_state == NSOnState) {
-        NSString *title = [_translationsForPlaylistTableColumns objectForKey:columnId];
-        if (!title)
-            return NO;
-
-        NSTableColumn *tableColumn = [[NSTableColumn alloc] initWithIdentifier:columnId];
-        [tableColumn setEditable:NO];
-        [[tableColumn dataCell] setFont:[NSFont controlContentFontOfSize:11.]];
-
-        [[tableColumn headerCell] setStringValue:[_translationsForPlaylistTableColumns objectForKey:columnId]];
-
-        if ([columnId isEqualToString: TRACKNUM_COLUMN]) {
-            [tableColumn setMinWidth:20.];
-            [tableColumn setMaxWidth:70.];
-            [[tableColumn headerCell] setStringValue:@"#"];
-
-        } else {
-            [tableColumn setMinWidth:42.];
-        }
-
-        [_outlineView addTableColumn:tableColumn];
-        [_outlineView reloadData];
-        [_outlineView setNeedsDisplay: YES];
-    }
-    else
-        [_outlineView removeTableColumn: [_outlineView tableColumnWithIdentifier:columnId]];
-
-    [_outlineView setOutlineTableColumn: [_outlineView tableColumnWithIdentifier:TITLE_COLUMN]];
-
-    return YES;
-}
-
-- (BOOL)validateMenuItem:(NSMenuItem *)item
-{
-    if ([item action] == @selector(revealItemInFinder:)) {
-        NSIndexSet *selectedRows = [_outlineView selectedRowIndexes];
-        if (selectedRows.count != 1)
-            return NO;
-
-        VLCPLItem *o_item = [_outlineView itemAtRow:selectedRows.firstIndex];
-
-        // Check if item exists in file system
-        char *psz_url = input_item_GetURI([o_item input]);
-        NSURL *url = [NSURL URLWithString:toNSStr(psz_url)];
-        free(psz_url);
-        if (![url isFileURL])
-            return NO;
-        if (![[NSFileManager defaultManager] fileExistsAtPath:[url path]])
-            return NO;
-
-    } else if ([item action] == @selector(deleteItem:)) {
-        return [_outlineView numberOfSelectedRows] > 0 && _model.editAllowed;
-    } else if ([item action] == @selector(selectAll:)) {
-        return [_outlineView numberOfRows] > 0;
-    } else if ([item action] == @selector(playItem:)) {
-        return [_outlineView numberOfSelectedRows] > 0;
-    } else if ([item action] == @selector(recursiveExpandOrCollapseNode:)) {
-        return [_outlineView numberOfSelectedRows] > 0;
-    } else if ([item action] == @selector(showInfoPanel:)) {
-        return [_outlineView numberOfSelectedRows] > 0;
-    }
-
-    return YES;
-}
-
-#pragma mark -
-#pragma mark Helper for playlist table columns
-
-- (void)setupPlaylistTableColumnsForMenu:(NSMenu *)menu
-{
-    NSMenuItem *menuItem;
-    NSUInteger count = [_menuOrderOfPlaylistTableColumns count];
-    for (NSUInteger i = 0; i < count; i++) {
-        NSString *columnId = [_menuOrderOfPlaylistTableColumns objectAtIndex:i];
-        NSString *title = [_translationsForPlaylistTableColumns objectForKey:columnId];
-        menuItem = [menu addItemWithTitle:title
-                                   action:@selector(togglePlaylistColumnTable:)
-                            keyEquivalent:@""];
-        [menuItem setTarget:self];
-        [menuItem setTag:i];
-
-        /* don't set a valid action for the title column selector, since we want it to be disabled */
-        if ([columnId isEqualToString: TITLE_COLUMN])
-            [menuItem setAction:nil];
-
-    }
-}
-
-- (void)saveTableColumns
-{
-    NSMutableArray *arrayToSave = [[NSMutableArray alloc] init];
-    NSArray *columns = [[NSArray alloc] initWithArray:[_outlineView tableColumns]];
-    NSUInteger columnCount = [columns count];
-    NSTableColumn *currentColumn;
-    for (NSUInteger i = 0; i < columnCount; i++) {
-        currentColumn = [columns objectAtIndex:i];
-        [arrayToSave addObject:[NSArray arrayWithObjects:[currentColumn identifier], [NSNumber numberWithFloat:[currentColumn width]], nil]];
-    }
-    [[NSUserDefaults standardUserDefaults] setObject:arrayToSave forKey:@"PlaylistColumnSelection"];
-    [[NSUserDefaults standardUserDefaults] synchronize];
-}
-
-#pragma mark -
-#pragma mark Item helpers
-
-- (BOOL)performDragOperation:(id <NSDraggingInfo>)sender
-{
-    NSArray *items = [self createItemsFromExternalPasteboard:[sender draggingPasteboard]];
-
-    if (items.count == 0)
-        return NO;
-
-    [self addPlaylistItems:items tryAsSubtitle:YES];
-    return YES;
-}
-
-- (input_item_t *)createItem:(NSDictionary *)itemToCreateDict
-{
-    intf_thread_t *p_intf = getIntf();
-
-    input_item_t *p_input;
-    BOOL b_rem = FALSE, b_dir = FALSE, b_writable = FALSE;
-    NSString *uri, *name, *path;
-    NSURL * url;
-    NSArray *optionsArray;
-
-    /* Get the item */
-    uri = (NSString *)[itemToCreateDict objectForKey: @"ITEM_URL"];
-    url = [NSURL URLWithString: uri];
-    path = [url path];
-    name = (NSString *)[itemToCreateDict objectForKey: @"ITEM_NAME"];
-    optionsArray = (NSArray *)[itemToCreateDict objectForKey: @"ITEM_OPTIONS"];
-
-    if ([[NSFileManager defaultManager] fileExistsAtPath:path isDirectory:&b_dir] && b_dir &&
-        [[NSWorkspace sharedWorkspace] getFileSystemInfoForPath:path isRemovable: &b_rem
-                                                     isWritable:&b_writable isUnmountable:NULL description:NULL type:NULL] && b_rem && !b_writable && [url isFileURL]) {
-
-        NSString *diskType = getVolumeTypeFromMountPath(path);
-        msg_Dbg(p_intf, "detected optical media of type %s in the file input", [diskType UTF8String]);
-
-        if ([diskType isEqualToString: kVLCMediaDVD])
-            uri = [NSString stringWithFormat: @"dvdnav://%@", getBSDNodeFromMountPath(path)];
-        else if ([diskType isEqualToString: kVLCMediaVideoTSFolder])
-            uri = [NSString stringWithFormat: @"dvdnav://%@", path];
-        else if ([diskType isEqualToString: kVLCMediaAudioCD])
-            uri = [NSString stringWithFormat: @"cdda://%@", getBSDNodeFromMountPath(path)];
-        else if ([diskType isEqualToString: kVLCMediaVCD])
-            uri = [NSString stringWithFormat: @"vcd://%@#0:0", getBSDNodeFromMountPath(path)];
-        else if ([diskType isEqualToString: kVLCMediaSVCD])
-            uri = [NSString stringWithFormat: @"vcd://%@@0:0", getBSDNodeFromMountPath(path)];
-        else if ([diskType isEqualToString: kVLCMediaBD] || [diskType isEqualToString: kVLCMediaBDMVFolder])
-            uri = [NSString stringWithFormat: @"bluray://%@", path];
-        else
-            msg_Warn(getIntf(), "unknown disk type, treating %s as regular input", [path UTF8String]);
-
-        p_input = input_item_New([uri UTF8String], [[[NSFileManager defaultManager] displayNameAtPath:path] UTF8String]);
-    }
-    else
-        p_input = input_item_New([uri fileSystemRepresentation], name ? [name UTF8String] : NULL);
-
-    if (!p_input)
-        return NULL;
-
-    if (optionsArray) {
-        NSUInteger count = [optionsArray count];
-        for (NSUInteger i = 0; i < count; i++)
-            input_item_AddOption(p_input, [[optionsArray objectAtIndex:i] UTF8String], VLC_INPUT_OPTION_TRUSTED);
-    }
-
-    /* Recent documents menu */
-    if (url != nil && var_InheritBool(getIntf(), "macosx-recentitems"))
-        [[NSDocumentController sharedDocumentController] noteNewRecentDocumentURL:url];
-
-    return p_input;
-}
-
-- (NSArray *)createItemsFromExternalPasteboard:(NSPasteboard *)pasteboard
-{
-    NSArray *o_array = [NSArray array];
-    if (![[pasteboard types] containsObject: NSFilenamesPboardType])
-        return o_array;
-
-    NSArray *o_values = [[pasteboard propertyListForType: NSFilenamesPboardType] sortedArrayUsingSelector:@selector(caseInsensitiveCompare:)];
-    NSUInteger count = [o_values count];
-
-    for (NSUInteger i = 0; i < count; i++) {
-        NSDictionary *o_dic;
-        char *psz_uri = vlc_path2uri([[o_values objectAtIndex:i] UTF8String], NULL);
-        if (!psz_uri)
-            continue;
-
-        o_dic = [NSDictionary dictionaryWithObject:toNSStr(psz_uri) forKey:@"ITEM_URL"];
-        free(psz_uri);
-
-        o_array = [o_array arrayByAddingObject: o_dic];
-    }
-
-    return o_array;
-}
-
-- (void)addPlaylistItems:(NSArray*)array
-{
-
-    int i_plItemId = -1;
-
-    BOOL b_autoplay = var_InheritBool(getIntf(), "macosx-autoplay");
-
-    [self addPlaylistItems:array withParentItemId:i_plItemId atPos:-1 startPlayback:b_autoplay];
-}
-
-- (void)addPlaylistItems:(NSArray*)array tryAsSubtitle:(BOOL)isSubtitle
-{
-    input_thread_t *p_input = pl_CurrentInput(getIntf());
-    if (isSubtitle && array.count == 1 && p_input) {
-        int i_result = input_AddSlave(p_input, SLAVE_TYPE_SPU,
-                    [[[array firstObject] objectForKey:@"ITEM_URL"] UTF8String],
-                    true, true, true);
-        if (i_result == VLC_SUCCESS) {
-            vlc_object_release(p_input);
-            return;
-        }
-    }
-
-    if (p_input)
-        vlc_object_release(p_input);
-
-    [self addPlaylistItems:array];
-}
-
-- (void)addPlaylistItems:(NSArray*)array withParentItemId:(int)i_plItemId atPos:(int)i_position startPlayback:(BOOL)b_start
-{
-    playlist_t * p_playlist = pl_Get(getIntf());
-    PL_LOCK;
-
-    playlist_item_t *p_parent = NULL;
-    if (i_plItemId >= 0)
-        p_parent = playlist_ItemGetById(p_playlist, i_plItemId);
-    else
-        p_parent = p_playlist->p_playing;
-
-    if (!p_parent) {
-        PL_UNLOCK;
-        return;
-    }
-
-    NSUInteger count = [array count];
-    int i_current_offset = 0;
-    for (NSUInteger i = 0; i < count; ++i) {
-
-        NSDictionary *o_current_item = [array objectAtIndex:i];
-        input_item_t *p_input = [self createItem: o_current_item];
-        if (!p_input)
-            continue;
-
-        int i_pos = (i_position == -1) ? PLAYLIST_END : i_position + i_current_offset++;
-        playlist_item_t *p_item = playlist_NodeAddInput(p_playlist, p_input,
-                                                        p_parent, i_pos);
-        if (!p_item)
-            continue;
-
-        if (i == 0 && b_start) {
-            playlist_ViewPlay(p_playlist, p_parent, p_item);
-        }
-        input_item_Release(p_input);
-    }
-    PL_UNLOCK;
-    [[[[VLCMain sharedInstance] mainWindow] sidebarView] performSelector:@selector(reloadData) withObject:nil afterDelay:0.15];
-}
-
-- (IBAction)recursiveExpandOrCollapseNode:(id)sender
-{
-    bool expand = (sender == _recursiveExpandPlaylistMenuItem);
-
-    NSIndexSet * selectedRows = [_outlineView selectedRowIndexes];
-    NSUInteger count = [selectedRows count];
-    NSUInteger indexes[count];
-    [selectedRows getIndexes:indexes maxCount:count inIndexRange:nil];
-
-    id item;
-    for (NSUInteger i = 0; i < count; i++) {
-        item = [_outlineView itemAtRow: indexes[i]];
-
-        /* We need to collapse the node first, since OSX refuses to recursively
-         expand an already expanded node, even if children nodes are collapsed. */
-        if ([_outlineView isExpandable:item]) {
-            [_outlineView collapseItem: item collapseChildren: YES];
-
-            if (expand)
-                [_outlineView expandItem: item expandChildren: YES];
-        }
-
-        selectedRows = [_outlineView selectedRowIndexes];
-        [selectedRows getIndexes:indexes maxCount:count inIndexRange:nil];
-    }
-}
-
-- (NSMenu *)menuForEvent:(NSEvent *)o_event
-{
-    if (!b_playlistmenu_nib_loaded)
-        b_playlistmenu_nib_loaded = [[NSBundle mainBundle] loadNibNamed:@"PlaylistMenu" owner:self topLevelObjects:nil];
-
-    NSPoint pt = [_outlineView convertPoint: [o_event locationInWindow] fromView: nil];
-    NSInteger row = [_outlineView rowAtPoint:pt];
-    if (row != -1 && ![[_outlineView selectedRowIndexes] containsIndex: row])
-        [_outlineView selectRowIndexes:[NSIndexSet indexSetWithIndex:row] byExtendingSelection:NO];
-
-    // TODO Reenable once per-item info panel is supported again
-    _infoPlaylistMenuItem.hidden = YES;
-
-    return _playlistMenu;
-}
-
-- (void)outlineView:(NSOutlineView *)outlineView didClickTableColumn:(NSTableColumn *)aTableColumn
-{
-    int type = 0;
-    NSString * identifier = [aTableColumn identifier];
-
-    if (_sortTableColumn == aTableColumn)
-        b_isSortDescending = !b_isSortDescending;
-    else
-        b_isSortDescending = false;
-
-    if (b_isSortDescending)
-        type = ORDER_REVERSE;
-    else
-        type = ORDER_NORMAL;
-
-    [[self model] sortForColumn:identifier withMode:type];
-
-    /* Clear indications of any existing column sorting */
-    NSUInteger count = [[_outlineView tableColumns] count];
-    for (NSUInteger i = 0 ; i < count ; i++)
-        [_outlineView setIndicatorImage:nil inTableColumn: [[_outlineView tableColumns] objectAtIndex:i]];
-
-    [_outlineView setHighlightedTableColumn:nil];
-    _sortTableColumn = aTableColumn;
-    [_outlineView setHighlightedTableColumn:aTableColumn];
-
-    if (b_isSortDescending)
-        [_outlineView setIndicatorImage:_descendingSortingImage inTableColumn:aTableColumn];
-    else
-        [_outlineView setIndicatorImage:_ascendingSortingImage inTableColumn:aTableColumn];
-}
-
-
-- (void)outlineView:(NSOutlineView *)outlineView
-    willDisplayCell:(id)cell
-     forTableColumn:(NSTableColumn *)tableColumn
-               item:(id)item
-{
-    /* this method can be called when VLC is already dead, hence the extra checks */
-    intf_thread_t * p_intf = getIntf();
-    if (!p_intf)
-        return;
-    playlist_t *p_playlist = pl_Get(p_intf);
-
-    NSFont *fontToUse;
-    if (var_InheritBool(getIntf(), "macosx-large-text"))
-        fontToUse = [NSFont systemFontOfSize:13.];
-    else
-        fontToUse = [NSFont systemFontOfSize:11.];
-
-    BOOL b_is_playing = NO;
-    PL_LOCK;
-    playlist_item_t *p_current_item = playlist_CurrentPlayingItem(p_playlist);
-    if (p_current_item) {
-        b_is_playing = p_current_item->i_id == [item plItemId];
-    }
-    PL_UNLOCK;
-
-    if (b_is_playing)
-        [cell setFont: [[NSFontManager sharedFontManager] convertFont:fontToUse toHaveTrait:NSBoldFontMask]];
-    else
-        [cell setFont: [[NSFontManager sharedFontManager] convertFont:fontToUse toNotHaveTrait:NSBoldFontMask]];
-}
-
-// TODO remove method
-- (NSArray *)draggedItems
-{
-    return [[self model] draggedItems];
-}
-
-@end
diff --git a/modules/gui/macosx/VLCPlaylistInfo.m b/modules/gui/macosx/VLCPlaylistInfo.m
index 937338f1ed654c4a34898b0a8b2d549c0fc9ce21..e9c2cf2bf9bed2c39aa566623684cfdcf81fd687 100644
--- a/modules/gui/macosx/VLCPlaylistInfo.m
+++ b/modules/gui/macosx/VLCPlaylistInfo.m
@@ -24,7 +24,6 @@
 #import "CompatibilityFixes.h"
 #import "VLCMain.h"
 #import "VLCPlaylistInfo.h"
-#import "VLCPlaylist.h"
 #import <vlc_url.h>
 
 @interface VLCInfo () <NSOutlineViewDataSource>
diff --git a/modules/gui/macosx/VLCPlaylistView.h b/modules/gui/macosx/VLCPlaylistView.h
deleted file mode 100644
index 639b9d48b17da19ea960c29d83fd12b4a13c33f6..0000000000000000000000000000000000000000
--- a/modules/gui/macosx/VLCPlaylistView.h
+++ /dev/null
@@ -1,28 +0,0 @@
-/*****************************************************************************
- * VLCPlaylistView.h: OutlineView subclass for the playlist
- *****************************************************************************
- * Copyright (C) 2002-2015 VLC authors and VideoLAN
- *
- * Authors: Derk-Jan Hartman <hartman at videolan dot org>
- *          Felix Paul Kühne <fkuehne at videolan dot 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
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
- *****************************************************************************/
-
-#import <Cocoa/Cocoa.h>
-
-@interface VLCPlaylistView : NSOutlineView
-
-@end
diff --git a/modules/gui/macosx/VLCPlaylistView.m b/modules/gui/macosx/VLCPlaylistView.m
deleted file mode 100644
index 4c57a4a5e465e0d0492f94ac854f10b75145046b..0000000000000000000000000000000000000000
--- a/modules/gui/macosx/VLCPlaylistView.m
+++ /dev/null
@@ -1,79 +0,0 @@
-/*****************************************************************************
- * VLCPlaylistView.m: OutlineView subclass for the playlist
- *****************************************************************************
-* Copyright (C) 2003-2015 VLC authors and VideoLAN
- *
- * Authors: Derk-Jan Hartman <hartman at videola/n dot org>
- *          Benjamin Pracht <bigben at videolab dot org>
- *          Felix Paul Kühne <fkuehne at videolan dot 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
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
- *****************************************************************************/
-
-#import "VLCMain.h"
-#import "VLCPlaylistView.h"
-#import "VLCPlaylist.h"
-
-@implementation VLCPlaylistView
-
-- (NSMenu *)menuForEvent:(NSEvent *)event
-{
-    return([(VLCPlaylist *)[self delegate] menuForEvent: event]);
-}
-
-- (void)keyDown:(NSEvent *)event
-{
-    unichar key = 0;
-
-    if ([[event characters] length])
-        key = [[event characters] characterAtIndex: 0];
-
-    switch(key) {
-        case NSDeleteCharacter:
-        case NSDeleteFunctionKey:
-        case NSDeleteCharFunctionKey:
-        case NSBackspaceCharacter:
-            [(VLCPlaylist *)[self delegate] deleteItem:self];
-            break;
-
-        case NSEnterCharacter:
-        case NSCarriageReturnCharacter:
-            [(VLCPlaylist *)[[VLCMain sharedInstance] playlist] playItem:nil];
-            break;
-
-        default:
-            [super keyDown: event];
-            break;
-    }
-}
-
-- (BOOL)acceptsFirstResponder
-{
-    return YES;
-}
-
-- (BOOL)becomeFirstResponder
-{
-    [self setNeedsDisplay:YES];
-    return YES;
-}
-
-- (BOOL)resignFirstResponder
-{
-    [self setNeedsDisplay:YES];
-    return YES;
-}
-
-@end
diff --git a/modules/gui/macosx/VLCVideoOutputProvider.m b/modules/gui/macosx/VLCVideoOutputProvider.m
index c1748f40ab1cf552de86edc145df6573d53de621..eb463f6ba2294eee2bebf14c8ae82f4f5111a44f 100644
--- a/modules/gui/macosx/VLCVideoOutputProvider.m
+++ b/modules/gui/macosx/VLCVideoOutputProvider.m
@@ -36,7 +36,6 @@
 #import "VLCBookmarksWindowController.h"
 #import "VLCTrackSynchronizationWindowController.h"
 #import "VLCResumeDialogController.h"
-#import "VLCPlaylist.h"
 #import "NSScreen+VLCAdditions.h"
 
 static int WindowEnable(vout_window_t *p_wnd, const vout_window_cfg_t *cfg)
diff --git a/modules/gui/macosx/VLCVoutView.m b/modules/gui/macosx/VLCVoutView.m
index d5e31012d765cab1119d895ffe361d1494fb18f5..5cea84c6073b99736ef30c3a2cc425f463fb8193 100644
--- a/modules/gui/macosx/VLCVoutView.m
+++ b/modules/gui/macosx/VLCVoutView.m
@@ -34,7 +34,6 @@
 #import "VLCMain.h"
 #import "VLCCoreInteraction.h"
 #import "VLCVoutView.h"
-#import "VLCPlaylist.h"
 #import "VLCMainMenu.h"
 
 #import <QuartzCore/QuartzCore.h>
@@ -131,7 +130,8 @@
 
 - (BOOL)performDragOperation:(id <NSDraggingInfo>)sender
 {
-    BOOL b_returned = [[[VLCMain sharedInstance] playlist] performDragOperation:sender];
+    // FIXME: re-implement drag and drop of new input items to the playlist
+    BOOL b_returned = NO;
 
     [self setNeedsDisplay:YES];
     return b_returned;
diff --git a/modules/gui/macosx/misc.m b/modules/gui/macosx/misc.m
index 8e5c916f3883c2583e41dcbda3549ab3ddbbabda..02a6d09fecd2b6c611efdbaafd1683474899e274 100644
--- a/modules/gui/macosx/misc.m
+++ b/modules/gui/macosx/misc.m
@@ -25,7 +25,6 @@
 #import "misc.h"
 #import "VLCMainWindow.h"
 #import "VLCMain.h"
-#import "VLCPlaylist.h"
 #import "VLCMainMenu.h"
 #import "VLCControlsBarCommon.h"
 #import "VLCCoreInteraction.h"
@@ -119,12 +118,13 @@
 
 - (BOOL)performDragOperation:(id <NSDraggingInfo>)sender
 {
-    BOOL b_returned;
+    BOOL b_returned = NO;
 
     if (_dropHandler && [_dropHandler respondsToSelector:@selector(performDragOperation:)])
         b_returned = [_dropHandler performDragOperation:sender];
-    else // default
-        b_returned = [[[VLCMain sharedInstance] playlist] performDragOperation:sender];
+    // default
+        // FIXME: implement drag and drop _on_ new playlist
+//        b_returned = [[[VLCMain sharedInstance] playlist] performDragOperation:sender];
 
     [self setNeedsDisplay:YES];
     return b_returned;
diff --git a/po/POTFILES.in b/po/POTFILES.in
index a6c8400492199c9cc56895748b7584c7e8776864..d1fd2c6c038a8ea0db8259719c671b8a8d1b186c 100644
--- a/po/POTFILES.in
+++ b/po/POTFILES.in
@@ -509,18 +509,10 @@ modules/gui/macosx/VLCOpenWindowController.h
 modules/gui/macosx/VLCOpenWindowController.m
 modules/gui/macosx/VLCOutput.h
 modules/gui/macosx/VLCOutput.m
-modules/gui/macosx/VLCPLItem.h
-modules/gui/macosx/VLCPLItem.m
-modules/gui/macosx/VLCPLModel.h
-modules/gui/macosx/VLCPLModel.m
-modules/gui/macosx/VLCPlaylist.h
-modules/gui/macosx/VLCPlaylist.m
 modules/gui/macosx/VLCPlaylistInfo.h
 modules/gui/macosx/VLCPlaylistInfo.m
 modules/gui/macosx/VLCPlaylistMenuController.h
 modules/gui/macosx/VLCPlaylistMenuController.m
-modules/gui/macosx/VLCPlaylistView.h
-modules/gui/macosx/VLCPlaylistView.m
 modules/gui/macosx/VLCPopupPanelController.h
 modules/gui/macosx/VLCPopupPanelController.m
 modules/gui/macosx/VLCRendererDiscovery.h