/* */ #include "BtFileAllocationEntry.h" #include #include "BtSetup.h" #include "RequestGroup.h" #include "Command.h" #include "DownloadEngine.h" #include "DownloadContext.h" #include "FileEntry.h" #include "PieceStorage.h" #include "DiskAdaptor.h" #include "Option.h" #include "prefs.h" #include "LogFactory.h" namespace aria2 { BtFileAllocationEntry::BtFileAllocationEntry(RequestGroup* requestGroup) : FileAllocationEntry(requestGroup, nullptr) { } BtFileAllocationEntry::~BtFileAllocationEntry() {} void BtFileAllocationEntry::prepareForNextAction( std::vector>& commands, DownloadEngine* e) { auto& option = getRequestGroup()->getOption(); BtSetup().setup(commands, getRequestGroup(), e, option.get()); if (option->getAsBool(PREF_ENABLE_MMAP) && option->get(PREF_FILE_ALLOCATION) != V_NONE && getRequestGroup()->getPieceStorage()->getDiskAdaptor()->size() <= option->getAsLLInt(PREF_MAX_MMAP_LIMIT)) { getRequestGroup()->getPieceStorage()->getDiskAdaptor()->enableMmap(); } if (!getRequestGroup()->downloadFinished()) { // For DownloadContext::resetDownloadStartTime(), see also // RequestGroup::createInitialCommand() getRequestGroup()->getDownloadContext()->resetDownloadStartTime(); const std::vector>& fileEntries = getRequestGroup()->getDownloadContext()->getFileEntries(); if (isUriSuppliedForRequsetFileEntry(std::begin(fileEntries), std::end(fileEntries))) { getRequestGroup()->createNextCommandWithAdj(commands, e, 0); } } else { #ifdef __MINGW32__ const std::shared_ptr& diskAdaptor = getRequestGroup()->getPieceStorage()->getDiskAdaptor(); if (!diskAdaptor->isReadOnlyEnabled()) { // On Windows, if aria2 opens files with GENERIC_WRITE access // right, some programs cannot open them aria2 is seeding. To // avoid this situation, re-open the files with read-only // enabled. A2_LOG_INFO("Closing files and re-open them with read-only mode" " enabled."); diskAdaptor->closeFile(); diskAdaptor->enableReadOnly(); diskAdaptor->openFile(); } #endif // __MINGW32__ getRequestGroup()->enableSeedOnly(); } } } // namespace aria2