int QueueBundleUtils::compareBundles(const BundlePtr& a, const BundlePtr& b, int aPropertyName) noexcept { switch (aPropertyName) { case PROP_NAME: { COMPARE_TYPE(a, b); return Util::stricmp(a->getName(), b->getName()); } case PROP_TYPE: { COMPARE_TYPE(a, b); if (!a->isFileBundle() && !b->isFileBundle()) { // Directory bundles RLock l(QueueManager::getInstance()->getCS()); auto dirsA = QueueManager::getInstance()->bundleQueue.getDirectoryCount(a); auto dirsB = QueueManager::getInstance()->bundleQueue.getDirectoryCount(b); if (dirsA != dirsB) { return compare(dirsA, dirsB); } auto filesA = a->getQueueItems().size() + a->getFinishedFiles().size(); auto filesB = b->getQueueItems().size() + b->getFinishedFiles().size(); return compare(filesA, filesB); } return Util::stricmp(Util::getFileExt(a->getTarget()), Util::getFileExt(b->getTarget())); } case PROP_PRIORITY: { COMPARE_FINISHED(a, b); if (a->isFinished() != b->isFinished()) { return a->isFinished() ? 1 : -1; } return compare(static_cast<int>(a->getPriority()), static_cast<int>(b->getPriority())); } case PROP_STATUS: { if (a->getStatus() != b->getStatus()) { return compare(a->getStatus(), b->getStatus()); } return compare( a->getPercentage(a->getDownloadedBytes()), b->getPercentage(b->getDownloadedBytes()) ); } case PROP_SOURCES: { COMPARE_FINISHED(a, b); auto countsA = QueueManager::getInstance()->getSourceCount(a); auto countsB = QueueManager::getInstance()->getSourceCount(b); return QueueItemBase::SourceCount::compare(countsA, countsB); } default: dcassert(0); } return 0; }
std::string QueueBundleUtils::formatBundleType(const BundlePtr& aBundle) noexcept { if (aBundle->isFileBundle()) { return Format::formatFileType(aBundle->getTarget()); } else { size_t files = 0, folders = 0; QueueManager::getInstance()->getBundleContent(aBundle, files, folders); return Format::formatFolderContent(files, folders); } }
json QueueUtils::serializeBundleProperty(const BundlePtr& aBundle, int aPropertyName) noexcept { switch (aPropertyName) { case QueueApi::PROP_SOURCES: { int total = 0, online = 0; std::string str; getBundleSourceInfo(aBundle, online, total, str); return { { "online", online }, { "total", total }, { "str", str }, }; } case QueueApi::PROP_STATUS: { return{ { "id", aBundle->getStatus() }, { "failed", aBundle->isFailed() }, { "str", formatBundleStatus(aBundle) }, }; } case QueueApi::PROP_TYPE: { if (aBundle->isFileBundle()) { return Serializer::serializeFileType(aBundle->getTarget()); } else { size_t files = 0; size_t folders = 0; { RLock l(QueueManager::getInstance()->getCS()); files = aBundle->getQueueItems().size() + aBundle->getFinishedFiles().size(); folders = aBundle->getDirectories().size(); } return Serializer::serializeFolderType(files, folders); } } case QueueApi::PROP_PRIORITY: { return serializePriority(*aBundle.get()); } } dcassert(0); return json(); }
std::string QueueUtils::formatBundleType(const BundlePtr& aBundle) noexcept { if (aBundle->isFileBundle()) { return Format::formatFileType(aBundle->getTarget()); } else { size_t files = 0; size_t folders = 0; { RLock l(QueueManager::getInstance()->getCS()); files = aBundle->getQueueItems().size() + aBundle->getFinishedFiles().size(); folders = aBundle->getDirectories().size(); } return Format::formatFolderContent(files, folders); } }
void BundleQueue::addBundleItem(QueueItemPtr& aQI, BundlePtr& aBundle) noexcept { dcassert(!aQI->getBundle()); aBundle->addQueue(aQI); aQI->setBundle(aBundle); if (!aBundle->isFileBundle()) { forEachPath(aBundle, aQI->getTarget(), [&](PathInfo& aInfo) { if (aQI->isDownloaded()) { aInfo.finishedFiles++; } else { aInfo.queuedFiles++; } aInfo.size += aQI->getSize(); }); } if (!aQI->isDownloaded()) { queueSize += aQI->getSize(); } }
json QueueBundleUtils::serializeBundleProperty(const BundlePtr& aBundle, int aPropertyName) noexcept { switch (aPropertyName) { case PROP_SOURCES: { auto c = QueueManager::getInstance()->getSourceCount(aBundle); return Serializer::serializeSourceCount(c); } case PROP_STATUS: { return{ { "id", formatStatusId(aBundle) }, { "failed", aBundle->isFailed() }, { "finished", aBundle->getStatus() >= Bundle::STATUS_MOVED }, { "str", formatDisplayStatus(aBundle) }, }; } case PROP_TYPE: { if (aBundle->isFileBundle()) { return Serializer::serializeFileType(aBundle->getTarget()); } else { size_t files = 0, folders = 0; QueueManager::getInstance()->getBundleContent(aBundle, files, folders); return Serializer::serializeFolderType(static_cast<int>(files), static_cast<int>(folders)); } } case PROP_PRIORITY: { return Serializer::serializePriority(*aBundle.get()); } } dcassert(0); return nullptr; }
int QueueUtils::compareBundles(const BundlePtr& a, const BundlePtr& b, int aPropertyName) noexcept { switch (aPropertyName) { case QueueApi::PROP_NAME: { if (a->isFileBundle() && !b->isFileBundle()) return 1; if (!a->isFileBundle() && b->isFileBundle()) return -1; return Util::stricmp(a->getName(), b->getName()); } case QueueApi::PROP_TYPE: { if (a->isFileBundle() != b->isFileBundle()) { // Directories go first return a->isFileBundle() ? 1 : -1; } if (!a->isFileBundle() && !b->isFileBundle()) { // Directory bundles RLock l(QueueManager::getInstance()->getCS()); auto dirsA = a->getDirectories().size(); auto dirsB = a->getDirectories().size(); if (dirsA != dirsB) { return compare(dirsA, dirsB); } auto filesA = a->getQueueItems().size() + a->getFinishedFiles().size(); auto filesB = b->getQueueItems().size() + b->getFinishedFiles().size(); return compare(filesA, filesB); } return Util::stricmp(Util::getFileExt(a->getTarget()), Util::getFileExt(b->getTarget())); } case QueueApi::PROP_PRIORITY: { if (a->isFinished() != b->isFinished()) { return a->isFinished() ? 1 : -1; } return compare(static_cast<int>(a->getPriority()), static_cast<int>(b->getPriority())); } case QueueApi::PROP_STATUS: { if (a->getStatus() != b->getStatus()) { return compare(a->getStatus(), b->getStatus()); } return compare(a->getDownloadedBytes(), b->getDownloadedBytes()); } case QueueApi::PROP_SOURCES: { if (a->isFinished() != b->isFinished()) { return a->isFinished() ? 1 : -1; } int onlineA = 0, totalA = 0, onlineB = 0, totalB = 0; std::string str; getBundleSourceInfo(a, onlineA, totalA, str); getBundleSourceInfo(b, onlineB, totalB, str); if (onlineA != onlineB) { return compare(onlineA, onlineB); } return compare(totalA, totalB); } default: dcassert(0); } return 0; }