public override string ReadString() { if (readingDate) { string dateString = base.ReadString(); var dt = MiscHelper.GetDateFromAnyFormatString(dateString); return(dt.ToUniversalTime().ToString("R", CultureInfo.InvariantCulture)); } else { return(base.ReadString()); } }
void p_Old(Feed feed, XDocument feedXML) { lock (thisLock) { try { RssDnldInfos.Clear(); var errMsgs = " "; if (feedXML == null) { feed.LastAvailCastCount = -7; Debug.WriteLine( $"Unable to get data from {feed.Url}:\n{System.Reflection.MethodInfo.GetCurrentMethod().DeclaringType.Name}\n{System.Reflection.MethodInfo.GetCurrentMethod().Name}\a"); } else { var podcastSyndItems = from cast in feedXML.Descendants("item") select cast; feed.LastAvailCastCount = podcastSyndItems.Count(); feed.LastCastAt = DateTime.Today.AddYears(-10); var neverRanYet = true; foreach (var si in podcastSyndItems) { //Debug.WriteLine(string.Format("\n{0}\n", feed)); if (si.Element("pubDate") == null) { var msg = $"No \"pubDate\" element \n in podcast: \t {(si.Element("title") != null ? si.Element("title").Value : "")} \n from feed: \t {feed.Name} \n feed url: \t {feed.Url}"; Debug.WriteLine(msg); errMsgs += msg; // if (showMessages) showMessages = (MessageBox.Show(msg, "Continue showing these messages?", MessageBoxButton.YesNo, MessageBoxImage.Question) == MessageBoxResult.Yes); continue; } var pubDate = MiscHelper.GetDateFromAnyFormatString(si.Element("pubDate").Value); if (feed.LastCastAt < pubDate) { feed.LastCastAt = pubDate; } var enclosure = MiscHelper.gerRightEleName(si); if (enclosure == "" || si.Element(enclosure).Attribute("url") == null || si.Element(enclosure).Attribute("length") == null) { if ((DateTime.Now - pubDate).TotalDays > feed.AcptblAgeDay || pubDate < feed.IgnoreBefore) { continue;//ignore old errors } else { var msg = $"No \"enclosure\" element \n in podcast: \t {(si.Element("title") != null ? si.Element("title").Value : "")} \n published: \t {pubDate} \n from feed: \t {feed.Name} \n feed url: \t {feed.Url}"; Debug.WriteLine(msg); Clipboard.SetText(feed.Url); if (neverRanYet) { neverRanYet = false; Process.Start(new ProcessStartInfo(feed.Url)); } else { Debug.WriteLine("::>>Second try."); } errMsgs += msg; // if (showMessages) showMessages = (MessageBox.Show(msg, "Continue showing these messages?", MessageBoxButton.YesNo, MessageBoxImage.Question) == MessageBoxResult.Yes); continue; } } var castTitle = si.Element("title") == null ? "NoTitle" : si.Element("title").Value.Replace("\n", " ").Trim(); var castUrl = si.Element(enclosure).Attribute("url").Value; long castLen = -1; long.TryParse(si.Element(enclosure).Attribute("length").Value, out castLen); var fnm = MiscHelper.GetSmartPathFileName(castUrl, pubDate, feed.Tla, feed.SubFolderEx, feed.IsTitleInFilename ? castTitle : null, feed.IsNewerFirst); RssDnldInfos.Add(new RssDnldInfo { CastTitle = castTitle, Published = pubDate, OrgSrcUrl = castUrl, AltSrcUrl = "", OrignLink = "", CastSumry = "old rss parser (xml-based)", TtlMinuts = 44.444, CastFileLen = castLen, CasFilename = fnm }); // saveToDnldRow_IsNewAdded(_db, feed, castTitle, pubDate, castUrl, "altSrcUrl", "origLink_", "summary__", 44.444, castLen, fnm); } } // foreach (var pCast in availablePodcasts) } catch (Exception ex) { ex.Log(); throw; } } }