1
0
Fork 0
mirror of https://github.com/transmission/transmission synced 2025-01-19 05:19:54 +00:00
transmission/qt/FaviconCache.h
Mike Gelfand dadffa2c0f Align type qualifiers to the right (code style)
This way all the qualifiers (`const`, `volatile`, `mutable`) are grouped
together, e.g. `T const* const x` vs. `const T* const x`. Also helps reading
types right-to-left, e.g. "constant pointer to constant T" vs. "constant
pointer to T which is constant".
2017-04-20 19:53:20 +03:00

53 lines
1.1 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 <QMap>
#include <QString>
#include <QObject>
#include <QPixmap>
class QNetworkAccessManager;
class QNetworkReply;
class QUrl;
class FaviconCache : public QObject
{
Q_OBJECT
public:
FaviconCache();
virtual ~FaviconCache();
// returns a cached pixmap, or a NULL pixmap if there's no match in the cache
QPixmap find(QUrl const& url);
// returns a cached pixmap, or a NULL pixmap if there's no match in the cache
QPixmap findFromHost(QString const& host);
// this will emit a signal when (if) the icon becomes ready
void add(QUrl const& url);
static QString getHost(QUrl const& url);
static QSize getIconSize();
signals:
void pixmapReady(QString const& host);
private:
QString getCacheDir();
void ensureCacheDirHasBeenScanned();
private slots:
void onRequestFinished(QNetworkReply* reply);
private:
QNetworkAccessManager* myNAM;
QMap<QString, QPixmap> myPixmaps;
};