|
@@ -1,65 +1,68 @@
|
|
-#pragma warning disable CS1591
|
|
|
|
-#pragma warning disable SA1600
|
|
|
|
-
|
|
|
|
using System;
|
|
using System;
|
|
using System.IO;
|
|
using System.IO;
|
|
using System.Linq;
|
|
using System.Linq;
|
|
using MediaBrowser.Controller.Library;
|
|
using MediaBrowser.Controller.Library;
|
|
using MediaBrowser.Controller.Playlists;
|
|
using MediaBrowser.Controller.Playlists;
|
|
|
|
+using MediaBrowser.Controller.Resolvers;
|
|
|
|
+using MediaBrowser.LocalMetadata.Savers;
|
|
using MediaBrowser.Model.Entities;
|
|
using MediaBrowser.Model.Entities;
|
|
|
|
|
|
namespace Emby.Server.Implementations.Library.Resolvers
|
|
namespace Emby.Server.Implementations.Library.Resolvers
|
|
{
|
|
{
|
|
|
|
+ /// <summary>
|
|
|
|
+ /// <see cref="IItemResolver"/> for <see cref="Playlist"/> library items.
|
|
|
|
+ /// </summary>
|
|
public class PlaylistResolver : FolderResolver<Playlist>
|
|
public class PlaylistResolver : FolderResolver<Playlist>
|
|
{
|
|
{
|
|
- private string[] SupportedCollectionTypes = new string[] {
|
|
|
|
-
|
|
|
|
|
|
+ private string[] _musicPlaylistCollectionTypes = new string[] {
|
|
string.Empty,
|
|
string.Empty,
|
|
CollectionType.Music
|
|
CollectionType.Music
|
|
};
|
|
};
|
|
|
|
|
|
- /// <summary>
|
|
|
|
- /// Resolves the specified args.
|
|
|
|
- /// </summary>
|
|
|
|
- /// <param name="args">The args.</param>
|
|
|
|
- /// <returns>BoxSet.</returns>
|
|
|
|
|
|
+ /// <inheritdoc/>
|
|
protected override Playlist Resolve(ItemResolveArgs args)
|
|
protected override Playlist Resolve(ItemResolveArgs args)
|
|
{
|
|
{
|
|
- // It's a boxset if all of the following conditions are met:
|
|
|
|
- // Is a Directory
|
|
|
|
- // Contains [playlist] in the path
|
|
|
|
if (args.IsDirectory)
|
|
if (args.IsDirectory)
|
|
{
|
|
{
|
|
- var filename = Path.GetFileName(args.Path);
|
|
|
|
-
|
|
|
|
- if (string.IsNullOrEmpty(filename))
|
|
|
|
|
|
+ // It's a boxset if the path is a directory with [playlist] in it's the name
|
|
|
|
+ // TODO: Should this use Path.GetDirectoryName() instead?
|
|
|
|
+ bool isBoxSet = Path.GetFileName(args.Path)
|
|
|
|
+ ?.Contains("[playlist]", StringComparison.OrdinalIgnoreCase)
|
|
|
|
+ ?? false;
|
|
|
|
+ if (isBoxSet)
|
|
{
|
|
{
|
|
- return null;
|
|
|
|
|
|
+ return new Playlist
|
|
|
|
+ {
|
|
|
|
+ Path = args.Path,
|
|
|
|
+ Name = Path.GetFileName(args.Path).Replace("[playlist]", string.Empty, StringComparison.OrdinalIgnoreCase).Trim()
|
|
|
|
+ };
|
|
}
|
|
}
|
|
|
|
|
|
- if (filename.IndexOf("[playlist]", StringComparison.OrdinalIgnoreCase) != -1)
|
|
|
|
|
|
+ // It's a directory-based playlist if the directory contains a playlist file
|
|
|
|
+ var filePaths = Directory.EnumerateFiles(args.Path);
|
|
|
|
+ if (filePaths.Any(f => f.EndsWith(PlaylistXmlSaver.DefaultPlaylistFilename, StringComparison.OrdinalIgnoreCase)))
|
|
{
|
|
{
|
|
return new Playlist
|
|
return new Playlist
|
|
{
|
|
{
|
|
Path = args.Path,
|
|
Path = args.Path,
|
|
- Name = Path.GetFileName(args.Path).Replace("[playlist]", string.Empty, StringComparison.OrdinalIgnoreCase).Trim()
|
|
|
|
|
|
+ Name = Path.GetFileName(args.Path)
|
|
};
|
|
};
|
|
}
|
|
}
|
|
}
|
|
}
|
|
- else
|
|
|
|
|
|
+
|
|
|
|
+ // Check if this is a music playlist file
|
|
|
|
+ // It should have the correct collection type and a supported file extension
|
|
|
|
+ else if (_musicPlaylistCollectionTypes.Contains(args.CollectionType ?? string.Empty, StringComparer.OrdinalIgnoreCase))
|
|
{
|
|
{
|
|
- if (SupportedCollectionTypes.Contains(args.CollectionType ?? string.Empty, StringComparer.OrdinalIgnoreCase))
|
|
|
|
|
|
+ var extension = Path.GetExtension(args.Path);
|
|
|
|
+ if (Playlist.SupportedExtensions.Contains(extension ?? string.Empty, StringComparer.OrdinalIgnoreCase))
|
|
{
|
|
{
|
|
- var extension = Path.GetExtension(args.Path);
|
|
|
|
- if (Playlist.SupportedExtensions.Contains(extension ?? string.Empty, StringComparer.OrdinalIgnoreCase))
|
|
|
|
|
|
+ return new Playlist
|
|
{
|
|
{
|
|
- return new Playlist
|
|
|
|
- {
|
|
|
|
- Path = args.Path,
|
|
|
|
- Name = Path.GetFileNameWithoutExtension(args.Path),
|
|
|
|
- IsInMixedFolder = true
|
|
|
|
- };
|
|
|
|
- }
|
|
|
|
|
|
+ Path = args.Path,
|
|
|
|
+ Name = Path.GetFileNameWithoutExtension(args.Path),
|
|
|
|
+ IsInMixedFolder = true
|
|
|
|
+ };
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|