aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLuke Pulverenti <luke.pulverenti@gmail.com>2013-09-19 17:23:56 -0400
committerLuke Pulverenti <luke.pulverenti@gmail.com>2013-09-19 17:23:56 -0400
commit04468452ea873e83811522180a0423ac72d6f77d (patch)
tree17c0bee92b9a55b0b02bff481c7da24ca43a3f4e
parent4a1d8771a80c805dfb27b119a33e14f99c9e0812 (diff)
Added Add/Remove/Clear Children protected methods
-rw-r--r--MediaBrowser.Controller/Entities/Folder.cs43
-rw-r--r--Nuget/MediaBrowser.Common.Internal.nuspec4
-rw-r--r--Nuget/MediaBrowser.Common.nuspec2
-rw-r--r--Nuget/MediaBrowser.Server.Core.nuspec4
4 files changed, 35 insertions, 18 deletions
diff --git a/MediaBrowser.Controller/Entities/Folder.cs b/MediaBrowser.Controller/Entities/Folder.cs
index 5b90382b6..fba873251 100644
--- a/MediaBrowser.Controller/Entities/Folder.cs
+++ b/MediaBrowser.Controller/Entities/Folder.cs
@@ -103,7 +103,33 @@ namespace MediaBrowser.Controller.Entities
await LibraryManager.CreateItem(item, cancellationToken).ConfigureAwait(false);
- await ItemRepository.SaveChildren(Id, _children.ToList().Select(i => i.Id), cancellationToken).ConfigureAwait(false);
+ await ItemRepository.SaveChildren(Id, _children.Select(i => i.Id).ToList(), cancellationToken).ConfigureAwait(false);
+ }
+
+ protected void AddChildrenInternal(IEnumerable<BaseItem> children)
+ {
+ foreach (var child in children)
+ {
+ _children.Add(child);
+ }
+ }
+
+ protected void RemoveChildrenInternal(IEnumerable<BaseItem> children)
+ {
+ lock (ChildrenSyncLock)
+ {
+ _children = new ConcurrentBag<BaseItem>(_children.Except(children));
+ }
+ }
+
+ protected void ClearChildrenInternal()
+ {
+ BaseItem removed;
+
+ while (_children.TryTake(out removed))
+ {
+
+ }
}
/// <summary>
@@ -132,22 +158,13 @@ namespace MediaBrowser.Controller.Entities
/// <exception cref="System.InvalidOperationException">Unable to remove + item.Name</exception>
public Task RemoveChild(BaseItem item, CancellationToken cancellationToken)
{
- List<BaseItem> newChildren;
-
- lock (ChildrenSyncLock)
- {
- newChildren = _children.ToList();
-
- newChildren.Remove(item);
-
- _children = new ConcurrentBag<BaseItem>(newChildren);
- }
+ RemoveChildrenInternal(new[] { item });
item.Parent = null;
LibraryManager.ReportItemRemoved(item);
- return ItemRepository.SaveChildren(Id, newChildren.Select(i => i.Id), cancellationToken);
+ return ItemRepository.SaveChildren(Id, ActualChildren.Select(i => i.Id).ToList(), cancellationToken);
}
#region Indexing
@@ -726,7 +743,7 @@ namespace MediaBrowser.Controller.Entities
Logger.Debug("** " + item.Name + " Added to library.");
}
- await ItemRepository.SaveChildren(Id, _children.ToList().Select(i => i.Id), cancellationToken).ConfigureAwait(false);
+ await ItemRepository.SaveChildren(Id, _children.Select(i => i.Id).ToList(), cancellationToken).ConfigureAwait(false);
//force the indexes to rebuild next time
if (IndexCache != null)
diff --git a/Nuget/MediaBrowser.Common.Internal.nuspec b/Nuget/MediaBrowser.Common.Internal.nuspec
index 6b21d20a8..00c31ba5e 100644
--- a/Nuget/MediaBrowser.Common.Internal.nuspec
+++ b/Nuget/MediaBrowser.Common.Internal.nuspec
@@ -2,7 +2,7 @@
<package xmlns="http://schemas.microsoft.com/packaging/2011/08/nuspec.xsd">
<metadata>
<id>MediaBrowser.Common.Internal</id>
- <version>3.0.202</version>
+ <version>3.0.203</version>
<title>MediaBrowser.Common.Internal</title>
<authors>Luke</authors>
<owners>ebr,Luke,scottisafool</owners>
@@ -12,7 +12,7 @@
<description>Contains common components shared by Media Browser Theater and Media Browser Server. Not intended for plugin developer consumption.</description>
<copyright>Copyright © Media Browser 2013</copyright>
<dependencies>
- <dependency id="MediaBrowser.Common" version="3.0.202" />
+ <dependency id="MediaBrowser.Common" version="3.0.203" />
<dependency id="NLog" version="2.0.1.2" />
<dependency id="ServiceStack.Text" version="3.9.58" />
<dependency id="SimpleInjector" version="2.3.2" />
diff --git a/Nuget/MediaBrowser.Common.nuspec b/Nuget/MediaBrowser.Common.nuspec
index 0f83c0e7a..94d3b6131 100644
--- a/Nuget/MediaBrowser.Common.nuspec
+++ b/Nuget/MediaBrowser.Common.nuspec
@@ -2,7 +2,7 @@
<package xmlns="http://schemas.microsoft.com/packaging/2011/08/nuspec.xsd">
<metadata>
<id>MediaBrowser.Common</id>
- <version>3.0.202</version>
+ <version>3.0.203</version>
<title>MediaBrowser.Common</title>
<authors>Media Browser Team</authors>
<owners>ebr,Luke,scottisafool</owners>
diff --git a/Nuget/MediaBrowser.Server.Core.nuspec b/Nuget/MediaBrowser.Server.Core.nuspec
index 8a0f19414..72aa871bf 100644
--- a/Nuget/MediaBrowser.Server.Core.nuspec
+++ b/Nuget/MediaBrowser.Server.Core.nuspec
@@ -2,7 +2,7 @@
<package xmlns="http://schemas.microsoft.com/packaging/2010/07/nuspec.xsd">
<metadata>
<id>MediaBrowser.Server.Core</id>
- <version>3.0.202</version>
+ <version>3.0.203</version>
<title>Media Browser.Server.Core</title>
<authors>Media Browser Team</authors>
<owners>ebr,Luke,scottisafool</owners>
@@ -12,7 +12,7 @@
<description>Contains core components required to build plugins for Media Browser Server.</description>
<copyright>Copyright © Media Browser 2013</copyright>
<dependencies>
- <dependency id="MediaBrowser.Common" version="3.0.202" />
+ <dependency id="MediaBrowser.Common" version="3.0.203" />
</dependencies>
</metadata>
<files>