Add a limit option to the pool retrieval functions
To download less than the maximum (and ease testing)
This commit is contained in:
parent
c5b8fccc6f
commit
08402657a0
3 changed files with 15 additions and 6 deletions
|
@ -106,7 +106,7 @@ void KonachanDanbooruService::getPostList() {
|
|||
|
||||
}
|
||||
|
||||
void KonachanDanbooruService::getPoolList()
|
||||
void KonachanDanbooruService::getPoolList(int limit)
|
||||
{
|
||||
|
||||
QUrl danbooruUrl;
|
||||
|
@ -130,7 +130,7 @@ void KonachanDanbooruService::getPoolList()
|
|||
|
||||
// connect(job, &KIO::StoredTransferJob::result, this, &DanbooruService::processPoolList);
|
||||
|
||||
connect(job, &KIO::StoredTransferJob::result, [this](KJob * job) {
|
||||
connect(job, &KIO::StoredTransferJob::result, [this, limit](KJob * job) {
|
||||
|
||||
if (job->error()) {
|
||||
Q_EMIT(downloadError(job->errorString()));
|
||||
|
@ -148,6 +148,10 @@ void KonachanDanbooruService::getPoolList()
|
|||
return;
|
||||
}
|
||||
|
||||
if (limit > 0 && poolList.length() > limit) {
|
||||
poolList = poolList.mid(0, limit);
|
||||
}
|
||||
|
||||
for (auto element : poolList) {
|
||||
QVariantMap map = element.toMap();
|
||||
|
||||
|
@ -378,7 +382,13 @@ void KonachanDanbooruService::processPostList(KJob *job)
|
|||
}
|
||||
|
||||
m_postsToFetch = postList.length();
|
||||
// qCDebug(LIBDANBOORU) << "Found " << m_postsToFetch << "posts to fetch";
|
||||
qCDebug(LIBDANBOORU) << "Found " << m_postsToFetch << "posts to fetch" << "with limit" << m_maxPosts;
|
||||
|
||||
// This is mostly needed for pools
|
||||
if (postList.length() > m_maxPosts) {
|
||||
m_postsToFetch = m_maxPosts;
|
||||
postList = postList.mid(0, m_maxPosts);
|
||||
}
|
||||
|
||||
for (auto element : postList) {
|
||||
|
||||
|
@ -446,7 +456,6 @@ void KonachanDanbooruService::processPostList(KJob *job)
|
|||
m_cache->insertPixmap(post->thumbnailUrl().url(), pix);
|
||||
}
|
||||
|
||||
|
||||
m_postsToFetch--; // One less post to do
|
||||
|
||||
qCDebug(LIBDANBOORU) << "Current posts remaining: " << m_postsToFetch;
|
||||
|
|
|
@ -48,7 +48,7 @@ public:
|
|||
Danbooru::ApiType apiType() const override;
|
||||
|
||||
void getPostList() override;
|
||||
void getPoolList() override;
|
||||
void getPoolList(int limit = -1) override;
|
||||
void getPool(int poolId, int page = 1) override;
|
||||
void getTagList(int limit = 10, QString name = "") override;
|
||||
void getRelatedTags(const QStringList &tags,
|
||||
|
|
|
@ -282,7 +282,7 @@ public:
|
|||
* This does not actually retrieve pool contents, only their definitions.
|
||||
*
|
||||
**/
|
||||
virtual void getPoolList() = 0;
|
||||
virtual void getPoolList(int limit = -1) = 0;
|
||||
|
||||
/**
|
||||
* @brief retrieve posts associated to a specific pool from a Danbooru board.
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue