blob: 5aab2b647eccea3ce41f1d3ac3a919924d282ca9 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
|
#ifndef CACHEHANDLER_HPP
#define CACHEHANDLER_HPP
#include "mimeparser.hpp"
#include <memory>
#include <unordered_map>
#include <QUrl>
#include <QString>
#include <QByteArray>
#include <QtGlobal>
// Need a QString hash implementation for Qt versions below 5.14
#if QT_VERSION < QT_VERSION_CHECK(5, 14, 0)
#include <QHash>
namespace std
{
template<>
struct hash<QString>
{
std::size_t operator()(const QString& s) const noexcept
{
return (size_t)qHash(s);
}
};
}
#endif
struct CachedPage
{
QUrl url;
QByteArray body;
MimeType mime;
int scroll_pos;
// also: maybe compress page contents? May test
// to see if it's worth it
CachedPage(const QUrl &url, const QByteArray &body, const MimeType &mime)
: url(url), body(body), mime(mime), scroll_pos(-1)
{}
};
typedef std::unordered_map<QString, std::shared_ptr<CachedPage>> CacheMap;
class CacheHandler
{
public:
void push(QUrl const & url, QByteArray const & body, MimeType const & mime);
std::shared_ptr<CachedPage> find(QUrl const &url);
bool contains(QUrl const & url) const;
CacheMap const& getPages() const;
private:
std::shared_ptr<CachedPage> find(QString const &url);
bool contains(QString const & url) const;
private:
// In-memory cache storage.
CacheMap page_cache;
};
#endif
|