mirror of
https://github.com/jellyfin/jellyfin.git
synced 2024-11-16 02:18:54 -07:00
removed ISupportsSpecialFeatures
This commit is contained in:
parent
ec621df5f6
commit
c5fd7c3bd6
@ -1,105 +0,0 @@
|
|||||||
using MediaBrowser.Common.IO;
|
|
||||||
using MediaBrowser.Common.Logging;
|
|
||||||
using MediaBrowser.Common.Win32;
|
|
||||||
using MediaBrowser.Controller.Library;
|
|
||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.IO;
|
|
||||||
using System.Linq;
|
|
||||||
|
|
||||||
namespace MediaBrowser.Controller.Entities
|
|
||||||
{
|
|
||||||
/// <summary>
|
|
||||||
/// Allows some code sharing between entities that support special features
|
|
||||||
/// </summary>
|
|
||||||
public interface ISupportsSpecialFeatures
|
|
||||||
{
|
|
||||||
/// <summary>
|
|
||||||
/// Gets the path.
|
|
||||||
/// </summary>
|
|
||||||
/// <value>The path.</value>
|
|
||||||
string Path { get; }
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Gets the name.
|
|
||||||
/// </summary>
|
|
||||||
/// <value>The name.</value>
|
|
||||||
string Name { get; }
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Gets the resolve args.
|
|
||||||
/// </summary>
|
|
||||||
/// <value>The resolve args.</value>
|
|
||||||
ItemResolveArgs ResolveArgs { get; }
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Gets the special features.
|
|
||||||
/// </summary>
|
|
||||||
/// <value>The special features.</value>
|
|
||||||
List<Video> SpecialFeatures { get; }
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Class SpecialFeatures
|
|
||||||
/// </summary>
|
|
||||||
public static class SpecialFeatures
|
|
||||||
{
|
|
||||||
/// <summary>
|
|
||||||
/// Loads special features from the file system
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="entity">The entity.</param>
|
|
||||||
/// <returns>List{Video}.</returns>
|
|
||||||
/// <exception cref="System.ArgumentNullException"></exception>
|
|
||||||
public static IEnumerable<Video> LoadSpecialFeatures(ISupportsSpecialFeatures entity)
|
|
||||||
{
|
|
||||||
if (entity == null)
|
|
||||||
{
|
|
||||||
throw new ArgumentNullException();
|
|
||||||
}
|
|
||||||
|
|
||||||
WIN32_FIND_DATA? folder;
|
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
folder = entity.ResolveArgs.GetFileSystemEntryByName("specials");
|
|
||||||
}
|
|
||||||
catch (IOException ex)
|
|
||||||
{
|
|
||||||
Logger.LogException("Error getting ResolveArgs for {0}", ex, entity.Path);
|
|
||||||
return new List<Video> { };
|
|
||||||
}
|
|
||||||
|
|
||||||
// Path doesn't exist. No biggie
|
|
||||||
if (folder == null)
|
|
||||||
{
|
|
||||||
return new List<Video> {};
|
|
||||||
}
|
|
||||||
|
|
||||||
IEnumerable<WIN32_FIND_DATA> files;
|
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
files = FileSystem.GetFiles(folder.Value.Path);
|
|
||||||
}
|
|
||||||
catch (IOException ex)
|
|
||||||
{
|
|
||||||
Logger.LogException("Error loading trailers for {0}", ex, entity.Name);
|
|
||||||
return new List<Video> { };
|
|
||||||
}
|
|
||||||
|
|
||||||
return Kernel.Instance.LibraryManager.GetItems<Video>(files, null).Select(video =>
|
|
||||||
{
|
|
||||||
// Try to retrieve it from the db. If we don't find it, use the resolved version
|
|
||||||
var dbItem = Kernel.Instance.ItemRepository.RetrieveItem(video.Id) as Video;
|
|
||||||
|
|
||||||
if (dbItem != null)
|
|
||||||
{
|
|
||||||
dbItem.ResolveArgs = video.ResolveArgs;
|
|
||||||
video = dbItem;
|
|
||||||
}
|
|
||||||
|
|
||||||
return video;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,7 +1,11 @@
|
|||||||
using MediaBrowser.Common.Extensions;
|
using MediaBrowser.Common.Extensions;
|
||||||
|
using MediaBrowser.Common.IO;
|
||||||
|
using MediaBrowser.Common.Logging;
|
||||||
|
using MediaBrowser.Common.Win32;
|
||||||
using MediaBrowser.Model.Entities;
|
using MediaBrowser.Model.Entities;
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using System.IO;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Runtime.Serialization;
|
using System.Runtime.Serialization;
|
||||||
using System.Threading;
|
using System.Threading;
|
||||||
@ -12,7 +16,7 @@ namespace MediaBrowser.Controller.Entities.Movies
|
|||||||
/// <summary>
|
/// <summary>
|
||||||
/// Class Movie
|
/// Class Movie
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public class Movie : Video, ISupportsSpecialFeatures
|
public class Movie : Video
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Should be overridden to return the proper folder where metadata lives
|
/// Should be overridden to return the proper folder where metadata lives
|
||||||
@ -66,7 +70,7 @@ namespace MediaBrowser.Controller.Entities.Movies
|
|||||||
{
|
{
|
||||||
get
|
get
|
||||||
{
|
{
|
||||||
LazyInitializer.EnsureInitialized(ref _specialFeatures, ref _specialFeaturesInitialized, ref _specialFeaturesSyncLock, () => Entities.SpecialFeatures.LoadSpecialFeatures(this).ToList());
|
LazyInitializer.EnsureInitialized(ref _specialFeatures, ref _specialFeaturesInitialized, ref _specialFeaturesSyncLock, () => LoadSpecialFeatures().ToList());
|
||||||
return _specialFeatures;
|
return _specialFeatures;
|
||||||
}
|
}
|
||||||
private set
|
private set
|
||||||
@ -139,6 +143,60 @@ namespace MediaBrowser.Controller.Entities.Movies
|
|||||||
}
|
}
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Loads special features from the file system
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="entity">The entity.</param>
|
||||||
|
/// <returns>List{Video}.</returns>
|
||||||
|
/// <exception cref="System.ArgumentNullException"></exception>
|
||||||
|
private IEnumerable<Video> LoadSpecialFeatures()
|
||||||
|
{
|
||||||
|
WIN32_FIND_DATA? folder;
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
folder = ResolveArgs.GetFileSystemEntryByName("specials");
|
||||||
|
}
|
||||||
|
catch (IOException ex)
|
||||||
|
{
|
||||||
|
Logger.LogException("Error getting ResolveArgs for {0}", ex, Path);
|
||||||
|
return new List<Video> { };
|
||||||
|
}
|
||||||
|
|
||||||
|
// Path doesn't exist. No biggie
|
||||||
|
if (folder == null)
|
||||||
|
{
|
||||||
|
return new List<Video> { };
|
||||||
|
}
|
||||||
|
|
||||||
|
IEnumerable<WIN32_FIND_DATA> files;
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
files = FileSystem.GetFiles(folder.Value.Path);
|
||||||
|
}
|
||||||
|
catch (IOException ex)
|
||||||
|
{
|
||||||
|
Logger.LogException("Error loading trailers for {0}", ex, Name);
|
||||||
|
return new List<Video> { };
|
||||||
|
}
|
||||||
|
|
||||||
|
return Kernel.Instance.LibraryManager.GetItems<Video>(files, null).Select(video =>
|
||||||
|
{
|
||||||
|
// Try to retrieve it from the db. If we don't find it, use the resolved version
|
||||||
|
var dbItem = Kernel.Instance.ItemRepository.RetrieveItem(video.Id) as Video;
|
||||||
|
|
||||||
|
if (dbItem != null)
|
||||||
|
{
|
||||||
|
dbItem.ResolveArgs = video.ResolveArgs;
|
||||||
|
video = dbItem;
|
||||||
|
}
|
||||||
|
|
||||||
|
return video;
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -90,7 +90,6 @@
|
|||||||
<Compile Include="Entities\ICollectionFolder.cs" />
|
<Compile Include="Entities\ICollectionFolder.cs" />
|
||||||
<Compile Include="Entities\IndexFolder.cs" />
|
<Compile Include="Entities\IndexFolder.cs" />
|
||||||
<Compile Include="Entities\Movies\BoxSet.cs" />
|
<Compile Include="Entities\Movies\BoxSet.cs" />
|
||||||
<Compile Include="Entities\ISupportsSpecialFeatures.cs" />
|
|
||||||
<Compile Include="Entities\Movies\Movie.cs" />
|
<Compile Include="Entities\Movies\Movie.cs" />
|
||||||
<Compile Include="Entities\Person.cs" />
|
<Compile Include="Entities\Person.cs" />
|
||||||
<Compile Include="Entities\PlaybackProgressEventArgs.cs" />
|
<Compile Include="Entities\PlaybackProgressEventArgs.cs" />
|
||||||
|
Loading…
Reference in New Issue
Block a user