Merge pull request #1491 from jose-pr/M3UParser

M3u Parser Improvements
pull/702/head
Luke 9 years ago
commit af90c48057

@ -48,11 +48,8 @@ namespace MediaBrowser.Server.Implementations.LiveTv.TunerHosts
private List<M3UChannel> GetChannels(StreamReader reader, string urlHash, string channelIdPrefix) private List<M3UChannel> GetChannels(StreamReader reader, string urlHash, string channelIdPrefix)
{ {
var channels = new List<M3UChannel>(); var channels = new List<M3UChannel>();
string channnelName = null;
string channelNumber = null;
string line; string line;
string imageUrl = null; string extInf = "";
while ((line = reader.ReadLine()) != null) while ((line = reader.ReadLine()) != null)
{ {
line = line.Trim(); line = line.Trim();
@ -68,29 +65,48 @@ namespace MediaBrowser.Server.Implementations.LiveTv.TunerHosts
if (line.StartsWith("#EXTINF:", StringComparison.OrdinalIgnoreCase)) if (line.StartsWith("#EXTINF:", StringComparison.OrdinalIgnoreCase))
{ {
line = line.Substring(8); extInf = line.Substring(8).Trim();
_logger.Info("Found m3u channel: {0}", line); _logger.Info("Found m3u channel: {0}", extInf);
var parts = line.Split(new[] { ',' }, 2);
channelNumber = parts[0].Trim().Split(' ')[0] ?? "0";
channnelName = FindProperty("tvg-name", line, parts[1]);
imageUrl = FindProperty("tvg-logo", line, null);
} }
else if (!string.IsNullOrWhiteSpace(channelNumber)) else if (!string.IsNullOrWhiteSpace(extInf))
{ {
channels.Add(new M3UChannel var channel = GetChannelnfo(extInf);
channel.Id = channelIdPrefix + urlHash + line.GetMD5().ToString("N");
channel.Path = line;
channels.Add(channel);
extInf = "";
}
}
return channels;
}
public M3UChannel GetChannelnfo(string extInf)
{ {
Name = channnelName, var titleIndex = extInf.LastIndexOf(',');
Number = channelNumber, var channel = new M3UChannel();
Id = channelIdPrefix + urlHash + line.GetMD5().ToString("N"),
ImageUrl = imageUrl channel.Number = extInf.Trim().Split(' ')[0] ?? "0";
}); channel.Name = extInf.Substring(titleIndex + 1);
imageUrl = null; if(channel.Number == "-1") { channel.Number = "0"; }
channelNumber = null;
channnelName = null; //Check for channel number with the format from SatIp
int number;
var numberIndex = channel.Name.IndexOf('.');
if (numberIndex > 0)
{
if (int.TryParse(channel.Name.Substring(0, numberIndex), out number))
{
channel.Number = number.ToString();
channel.Name = channel.Name.Substring(numberIndex + 1);
} }
} }
return channels; channel.ImageUrl = FindProperty("tvg-logo", extInf, null);
channel.Number = FindProperty("tvg-id", extInf, channel.Number);
channel.Number = FindProperty("channel-id", extInf, channel.Number);
channel.Name = FindProperty("tvg-name", extInf, channel.Name);
channel.Name = FindProperty("tvg-id", extInf, channel.Name);
return channel;
} }
public string FindProperty(string property, string properties, string defaultResult = "") public string FindProperty(string property, string properties, string defaultResult = "")
{ {

Loading…
Cancel
Save