commit
a615f87680
|
@ -470,6 +470,12 @@ namespace Emby.Naming.Common
|
||||||
" sample",
|
" sample",
|
||||||
MediaType.Video),
|
MediaType.Video),
|
||||||
|
|
||||||
|
new ExtraRule(
|
||||||
|
ExtraType.ThemeVideo,
|
||||||
|
ExtraRuleType.DirectoryName,
|
||||||
|
"backdrops",
|
||||||
|
MediaType.Video),
|
||||||
|
|
||||||
new ExtraRule(
|
new ExtraRule(
|
||||||
ExtraType.ThemeSong,
|
ExtraType.ThemeSong,
|
||||||
ExtraRuleType.Filename,
|
ExtraRuleType.Filename,
|
||||||
|
|
|
@ -1,18 +0,0 @@
|
||||||
#nullable disable
|
|
||||||
|
|
||||||
#pragma warning disable CS1591
|
|
||||||
|
|
||||||
using Emby.Naming.Common;
|
|
||||||
using MediaBrowser.Controller.Entities;
|
|
||||||
|
|
||||||
namespace Emby.Server.Implementations.Library.Resolvers
|
|
||||||
{
|
|
||||||
public class GenericVideoResolver<T> : BaseVideoResolver<T>
|
|
||||||
where T : Video, new()
|
|
||||||
{
|
|
||||||
public GenericVideoResolver(NamingOptions namingOptions)
|
|
||||||
: base(namingOptions)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -105,10 +105,9 @@ namespace Emby.Server.Implementations.Library.Resolvers.Movies
|
||||||
|
|
||||||
if (string.IsNullOrEmpty(collectionType))
|
if (string.IsNullOrEmpty(collectionType))
|
||||||
{
|
{
|
||||||
// Owned items will be caught by the plain video resolver
|
// Owned items will be caught by the video extra resolver
|
||||||
if (args.Parent == null)
|
if (args.Parent == null)
|
||||||
{
|
{
|
||||||
// return FindMovie<Video>(args.Path, args.Parent, files, args.DirectoryService, collectionType);
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -129,10 +128,10 @@ namespace Emby.Server.Implementations.Library.Resolvers.Movies
|
||||||
return movie?.ExtraType == null ? movie : null;
|
return movie?.ExtraType == null ? movie : null;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Handle owned items
|
// Owned items will be caught by the video extra resolver
|
||||||
if (args.Parent == null)
|
if (args.Parent == null)
|
||||||
{
|
{
|
||||||
return base.Resolve(args);
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (IsInvalid(args.Parent, collectionType))
|
if (IsInvalid(args.Parent, collectionType))
|
||||||
|
|
|
@ -0,0 +1,55 @@
|
||||||
|
#nullable disable
|
||||||
|
|
||||||
|
using Emby.Naming.Common;
|
||||||
|
using MediaBrowser.Controller.Entities;
|
||||||
|
using MediaBrowser.Controller.Library;
|
||||||
|
using MediaBrowser.Controller.Resolvers;
|
||||||
|
using MediaBrowser.Model.Entities;
|
||||||
|
|
||||||
|
namespace Emby.Server.Implementations.Library.Resolvers
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Resolves a Path into a Video or Video subclass.
|
||||||
|
/// </summary>
|
||||||
|
public class VideoExtraResolver : BaseVideoResolver<Video>
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Initializes a new instance of the <see cref="VideoExtraResolver"/> class.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="namingOptions">The naming options.</param>
|
||||||
|
public VideoExtraResolver(NamingOptions namingOptions)
|
||||||
|
: base(namingOptions)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets the priority.
|
||||||
|
/// </summary>
|
||||||
|
/// <value>The priority.</value>
|
||||||
|
public override ResolverPriority Priority => ResolverPriority.Last;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Resolves the specified args.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="args">The args.</param>
|
||||||
|
/// <returns>The video extra or null if not handled by this resolver.</returns>
|
||||||
|
public override Video Resolve(ItemResolveArgs args)
|
||||||
|
{
|
||||||
|
// Only handle owned items
|
||||||
|
if (args.Parent != null)
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
var ownedItem = base.Resolve(args);
|
||||||
|
|
||||||
|
// Re-resolve items that have their own type
|
||||||
|
if (ownedItem.ExtraType == ExtraType.Trailer)
|
||||||
|
{
|
||||||
|
ownedItem = ResolveVideo<Trailer>(args, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
return ownedItem;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -53,6 +53,7 @@ namespace Jellyfin.Naming.Tests.Video
|
||||||
[InlineData(ExtraType.Sample, "samples")]
|
[InlineData(ExtraType.Sample, "samples")]
|
||||||
[InlineData(ExtraType.Clip, "shorts")]
|
[InlineData(ExtraType.Clip, "shorts")]
|
||||||
[InlineData(ExtraType.Clip, "featurettes")]
|
[InlineData(ExtraType.Clip, "featurettes")]
|
||||||
|
[InlineData(ExtraType.ThemeVideo, "backdrops")]
|
||||||
[InlineData(ExtraType.Unknown, "extras")]
|
[InlineData(ExtraType.Unknown, "extras")]
|
||||||
public void TestDirectories(ExtraType type, string dirName)
|
public void TestDirectories(ExtraType type, string dirName)
|
||||||
{
|
{
|
||||||
|
|
|
@ -36,7 +36,7 @@ public class FindExtrasTests
|
||||||
_fileSystemMock.Setup(f => f.GetFileInfo(It.IsAny<string>())).Returns<string>(path => new FileSystemMetadata { FullName = path });
|
_fileSystemMock.Setup(f => f.GetFileInfo(It.IsAny<string>())).Returns<string>(path => new FileSystemMetadata { FullName = path });
|
||||||
_libraryManager = fixture.Build<Emby.Server.Implementations.Library.LibraryManager>().Do(s => s.AddParts(
|
_libraryManager = fixture.Build<Emby.Server.Implementations.Library.LibraryManager>().Do(s => s.AddParts(
|
||||||
fixture.Create<IEnumerable<IResolverIgnoreRule>>(),
|
fixture.Create<IEnumerable<IResolverIgnoreRule>>(),
|
||||||
new List<IItemResolver> { new GenericVideoResolver<Video>(fixture.Create<NamingOptions>()), new AudioResolver(fixture.Create<NamingOptions>()) },
|
new List<IItemResolver> { new VideoExtraResolver(fixture.Create<NamingOptions>()), new AudioResolver(fixture.Create<NamingOptions>()) },
|
||||||
fixture.Create<IEnumerable<IIntroProvider>>(),
|
fixture.Create<IEnumerable<IIntroProvider>>(),
|
||||||
fixture.Create<IEnumerable<IBaseItemComparer>>(),
|
fixture.Create<IEnumerable<IBaseItemComparer>>(),
|
||||||
fixture.Create<IEnumerable<ILibraryPostScanTask>>()))
|
fixture.Create<IEnumerable<ILibraryPostScanTask>>()))
|
||||||
|
@ -69,6 +69,7 @@ public class FindExtrasTests
|
||||||
|
|
||||||
Assert.Equal(2, extras.Count);
|
Assert.Equal(2, extras.Count);
|
||||||
Assert.Equal(ExtraType.Trailer, extras[0].ExtraType);
|
Assert.Equal(ExtraType.Trailer, extras[0].ExtraType);
|
||||||
|
Assert.Equal(typeof(Trailer), extras[0].GetType());
|
||||||
Assert.Equal(ExtraType.Sample, extras[1].ExtraType);
|
Assert.Equal(ExtraType.Sample, extras[1].ExtraType);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -146,7 +147,9 @@ public class FindExtrasTests
|
||||||
|
|
||||||
Assert.Equal(6, extras.Count);
|
Assert.Equal(6, extras.Count);
|
||||||
Assert.Equal(ExtraType.Trailer, extras[0].ExtraType);
|
Assert.Equal(ExtraType.Trailer, extras[0].ExtraType);
|
||||||
|
Assert.Equal(typeof(Trailer), extras[0].GetType());
|
||||||
Assert.Equal(ExtraType.Trailer, extras[1].ExtraType);
|
Assert.Equal(ExtraType.Trailer, extras[1].ExtraType);
|
||||||
|
Assert.Equal(typeof(Trailer), extras[1].GetType());
|
||||||
Assert.Equal(ExtraType.BehindTheScenes, extras[2].ExtraType);
|
Assert.Equal(ExtraType.BehindTheScenes, extras[2].ExtraType);
|
||||||
Assert.Equal(ExtraType.Sample, extras[3].ExtraType);
|
Assert.Equal(ExtraType.Sample, extras[3].ExtraType);
|
||||||
Assert.Equal(ExtraType.ThemeSong, extras[4].ExtraType);
|
Assert.Equal(ExtraType.ThemeSong, extras[4].ExtraType);
|
||||||
|
@ -174,6 +177,7 @@ public class FindExtrasTests
|
||||||
|
|
||||||
Assert.Single(extras);
|
Assert.Single(extras);
|
||||||
Assert.Equal(ExtraType.Trailer, extras[0].ExtraType);
|
Assert.Equal(ExtraType.Trailer, extras[0].ExtraType);
|
||||||
|
Assert.Equal(typeof(Trailer), extras[0].GetType());
|
||||||
Assert.Equal("trailer", extras[0].FileNameWithoutExtension);
|
Assert.Equal("trailer", extras[0].FileNameWithoutExtension);
|
||||||
Assert.Equal("/movies/Up/trailer.mkv", extras[0].Path);
|
Assert.Equal("/movies/Up/trailer.mkv", extras[0].Path);
|
||||||
}
|
}
|
||||||
|
@ -200,6 +204,7 @@ public class FindExtrasTests
|
||||||
|
|
||||||
Assert.Single(extras);
|
Assert.Single(extras);
|
||||||
Assert.Equal(ExtraType.Trailer, extras[0].ExtraType);
|
Assert.Equal(ExtraType.Trailer, extras[0].ExtraType);
|
||||||
|
Assert.Equal(typeof(Trailer), extras[0].GetType());
|
||||||
Assert.Equal("trailer", extras[0].FileNameWithoutExtension);
|
Assert.Equal("trailer", extras[0].FileNameWithoutExtension);
|
||||||
Assert.Equal("/movies/Up/trailer.mkv", extras[0].Path);
|
Assert.Equal("/movies/Up/trailer.mkv", extras[0].Path);
|
||||||
}
|
}
|
||||||
|
@ -225,6 +230,7 @@ public class FindExtrasTests
|
||||||
|
|
||||||
Assert.Equal(2, extras.Count);
|
Assert.Equal(2, extras.Count);
|
||||||
Assert.Equal(ExtraType.Trailer, extras[0].ExtraType);
|
Assert.Equal(ExtraType.Trailer, extras[0].ExtraType);
|
||||||
|
Assert.Equal(typeof(Trailer), extras[0].GetType());
|
||||||
Assert.Equal("trailer", extras[0].FileNameWithoutExtension);
|
Assert.Equal("trailer", extras[0].FileNameWithoutExtension);
|
||||||
Assert.Equal("/series/Dexter/trailer.mkv", extras[0].Path);
|
Assert.Equal("/series/Dexter/trailer.mkv", extras[0].Path);
|
||||||
Assert.Equal("/series/Dexter/trailers/trailer2.mkv", extras[1].Path);
|
Assert.Equal("/series/Dexter/trailers/trailer2.mkv", extras[1].Path);
|
||||||
|
|
Loading…
Reference in New Issue
Block a user