/* */ #include "FileAllocationCommand.h" #include "FileAllocationMan.h" #include "FileAllocationEntry.h" #include "DownloadEngine.h" #include "RequestGroup.h" #include "Logger.h" #include "message.h" #include "prefs.h" #include "util.h" #include "DownloadEngine.h" #include "DownloadContext.h" #include "a2functional.h" #include "RecoverableException.h" #include "wallclock.h" #include "RequestGroupMan.h" #include "CheckIntegrityEntry.h" #include "ServerStatMan.h" namespace aria2 { FileAllocationCommand::FileAllocationCommand (cuid_t cuid, RequestGroup* requestGroup, DownloadEngine* e, const SharedHandle& fileAllocationEntry): RealtimeCommand(cuid, requestGroup, e), _fileAllocationEntry(fileAllocationEntry) {} FileAllocationCommand::~FileAllocationCommand() {} bool FileAllocationCommand::executeInternal() { if(getRequestGroup()->isHaltRequested()) { getDownloadEngine()->getFileAllocationMan()->dropPickedEntry(); return true; } _fileAllocationEntry->allocateChunk(); if(_fileAllocationEntry->finished()) { if(getLogger()->debug()) { getLogger()->debug (MSG_ALLOCATION_COMPLETED, _timer.difference(global::wallclock), util::itos(getRequestGroup()->getTotalLength(), true).c_str()); } getDownloadEngine()->getFileAllocationMan()->dropPickedEntry(); std::vector* commands = new std::vector(); auto_delete_container > commandsDel(commands); _fileAllocationEntry->prepareForNextAction(*commands, getDownloadEngine()); getDownloadEngine()->addCommand(*commands); commands->clear(); getDownloadEngine()->setNoWait(true); return true; } else { getDownloadEngine()->addCommand(this); return false; } } bool FileAllocationCommand::handleException(Exception& e) { getDownloadEngine()->getFileAllocationMan()->dropPickedEntry(); getLogger()->error (MSG_FILE_ALLOCATION_FAILURE, e, util::itos(getCuid()).c_str()); getLogger()->error (MSG_DOWNLOAD_NOT_COMPLETE, util::itos(getCuid()).c_str(), getRequestGroup()->getDownloadContext()->getBasePath().c_str()); return true; } } // namespace aria2