transmission/qt/favicon.h

62 lines
1.2 KiB
C
Raw Normal View History

/*
* This file Copyright (C) 2012-2014 Mnemosyne LLC
*
* It may be used under the GNU Public License v2 or v3 licenses,
* or any future license endorsed by Mnemosyne LLC.
*
* $Id$
*/
#ifndef FAVICON_CACHE_H
#define FAVICON_CACHE_H
class QNetworkAccessManager;
class QNetworkReply;
class QUrl;
#include <QMap>
#include <QString>
#include <QObject>
#include <QPixmap>
class Favicons: public QObject
{
2013-09-14 22:45:04 +00:00
Q_OBJECT;
2013-09-14 22:45:04 +00:00
public:
2013-09-14 22:45:04 +00:00
static QString getHost( const QUrl& url );
2013-09-14 22:45:04 +00:00
public:
2013-09-14 22:45:04 +00:00
Favicons();
virtual ~Favicons();
2013-09-14 22:45:04 +00:00
// returns a cached pixmap, or a NULL pixmap if there's no match in the cache
QPixmap find (const QUrl& url);
2013-09-14 22:45:04 +00:00
// returns a cached pixmap, or a NULL pixmap if there's no match in the cache
QPixmap findFromHost (const QString& host);
2013-09-14 22:45:04 +00:00
// this will emit a signal when (if) the icon becomes ready
void add (const QUrl& url);
2013-09-14 22:45:04 +00:00
signals:
2013-09-14 22:45:04 +00:00
void pixmapReady (const QString& host);
2013-09-14 22:45:04 +00:00
private:
2013-09-14 22:45:04 +00:00
QNetworkAccessManager * myNAM;
QMap<QString,QPixmap> myPixmaps;
2013-09-14 22:45:04 +00:00
QString getCacheDir ();
void ensureCacheDirHasBeenScanned ();
2013-09-14 22:45:04 +00:00
private slots:
2013-09-14 22:45:04 +00:00
void onRequestFinished (QNetworkReply * reply);
};
#endif