aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.XbmcMetadata
diff options
context:
space:
mode:
authorTheMelmacian <76712303+TheMelmacian@users.noreply.github.com>2024-07-30 17:51:08 +0200
committerGitHub <noreply@github.com>2024-07-30 09:51:08 -0600
commitd4eeafe53ff8ae2f287f5dca49a873cd71f4c3da (patch)
treebe58617b2fb70f3f6642cbe70b0b11055dd6e3c2 /MediaBrowser.XbmcMetadata
parent0a1a109b2e9503213debdc8445910cb4c93ae382 (diff)
Fix: parsing of xbmc style multi episode nfo files (#12268)
Diffstat (limited to 'MediaBrowser.XbmcMetadata')
-rw-r--r--MediaBrowser.XbmcMetadata/Parsers/EpisodeNfoParser.cs116
1 files changed, 57 insertions, 59 deletions
diff --git a/MediaBrowser.XbmcMetadata/Parsers/EpisodeNfoParser.cs b/MediaBrowser.XbmcMetadata/Parsers/EpisodeNfoParser.cs
index 044efb51e..2a1a14834 100644
--- a/MediaBrowser.XbmcMetadata/Parsers/EpisodeNfoParser.cs
+++ b/MediaBrowser.XbmcMetadata/Parsers/EpisodeNfoParser.cs
@@ -59,80 +59,50 @@ namespace MediaBrowser.XbmcMetadata.Parsers
try
{
// Extract episode details from the first episodedetails block
- using (var stringReader = new StringReader(xml))
- using (var reader = XmlReader.Create(stringReader, settings))
- {
- reader.MoveToContent();
- reader.Read();
-
- // Loop through each element
- while (!reader.EOF && reader.ReadState == ReadState.Interactive)
- {
- cancellationToken.ThrowIfCancellationRequested();
-
- if (reader.NodeType == XmlNodeType.Element)
- {
- FetchDataFromXmlNode(reader, item);
- }
- else
- {
- reader.Read();
- }
- }
- }
+ ReadEpisodeDetailsFromXml(item, xml, settings, cancellationToken);
// Extract the last episode number from nfo
- // Retrieves all title and plot tags from the rest of the nfo and concatenates them with the first episode
+ // Retrieves all additional episodedetails blocks from the rest of the nfo and concatenates the name, originalTitle and overview tags with the first episode
// This is needed because XBMC metadata uses multiple episodedetails blocks instead of episodenumberend tag
var name = new StringBuilder(item.Item.Name);
+ var originalTitle = new StringBuilder(item.Item.OriginalTitle);
var overview = new StringBuilder(item.Item.Overview);
while ((index = xmlFile.IndexOf(srch, StringComparison.OrdinalIgnoreCase)) != -1)
{
xml = xmlFile.Substring(0, index + srch.Length);
xmlFile = xmlFile.Substring(index + srch.Length);
- using (var stringReader = new StringReader(xml))
- using (var reader = XmlReader.Create(stringReader, settings))
+ var additionalEpisode = new MetadataResult<Episode>()
+ {
+ Item = new Episode()
+ };
+
+ // Extract episode details from additional episodedetails block
+ ReadEpisodeDetailsFromXml(additionalEpisode, xml, settings, cancellationToken);
+
+ if (!string.IsNullOrEmpty(additionalEpisode.Item.Name))
+ {
+ name.Append(" / ").Append(additionalEpisode.Item.Name);
+ }
+
+ if (!string.IsNullOrEmpty(additionalEpisode.Item.Overview))
+ {
+ overview.Append(" / ").Append(additionalEpisode.Item.Overview);
+ }
+
+ if (!string.IsNullOrEmpty(additionalEpisode.Item.OriginalTitle))
+ {
+ originalTitle.Append(" / ").Append(additionalEpisode.Item.OriginalTitle);
+ }
+
+ if (additionalEpisode.Item.IndexNumber != null)
{
- reader.MoveToContent();
-
- while (!reader.EOF && reader.ReadState == ReadState.Interactive)
- {
- cancellationToken.ThrowIfCancellationRequested();
-
- if (reader.NodeType == XmlNodeType.Element)
- {
- switch (reader.Name)
- {
- case "name":
- case "title":
- case "localtitle":
- name.Append(" / ").Append(reader.ReadElementContentAsString());
- break;
- case "episode":
- {
- if (int.TryParse(reader.ReadElementContentAsString(), out var num))
- {
- item.Item.IndexNumberEnd = Math.Max(num, item.Item.IndexNumberEnd ?? num);
- }
-
- break;
- }
-
- case "biography":
- case "plot":
- case "review":
- overview.Append(" / ").Append(reader.ReadElementContentAsString());
- break;
- }
- }
-
- reader.Read();
- }
+ item.Item.IndexNumberEnd = Math.Max((int)additionalEpisode.Item.IndexNumber, item.Item.IndexNumberEnd ?? (int)additionalEpisode.Item.IndexNumber);
}
}
item.Item.Name = name.ToString();
+ item.Item.OriginalTitle = originalTitle.ToString();
item.Item.Overview = overview.ToString();
}
catch (XmlException)
@@ -200,5 +170,33 @@ namespace MediaBrowser.XbmcMetadata.Parsers
break;
}
}
+
+ /// <summary>
+ /// Reads the episode details from the given xml and saves the result in the provided result item.
+ /// </summary>
+ private void ReadEpisodeDetailsFromXml(MetadataResult<Episode> item, string xml, XmlReaderSettings settings, CancellationToken cancellationToken)
+ {
+ using (var stringReader = new StringReader(xml))
+ using (var reader = XmlReader.Create(stringReader, settings))
+ {
+ reader.MoveToContent();
+ reader.Read();
+
+ // Loop through each element
+ while (!reader.EOF && reader.ReadState == ReadState.Interactive)
+ {
+ cancellationToken.ThrowIfCancellationRequested();
+
+ if (reader.NodeType == XmlNodeType.Element)
+ {
+ FetchDataFromXmlNode(reader, item);
+ }
+ else
+ {
+ reader.Read();
+ }
+ }
+ }
+ }
}
}