/* */ #include "UTMetadataRequestTracker.h" #include #include "Logger.h" #include "LogFactory.h" #include "fmt.h" namespace aria2 { UTMetadataRequestTracker::UTMetadataRequestTracker() {} void UTMetadataRequestTracker::add(size_t index) { trackedRequests_.push_back(RequestEntry(index)); } bool UTMetadataRequestTracker::tracks(size_t index) { return std::find(trackedRequests_.begin(), trackedRequests_.end(), RequestEntry(index)) != trackedRequests_.end(); } void UTMetadataRequestTracker::remove(size_t index) { auto i = std::find(trackedRequests_.begin(), trackedRequests_.end(), RequestEntry(index)); if (i != trackedRequests_.end()) { trackedRequests_.erase(i); } } namespace { constexpr auto TIMEOUT = 20_s; } // namespace std::vector UTMetadataRequestTracker::removeTimeoutEntry() { std::vector indexes; trackedRequests_.erase( std::remove_if(std::begin(trackedRequests_), std::end(trackedRequests_), [&indexes](const RequestEntry& ent) { if (ent.elapsed(TIMEOUT)) { A2_LOG_DEBUG( fmt("ut_metadata request timeout. index=%lu", static_cast(ent.index_))); indexes.push_back(ent.index_); return true; } return false; }), std::end(trackedRequests_)); return indexes; } size_t UTMetadataRequestTracker::avail() const { const size_t MAX_OUTSTANDING_REQUEST = 1; if (MAX_OUTSTANDING_REQUEST > count()) { return MAX_OUTSTANDING_REQUEST - count(); } else { return 0; } } std::vector UTMetadataRequestTracker::getAllTrackedIndex() const { std::vector indexes; for (auto& e : trackedRequests_) { indexes.push_back(e.index_); } return indexes; } } // namespace aria2