diff options
| author | Michalis Adamidis <gsnerf@gsnerf.de> | 2014-08-06 01:29:56 +0200 |
|---|---|---|
| committer | Michalis Adamidis <gsnerf@gsnerf.de> | 2014-08-06 01:29:56 +0200 |
| commit | 7994f0dcd9082cc657e07dbff6ecc4e638f1f527 (patch) | |
| tree | a62175934f5c563c2fcb37ecccd8b014189a35c9 /MediaBrowser.LocalMetadata/Parsers | |
| parent | a118169a3ccf3361a5920794c7762dfcff1babd2 (diff) | |
| parent | 7e25c857a551ce06025b3b85996aef7ed3c6571e (diff) | |
Merge remote-tracking branch 'official/master'
Diffstat (limited to 'MediaBrowser.LocalMetadata/Parsers')
| -rw-r--r-- | MediaBrowser.LocalMetadata/Parsers/BoxSetXmlParser.cs | 63 | ||||
| -rw-r--r-- | MediaBrowser.LocalMetadata/Parsers/PlaylistXmlParser.cs | 72 |
2 files changed, 75 insertions, 60 deletions
diff --git a/MediaBrowser.LocalMetadata/Parsers/BoxSetXmlParser.cs b/MediaBrowser.LocalMetadata/Parsers/BoxSetXmlParser.cs index 51a4684d7..f89e29d54 100644 --- a/MediaBrowser.LocalMetadata/Parsers/BoxSetXmlParser.cs +++ b/MediaBrowser.LocalMetadata/Parsers/BoxSetXmlParser.cs @@ -1,17 +1,14 @@ -using System.Collections.Generic; -using System.Globalization; -using System.Xml; -using MediaBrowser.Controller.Entities; +using MediaBrowser.Controller.Entities; using MediaBrowser.Controller.Entities.Movies; using MediaBrowser.Controller.Providers; using MediaBrowser.Model.Logging; +using System.Collections.Generic; +using System.Xml; namespace MediaBrowser.LocalMetadata.Parsers { public class BoxSetXmlParser : BaseItemXmlParser<BoxSet> { - private readonly CultureInfo UsCulture = new CultureInfo("en-US"); - public BoxSetXmlParser(ILogger logger) : base(logger) { @@ -71,59 +68,5 @@ namespace MediaBrowser.LocalMetadata.Parsers item.LinkedChildren = list; } - - private LinkedChild GetLinkedChild(XmlReader reader) - { - reader.MoveToContent(); - - var linkedItem = new LinkedChild - { - Type = LinkedChildType.Manual - }; - - while (reader.Read()) - { - if (reader.NodeType == XmlNodeType.Element) - { - switch (reader.Name) - { - case "Name": - { - linkedItem.ItemName = reader.ReadElementContentAsString(); - break; - } - - case "Type": - { - linkedItem.ItemType = reader.ReadElementContentAsString(); - break; - } - - case "Year": - { - var val = reader.ReadElementContentAsString(); - - if (!string.IsNullOrWhiteSpace(val)) - { - int rval; - - if (int.TryParse(val, NumberStyles.Integer, UsCulture, out rval)) - { - linkedItem.ItemYear = rval; - } - } - - break; - } - - default: - reader.Skip(); - break; - } - } - } - - return string.IsNullOrWhiteSpace(linkedItem.ItemName) || string.IsNullOrWhiteSpace(linkedItem.ItemType) ? null : linkedItem; - } } } diff --git a/MediaBrowser.LocalMetadata/Parsers/PlaylistXmlParser.cs b/MediaBrowser.LocalMetadata/Parsers/PlaylistXmlParser.cs new file mode 100644 index 000000000..83bc6a49e --- /dev/null +++ b/MediaBrowser.LocalMetadata/Parsers/PlaylistXmlParser.cs @@ -0,0 +1,72 @@ +using MediaBrowser.Controller.Entities; +using MediaBrowser.Controller.Playlists; +using MediaBrowser.Controller.Providers; +using MediaBrowser.Model.Logging; +using System.Collections.Generic; +using System.Xml; + +namespace MediaBrowser.LocalMetadata.Parsers +{ + public class PlaylistXmlParser : BaseItemXmlParser<Playlist> + { + public PlaylistXmlParser(ILogger logger) + : base(logger) + { + } + + protected override void FetchDataFromXmlNode(XmlReader reader, Playlist item) + { + switch (reader.Name) + { + case "PlaylistItems": + + using (var subReader = reader.ReadSubtree()) + { + FetchFromCollectionItemsNode(subReader, item); + } + break; + + default: + base.FetchDataFromXmlNode(reader, item); + break; + } + } + + private void FetchFromCollectionItemsNode(XmlReader reader, Playlist item) + { + reader.MoveToContent(); + + var list = new List<LinkedChild>(); + + while (reader.Read()) + { + if (reader.NodeType == XmlNodeType.Element) + { + switch (reader.Name) + { + case "PlaylistItem": + { + using (var subReader = reader.ReadSubtree()) + { + var child = GetLinkedChild(subReader); + + if (child != null) + { + list.Add(child); + } + } + + break; + } + + default: + reader.Skip(); + break; + } + } + } + + item.LinkedChildren = list; + } + } +} |
