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"));
 		{