mirror of
https://github.com/d47081/qBittorrent.git
synced 2025-01-25 14:04:23 +00:00
WebUI: Use QVariantMap instead of QVariantHash
Currently QJsonDocument::fromVariant() does not support QVariantHash, so use QVariantMap instead. Closes #2849.
This commit is contained in:
parent
7af4928b18
commit
d49c79d032
@ -157,7 +157,7 @@ static const char KEY_SUFFIX_REMOVED[] = "_removed";
|
|||||||
QVariantMap getTranserInfoMap();
|
QVariantMap getTranserInfoMap();
|
||||||
QVariantMap toMap(const QTorrentHandle& h);
|
QVariantMap toMap(const QTorrentHandle& h);
|
||||||
void processMap(QVariantMap prevData, QVariantMap data, QVariantMap &syncData);
|
void processMap(QVariantMap prevData, QVariantMap data, QVariantMap &syncData);
|
||||||
void processHash(QVariantHash prevData, QVariantHash data, QVariantMap &syncData, QVariantList &removedItems);
|
void processHash(QVariantMap prevData, QVariantMap data, QVariantMap &syncData, QVariantList &removedItems);
|
||||||
void processList(QVariantList prevData, QVariantList data, QVariantList &syncData, QVariantList &removedItems);
|
void processList(QVariantList prevData, QVariantList data, QVariantList &syncData, QVariantList &removedItems);
|
||||||
QVariantMap generateSyncData(int acceptedResponseId, QVariantMap data, QVariantMap &lastAcceptedData, QVariantMap &lastData);
|
QVariantMap generateSyncData(int acceptedResponseId, QVariantMap data, QVariantMap &lastAcceptedData, QVariantMap &lastData);
|
||||||
|
|
||||||
@ -314,7 +314,7 @@ QByteArray btjson::getSyncMainData(int acceptedResponseId, QVariantMap &lastData
|
|||||||
{
|
{
|
||||||
QVariantMap data;
|
QVariantMap data;
|
||||||
|
|
||||||
QVariantHash torrents;
|
QVariantMap torrents;
|
||||||
|
|
||||||
std::vector<torrent_handle> torrentsList = QBtSession::instance()->getTorrents();
|
std::vector<torrent_handle> torrentsList = QBtSession::instance()->getTorrents();
|
||||||
std::vector<torrent_handle>::const_iterator it = torrentsList.begin();
|
std::vector<torrent_handle>::const_iterator it = torrentsList.begin();
|
||||||
@ -600,14 +600,7 @@ void processMap(QVariantMap prevData, QVariantMap data, QVariantMap &syncData)
|
|||||||
switch (data[key].type()) {
|
switch (data[key].type()) {
|
||||||
case QVariant::Map: {
|
case QVariant::Map: {
|
||||||
QVariantMap map;
|
QVariantMap map;
|
||||||
processMap(prevData[key].toMap(), data[key].toMap(), map);
|
processHash(prevData[key].toMap(), data[key].toMap(), map, removedItems);
|
||||||
if (!map.isEmpty())
|
|
||||||
syncData[key] = map;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case QVariant::Hash: {
|
|
||||||
QVariantMap map;
|
|
||||||
processHash(prevData[key].toHash(), data[key].toHash(), map, removedItems);
|
|
||||||
if (!map.isEmpty())
|
if (!map.isEmpty())
|
||||||
syncData[key] = map;
|
syncData[key] = map;
|
||||||
if (!removedItems.isEmpty())
|
if (!removedItems.isEmpty())
|
||||||
@ -643,7 +636,7 @@ void processMap(QVariantMap prevData, QVariantMap data, QVariantMap &syncData)
|
|||||||
// Compare two lists of structures (prevData, data) and calculate difference (syncData, removedItems).
|
// Compare two lists of structures (prevData, data) and calculate difference (syncData, removedItems).
|
||||||
// Structures encoded as map.
|
// Structures encoded as map.
|
||||||
// Lists are encoded as hash table (indexed by structure key value) to improve ease of searching for removed items.
|
// Lists are encoded as hash table (indexed by structure key value) to improve ease of searching for removed items.
|
||||||
void processHash(QVariantHash prevData, QVariantHash data, QVariantMap &syncData, QVariantList &removedItems)
|
void processHash(QVariantMap prevData, QVariantMap data, QVariantMap &syncData, QVariantList &removedItems)
|
||||||
{
|
{
|
||||||
// initialize output variables
|
// initialize output variables
|
||||||
syncData.clear();
|
syncData.clear();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user