1
0
Fork 0
mirror of https://github.com/transmission/transmission synced 2025-01-04 05:56:02 +00:00
transmission/qt/FaviconCache.h
Mike Gelfand 3e072f9bd4
Fix most of critical issues reported by Sonar (GTK client) (#2309)
* (C++) Macros should not be used to define constants

* (C++) Memory should not be managed manually

* (C++) "void*" should not be used in typedefs, member variables, function parameters or return type

* (C++) When the "Rule-of-Zero" is not applicable, the "Rule-of-Five" should be followed

* (C++) "switch" statements should have "default" clauses

* (C++) "explicit" should be used on single-parameter constructors and conversiosn operators

* (C++) Non-const global variables should not be used
2021-12-14 11:43:27 +03:00

61 lines
1.3 KiB
C++

/*
* This file Copyright (C) 2012-2015 Mnemosyne LLC
*
* It may be used under the GNU GPL versions 2 or 3
* or any future license endorsed by Mnemosyne LLC.
*
*/
#pragma once
#include <unordered_map>
#include <vector>
#include <QObject>
#include <QPixmap>
#include <QString>
#include <libtransmission/tr-macros.h>
#include "Utils.h" // std::hash<QString>
class QNetworkAccessManager;
class QNetworkReply;
class QUrl;
class FaviconCache : public QObject
{
Q_OBJECT
TR_DISABLE_COPY_MOVE(FaviconCache)
public:
FaviconCache();
using Key = QString;
using Keys = std::vector<Key>;
// returns a cached pixmap, or a nullptr pixmap if there's no match in the cache
QPixmap find(Key const& key);
static Key getKey(QString const& display_name);
// This will emit a signal when (if) the icon becomes ready.
Key add(QString const& url);
static QString getDisplayName(Key const& key);
static QSize getIconSize();
signals:
void pixmapReady(Key const& key);
private slots:
void onRequestFinished(QNetworkReply* reply);
private:
static Key getKey(QUrl const& url);
void ensureCacheDirHasBeenScanned();
QNetworkAccessManager* nam_ = {};
std::unordered_map<Key, QPixmap> pixmaps_;
std::unordered_map<QString, Key> keys_;
};