|
|
@ -110,9 +110,10 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
using (var reader = XmlReader.Create(streamReader, settings))
|
|
|
|
using (var reader = XmlReader.Create(streamReader, settings))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
reader.MoveToContent();
|
|
|
|
reader.MoveToContent();
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
|
|
|
|
// Loop through each element
|
|
|
|
// Loop through each element
|
|
|
|
while (reader.Read())
|
|
|
|
while (!reader.EOF && reader.ReadState == ReadState.Interactive)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
cancellationToken.ThrowIfCancellationRequested();
|
|
|
|
cancellationToken.ThrowIfCancellationRequested();
|
|
|
|
|
|
|
|
|
|
|
@ -120,6 +121,10 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
{
|
|
|
|
{
|
|
|
|
FetchDataFromXmlNode(reader, item);
|
|
|
|
FetchDataFromXmlNode(reader, item);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -389,20 +394,34 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
case "TagLines":
|
|
|
|
case "TagLines":
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (!reader.IsEmptyElement)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
using (var subtree = reader.ReadSubtree())
|
|
|
|
using (var subtree = reader.ReadSubtree())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
FetchFromTaglinesNode(subtree, item);
|
|
|
|
FetchFromTaglinesNode(subtree, item);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
case "Countries":
|
|
|
|
case "Countries":
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (!reader.IsEmptyElement)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
using (var subtree = reader.ReadSubtree())
|
|
|
|
using (var subtree = reader.ReadSubtree())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
FetchFromCountriesNode(subtree, item);
|
|
|
|
FetchFromCountriesNode(subtree, item);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -586,6 +605,8 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
case "Trailers":
|
|
|
|
case "Trailers":
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (!reader.IsEmptyElement)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
using (var subtree = reader.ReadSubtree())
|
|
|
|
using (var subtree = reader.ReadSubtree())
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -595,6 +616,11 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
FetchDataFromTrailersNode(subtree, hasTrailers);
|
|
|
|
FetchDataFromTrailersNode(subtree, hasTrailers);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -693,51 +719,88 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case "Genres":
|
|
|
|
case "Genres":
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (!reader.IsEmptyElement)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
using (var subtree = reader.ReadSubtree())
|
|
|
|
using (var subtree = reader.ReadSubtree())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
FetchFromGenresNode(subtree, item);
|
|
|
|
FetchFromGenresNode(subtree, item);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
case "Tags":
|
|
|
|
case "Tags":
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (!reader.IsEmptyElement)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
using (var subtree = reader.ReadSubtree())
|
|
|
|
using (var subtree = reader.ReadSubtree())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
FetchFromTagsNode(subtree, item);
|
|
|
|
FetchFromTagsNode(subtree, item);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
case "PlotKeywords":
|
|
|
|
case "PlotKeywords":
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (!reader.IsEmptyElement)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
using (var subtree = reader.ReadSubtree())
|
|
|
|
using (var subtree = reader.ReadSubtree())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
FetchFromKeywordsNode(subtree, item);
|
|
|
|
FetchFromKeywordsNode(subtree, item);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
case "Persons":
|
|
|
|
case "Persons":
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (!reader.IsEmptyElement)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
using (var subtree = reader.ReadSubtree())
|
|
|
|
using (var subtree = reader.ReadSubtree())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
FetchDataFromPersonsNode(subtree, itemResult);
|
|
|
|
FetchDataFromPersonsNode(subtree, itemResult);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
case "Studios":
|
|
|
|
case "Studios":
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (!reader.IsEmptyElement)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
using (var subtree = reader.ReadSubtree())
|
|
|
|
using (var subtree = reader.ReadSubtree())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
FetchFromStudiosNode(subtree, item);
|
|
|
|
FetchFromStudiosNode(subtree, item);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
case "Shares":
|
|
|
|
case "Shares":
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (!reader.IsEmptyElement)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
using (var subtree = reader.ReadSubtree())
|
|
|
|
using (var subtree = reader.ReadSubtree())
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -747,17 +810,22 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
FetchFromSharesNode(subtree, hasShares);
|
|
|
|
FetchFromSharesNode(subtree, hasShares);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
case "Format3D":
|
|
|
|
case "Format3D":
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
var val = reader.ReadElementContentAsString();
|
|
|
|
|
|
|
|
|
|
|
|
var video = item as Video;
|
|
|
|
var video = item as Video;
|
|
|
|
|
|
|
|
|
|
|
|
if (video != null)
|
|
|
|
if (video != null)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var val = reader.ReadElementContentAsString();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (string.Equals("HSBS", val, StringComparison.OrdinalIgnoreCase))
|
|
|
|
if (string.Equals("HSBS", val, StringComparison.OrdinalIgnoreCase))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
video.Video3DFormat = Video3DFormat.HalfSideBySide;
|
|
|
|
video.Video3DFormat = Video3DFormat.HalfSideBySide;
|
|
|
@ -808,8 +876,10 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
private void FetchFromSharesNode(XmlReader reader, IHasShares item)
|
|
|
|
private void FetchFromSharesNode(XmlReader reader, IHasShares item)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
reader.MoveToContent();
|
|
|
|
reader.MoveToContent();
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
|
|
|
|
while (reader.Read())
|
|
|
|
// Loop through each element
|
|
|
|
|
|
|
|
while (!reader.EOF && reader.ReadState == ReadState.Interactive)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -817,6 +887,11 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
{
|
|
|
|
{
|
|
|
|
case "Share":
|
|
|
|
case "Share":
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
if (reader.IsEmptyElement)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
continue;
|
|
|
|
|
|
|
|
}
|
|
|
|
using (var subtree = reader.ReadSubtree())
|
|
|
|
using (var subtree = reader.ReadSubtree())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var share = GetShareFromNode(subtree);
|
|
|
|
var share = GetShareFromNode(subtree);
|
|
|
@ -833,6 +908,10 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -841,8 +920,10 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
var share = new Share();
|
|
|
|
var share = new Share();
|
|
|
|
|
|
|
|
|
|
|
|
reader.MoveToContent();
|
|
|
|
reader.MoveToContent();
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
|
|
|
|
while (reader.Read())
|
|
|
|
// Loop through each element
|
|
|
|
|
|
|
|
while (!reader.EOF && reader.ReadState == ReadState.Interactive)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -865,6 +946,10 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return share;
|
|
|
|
return share;
|
|
|
@ -873,8 +958,10 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
private void FetchFromCountriesNode(XmlReader reader, T item)
|
|
|
|
private void FetchFromCountriesNode(XmlReader reader, T item)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
reader.MoveToContent();
|
|
|
|
reader.MoveToContent();
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
|
|
|
|
while (reader.Read())
|
|
|
|
// Loop through each element
|
|
|
|
|
|
|
|
while (!reader.EOF && reader.ReadState == ReadState.Interactive)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -895,6 +982,10 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -909,7 +1000,7 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
reader.Read();
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
|
|
|
|
// Loop through each element
|
|
|
|
// Loop through each element
|
|
|
|
while (!reader.EOF)
|
|
|
|
while (!reader.EOF && reader.ReadState == ReadState.Interactive)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -945,8 +1036,10 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
private void FetchFromGenresNode(XmlReader reader, T item)
|
|
|
|
private void FetchFromGenresNode(XmlReader reader, T item)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
reader.MoveToContent();
|
|
|
|
reader.MoveToContent();
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
|
|
|
|
while (reader.Read())
|
|
|
|
// Loop through each element
|
|
|
|
|
|
|
|
while (!reader.EOF && reader.ReadState == ReadState.Interactive)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -968,14 +1061,20 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void FetchFromTagsNode(XmlReader reader, BaseItem item)
|
|
|
|
private void FetchFromTagsNode(XmlReader reader, BaseItem item)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
reader.MoveToContent();
|
|
|
|
reader.MoveToContent();
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
|
|
|
|
while (reader.Read())
|
|
|
|
// Loop through each element
|
|
|
|
|
|
|
|
while (!reader.EOF && reader.ReadState == ReadState.Interactive)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -997,14 +1096,20 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void FetchFromKeywordsNode(XmlReader reader, BaseItem item)
|
|
|
|
private void FetchFromKeywordsNode(XmlReader reader, BaseItem item)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
reader.MoveToContent();
|
|
|
|
reader.MoveToContent();
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
|
|
|
|
while (reader.Read())
|
|
|
|
// Loop through each element
|
|
|
|
|
|
|
|
while (!reader.EOF && reader.ReadState == ReadState.Interactive)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -1026,6 +1131,10 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -1037,8 +1146,10 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
private void FetchDataFromPersonsNode(XmlReader reader, MetadataResult<T> item)
|
|
|
|
private void FetchDataFromPersonsNode(XmlReader reader, MetadataResult<T> item)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
reader.MoveToContent();
|
|
|
|
reader.MoveToContent();
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
|
|
|
|
while (reader.Read())
|
|
|
|
// Loop through each element
|
|
|
|
|
|
|
|
while (!reader.EOF && reader.ReadState == ReadState.Interactive)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -1047,6 +1158,11 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
case "Person":
|
|
|
|
case "Person":
|
|
|
|
case "Actor":
|
|
|
|
case "Actor":
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
if (reader.IsEmptyElement)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
continue;
|
|
|
|
|
|
|
|
}
|
|
|
|
using (var subtree = reader.ReadSubtree())
|
|
|
|
using (var subtree = reader.ReadSubtree())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
foreach (var person in GetPersonsFromXmlNode(subtree))
|
|
|
|
foreach (var person in GetPersonsFromXmlNode(subtree))
|
|
|
@ -1066,14 +1182,20 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void FetchDataFromTrailersNode(XmlReader reader, IHasTrailers item)
|
|
|
|
private void FetchDataFromTrailersNode(XmlReader reader, IHasTrailers item)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
reader.MoveToContent();
|
|
|
|
reader.MoveToContent();
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
|
|
|
|
while (reader.Read())
|
|
|
|
// Loop through each element
|
|
|
|
|
|
|
|
while (!reader.EOF && reader.ReadState == ReadState.Interactive)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -1095,87 +1217,11 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
protected List<ChapterInfo> FetchChaptersFromXmlNode(BaseItem item, XmlReader reader)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
using (reader)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return GetChaptersFromXmlNode(reader)
|
|
|
|
|
|
|
|
.Where(i => i.StartPositionTicks >= 0)
|
|
|
|
|
|
|
|
.ToList();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private IEnumerable<ChapterInfo> GetChaptersFromXmlNode(XmlReader reader)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
var chapters = new List<ChapterInfo>();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
reader.MoveToContent();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
while (reader.Read())
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
switch (reader.Name)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
case "Chapter":
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
using (var subtree = reader.ReadSubtree())
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
chapters.Add(GetChapterInfoFromXmlNode(subtree));
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
|
|
|
reader.Skip();
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return chapters;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private ChapterInfo GetChapterInfoFromXmlNode(XmlReader reader)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
var chapter = new ChapterInfo();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
reader.MoveToContent();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
while (reader.Read())
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
switch (reader.Name)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
case "StartPositionMs":
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
var val = reader.ReadElementContentAsString();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var ms = long.Parse(val, _usCulture);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
chapter.StartPositionTicks = TimeSpan.FromMilliseconds(ms).Ticks;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
case "Name":
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
chapter.Name = reader.ReadElementContentAsString();
|
|
|
|
reader.Read();
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
|
|
|
reader.Skip();
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return chapter;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// <summary>
|
|
|
@ -1186,8 +1232,10 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
private void FetchFromStudiosNode(XmlReader reader, T item)
|
|
|
|
private void FetchFromStudiosNode(XmlReader reader, T item)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
reader.MoveToContent();
|
|
|
|
reader.MoveToContent();
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
|
|
|
|
while (reader.Read())
|
|
|
|
// Loop through each element
|
|
|
|
|
|
|
|
while (!reader.EOF && reader.ReadState == ReadState.Interactive)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -1209,6 +1257,10 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -1225,8 +1277,10 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
int? sortOrder = null;
|
|
|
|
int? sortOrder = null;
|
|
|
|
|
|
|
|
|
|
|
|
reader.MoveToContent();
|
|
|
|
reader.MoveToContent();
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
|
|
|
|
while (reader.Read())
|
|
|
|
// Loop through each element
|
|
|
|
|
|
|
|
while (!reader.EOF && reader.ReadState == ReadState.Interactive)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -1277,6 +1331,10 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
var personInfo = new PersonInfo
|
|
|
|
var personInfo = new PersonInfo
|
|
|
@ -1292,14 +1350,16 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
|
|
|
|
|
|
|
|
protected LinkedChild GetLinkedChild(XmlReader reader)
|
|
|
|
protected LinkedChild GetLinkedChild(XmlReader reader)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
reader.MoveToContent();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var linkedItem = new LinkedChild
|
|
|
|
var linkedItem = new LinkedChild
|
|
|
|
{
|
|
|
|
{
|
|
|
|
Type = LinkedChildType.Manual
|
|
|
|
Type = LinkedChildType.Manual
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
while (reader.Read())
|
|
|
|
reader.MoveToContent();
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Loop through each element
|
|
|
|
|
|
|
|
while (!reader.EOF && reader.ReadState == ReadState.Interactive)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -1316,6 +1376,10 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// This is valid
|
|
|
|
// This is valid
|
|
|
@ -1335,7 +1399,7 @@ namespace MediaBrowser.LocalMetadata.Parsers
|
|
|
|
reader.Read();
|
|
|
|
reader.Read();
|
|
|
|
|
|
|
|
|
|
|
|
// Loop through each element
|
|
|
|
// Loop through each element
|
|
|
|
while (!reader.EOF)
|
|
|
|
while (!reader.EOF && reader.ReadState == ReadState.Interactive)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
if (reader.NodeType == XmlNodeType.Element)
|
|
|
|
{
|
|
|
|
{
|
|
|
|