Mercurial > minori
diff src/gui/pages/torrents.cc @ 202:71832ffe425a
animia: re-add kvm fd source
this is all being merged from my wildly out-of-date laptop. SORRY!
in other news, I edited the CI file to install the wayland client
as well, so the linux CI build might finally get wayland stuff.
author | Paper <paper@paper.us.eu.org> |
---|---|
date | Tue, 02 Jan 2024 06:05:06 -0500 |
parents | 01d259b9c89f |
children | 53211cb1e7f5 |
line wrap: on
line diff
--- a/src/gui/pages/torrents.cc Sun Nov 19 19:13:28 2023 -0500 +++ b/src/gui/pages/torrents.cc Tue Jan 02 06:05:06 2024 -0500 @@ -4,7 +4,7 @@ #include "core/session.h" #include "gui/widgets/text.h" #include "track/media.h" -#include "pugixml.hpp" + #include <QVBoxLayout> #include <QToolBar> #include <QTreeView> @@ -13,10 +13,12 @@ #include <QDataStream> #include <QThreadPool> #include <QDebug> + #include <iostream> #include <sstream> #include <algorithm> +#include "pugixml.hpp" #include "anitomy/anitomy.h" /* This file is very, very similar to the anime list page. @@ -52,6 +54,41 @@ return HTTP::Get(session.config.torrents.feed_link); } +void TorrentsPageListModel::ParseFeedDescription(const std::string& description, Torrent& torrent) { + /* Parse description... */ + enum class Keys { SIZE, AUTHORIZED, SUBMITTER, COMMENT }; + + const std::unordered_map<std::string, Keys> KeyMap = { + {"Size", Keys::SIZE}, + {"Authorized", Keys::AUTHORIZED}, + {"Submitter", Keys::SUBMITTER}, + {"Comment", Keys::COMMENT} + }; + + /* Parse size from description */ + std::istringstream descstream(description); + + for (std::string line; std::getline(descstream, line);) { + const size_t pos = line.find_first_of(':', 0); + if (pos == std::string::npos) + continue; + + const std::string key = line.substr(0, pos); + const std::string value = line.substr(line.find_first_not_of(": ", pos)); + + switch (KeyMap.at(key)) { + case Keys::COMMENT: + torrent.SetDescription(value); + break; + case Keys::SIZE: + torrent.SetSize(Strings::HumanReadableSizeToBytes(value)); + break; + default: + break; + } + } +} + void TorrentsPageListModel::ParseTorrentList(const QByteArray& ba) { std::istringstream stdstream(Strings::ToUtf8String(ba)); @@ -84,43 +121,9 @@ torrent.SetGroup(Strings::ToUtf8String(elements.get(anitomy::kElementReleaseGroup))); torrent.SetResolution(Strings::ToUtf8String(elements.get(anitomy::kElementVideoResolution))); } - torrent.SetDescription(Strings::TextifySynopsis(item.child_value("description"))); - { - /* Parse description... */ - enum class Keys { SIZE, AUTHORIZED, SUBMITTER, COMMENT }; - - const std::unordered_map<std::string, Keys> KeyMap = { - {"Size", Keys::SIZE}, - {"Authorized", Keys::AUTHORIZED}, - {"Submitter", Keys::SUBMITTER}, - {"Comment", Keys::COMMENT} - }; - - const std::string description = Strings::TextifySynopsis(item.child_value("description")); - - /* Parse size from description */ - std::istringstream descstream(description); - for (std::string line; std::getline(descstream, line);) { - const size_t pos = line.find_first_of(':', 0); - if (pos == std::string::npos) - continue; - - const std::string key = line.substr(0, pos); - const std::string value = line.substr(line.find_first_not_of(": ", pos)); + ParseFeedDescription(Strings::TextifySynopsis(item.child_value("description")), torrent); - switch (KeyMap.at(key)) { - case Keys::COMMENT: - torrent.SetDescription(value); - break; - case Keys::SIZE: - torrent.SetSize(Strings::HumanReadableSizeToBytes(value)); - break; - default: - break; - } - } - } torrent.SetLink(item.child_value("link")); torrent.SetGuid(item.child_value("guid")); {