From 92bee957b4face63285933f48f6d6e04ac064ca8 Mon Sep 17 00:00:00 2001 From: Physick <96335032+DegustatorPonos@users.noreply.github.com> Date: Sun, 10 May 2026 19:55:02 +0500 Subject: Time sorting --- src/RSS.cpp | 17 +++++++++++++++-- src/RSS.hpp | 1 + src/main.cpp | 8 ++++++-- 3 files changed, 22 insertions(+), 4 deletions(-) (limited to 'src') diff --git a/src/RSS.cpp b/src/RSS.cpp index 1282c83..93c391d 100644 --- a/src/RSS.cpp +++ b/src/RSS.cpp @@ -86,6 +86,18 @@ void RSS::print() { } } +void RSS::print_latest(int minutesSpan) { + std::time_t now = std::time(nullptr); + std::tm* gmt_time = std::gmtime(&now); + gmt_time->tm_min -= minutesSpan; + auto ticks = std::mktime(gmt_time); + + for (auto entry : Entries) { + if (entry.pubDate.tm_year == 0 || std::mktime(&entry.pubDate) < ticks) break; + entry.print(); + } +} + RSS_Entry::RSS_Entry(XML_leaf node) { Title = node.GetChild("title").GetValue(); URL = node.GetChild("link").GetValue(); @@ -98,9 +110,10 @@ RSS_Entry::RSS_Entry(XML_leaf node) { void RSS_Entry::print() { std::cout - << "==============================\n" << Title << '\n' << std::put_time(&pubDate, "%Y-%m-%d %H:%M:%S") << '\n' << Contents << '\n' - << URL<< '\n'; + << URL<< '\n' + << "==============================\n"; } + diff --git a/src/RSS.hpp b/src/RSS.hpp index 1ff2bc7..5dd8376 100644 --- a/src/RSS.hpp +++ b/src/RSS.hpp @@ -215,6 +215,7 @@ class RSS { RSS(std::string url); void print(); + void print_latest(int minutesSpan); private: std::string request(); diff --git a/src/main.cpp b/src/main.cpp index b7ff89a..cabe6dd 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -24,10 +24,14 @@ int main() { return 1; } XML_leaf configParsed(config); + + auto span = std::stoi(configParsed.GetChild("lastminutes").GetValue()); + std::cout << "News of the last " << span << " minutes:" << std::endl; + auto sources = configParsed.GetChildren("source"); for (auto src : sources) { - std::cout << "URL: " << src.GetValue() << std::endl; - RSS(src.GetValue()).print(); + // std::cout << "URL: " << src.GetValue() << std::endl; + RSS(src.GetValue()).print_latest(span); } } catch (char *ex) { std::cout << "failed to read config file: " << ex << std::endl; -- cgit v1.3