Переглянути джерело

2009-10-05 Tatsuhiro Tsujikawa <t-tujikawa@users.sourceforge.net>

	Don't save control file when aria2 exists while checking piece
	hash(behavior of -V option). If control file doesn't exist when
	aria2 launched, the completed length in saved control file will be
	0 byte and this confuses user. disableSaveControlFile() is called
	in RequestGroup::processCheckIntegrityEntry().
	enableSaveControlFile() will be called after hash checking is
	done. See CheckIntegrityCommand.
	* src/CheckIntegrityCommand.cc
	* src/RequestGroup.cc
	* src/RequestGroup.h
	* src/RequestGroupMan.cc
Tatsuhiro Tsujikawa 16 роки тому
батько
коміт
5f1d8c7897
5 змінених файлів з 53 додано та 11 видалено
  1. 14 0
      ChangeLog
  2. 4 1
      src/CheckIntegrityCommand.cc
  3. 20 0
      src/RequestGroup.cc
  4. 10 5
      src/RequestGroup.h
  5. 5 5
      src/RequestGroupMan.cc

+ 14 - 0
ChangeLog

@@ -1,3 +1,17 @@
+2009-10-05  Tatsuhiro Tsujikawa  <t-tujikawa@users.sourceforge.net>
+
+	Don't save control file when aria2 exists while checking piece
+	hash(behavior of -V option). If control file doesn't exist when
+	aria2 launched, the completed length in saved control file will be
+	0 byte and this confuses user. disableSaveControlFile() is called
+	in RequestGroup::processCheckIntegrityEntry().
+	enableSaveControlFile() will be called after hash checking is
+	done. See CheckIntegrityCommand.
+	* src/CheckIntegrityCommand.cc
+	* src/RequestGroup.cc
+	* src/RequestGroup.h
+	* src/RequestGroupMan.cc
+
 2009-10-05  Tatsuhiro Tsujikawa  <t-tujikawa@users.sourceforge.net>
 
 	Included version number in Peer ID and client version.  Peer ID

+ 4 - 1
src/CheckIntegrityCommand.cc

@@ -60,7 +60,10 @@ bool CheckIntegrityCommand::executeInternal()
   _entry->validateChunk();
   if(_entry->finished()) {
     _e->_checkIntegrityMan->dropPickedEntry();
-
+    // Enable control file saving here. See also
+    // RequestGroup::processCheckIntegrityEntry() to know why this is
+    // needed.
+    _requestGroup->enableSaveControlFile();
     if(_requestGroup->downloadFinished()) {
       logger->notice(MSG_VERIFICATION_SUCCESSFUL,
 		     _requestGroup->getDownloadContext()->getBasePath().c_str());

+ 20 - 0
src/RequestGroup.cc

@@ -118,6 +118,7 @@ RequestGroup::RequestGroup(const SharedHandle<Option>& option):
   _numStreamConnection(0),
   _numCommand(0),
   _segmentManFactory(new DefaultSegmentManFactory(_option.get())),
+  _saveControlFile(true),
   _progressInfoFile(new NullProgressInfoFile()),
   _preLocalFileCheckEnabled(true),
   _haltRequested(false),
@@ -394,6 +395,13 @@ void RequestGroup::processCheckIntegrityEntry(std::deque<Command*>& commands,
      entry->isValidationReady()) {
     entry->initValidator();
     entry->cutTrailingGarbage();
+    // Don't save control file(.aria2 file) when user presses
+    // control-c key while aria2 is checking hashes. If control file
+    // doesn't exist when aria2 launched, the completed length in
+    // saved control file will be 0 byte and this confuses user.
+    // enableSaveControlFile() will be called after hash checking is
+    // done. See CheckIntegrityCommand.
+    disableSaveControlFile();
     e->_checkIntegrityMan->pushEntry(entry);
   } else
 #endif // ENABLE_MESSAGE_DIGEST
@@ -1018,4 +1026,16 @@ void RequestGroup::setLastUriResult
   _lastUriResult.reset(new URIResult(uri, result));
 }
 
+void RequestGroup::saveControlFile() const
+{
+  if(_saveControlFile) {
+    _progressInfoFile->save();
+  }
+}
+
+void RequestGroup::removeControlFile() const
+{
+  _progressInfoFile->removeFile();
+}
+
 } // namespace aria2

+ 10 - 5
src/RequestGroup.h

@@ -102,6 +102,8 @@ private:
 
   SharedHandle<PieceStorage> _pieceStorage;
 
+  bool _saveControlFile;
+
   SharedHandle<BtProgressInfoFile> _progressInfoFile;
 
   SharedHandle<DiskWriterFactory> _diskWriterFactory;
@@ -253,11 +255,6 @@ public:
 
   void setPieceStorage(const SharedHandle<PieceStorage>& pieceStorage);
 
-  const SharedHandle<BtProgressInfoFile>& getProgressInfoFile() const
-  {
-    return _progressInfoFile;
-  }
-
   void setProgressInfoFile(const SharedHandle<BtProgressInfoFile>& progressInfoFile);
 
   void increaseStreamConnection();
@@ -440,6 +437,14 @@ public:
 
   void setLastUriResult(std::string uri, downloadresultcode::RESULT result);
 
+  void saveControlFile() const;
+
+  void removeControlFile() const;
+
+  void enableSaveControlFile() { _saveControlFile = true; }
+
+  void disableSaveControlFile() { _saveControlFile = false; }
+
   static void resetGIDCounter() { _gidCounter = 0; }
 };
 

+ 5 - 5
src/RequestGroupMan.cc

@@ -301,10 +301,10 @@ public:
 	  group->applyLastModifiedTimeToLocalFiles();
 	  group->reportDownloadFinished();
 	  if(group->allDownloadFinished()) {
-	    group->getProgressInfoFile()->removeFile();
+	    group->removeControlFile();
 	    saveSignature(group);
 	  } else {
-	    group->getProgressInfoFile()->save();
+	    group->saveControlFile();
 	  }
 	  RequestGroups nextGroups;
 	  group->postDownloadProcessing(nextGroups);
@@ -316,7 +316,7 @@ public:
 				   nextGroups.begin(), nextGroups.end());
 	  }
 	} else {
-	  group->getProgressInfoFile()->save();
+	  group->saveControlFile();
 	}
       } catch(RecoverableException& ex) {
 	_logger->error(EX_EXCEPTION_CAUGHT, ex);
@@ -500,10 +500,10 @@ void RequestGroupMan::save()
   for(RequestGroups::iterator itr = _requestGroups.begin();
       itr != _requestGroups.end(); ++itr) {
     if((*itr)->allDownloadFinished()) {
-      (*itr)->getProgressInfoFile()->removeFile();
+      (*itr)->removeControlFile();
     } else {
       try {
-	(*itr)->getProgressInfoFile()->save();
+	(*itr)->saveControlFile();
       } catch(RecoverableException& e) {
 	_logger->error(EX_EXCEPTION_CAUGHT, e);
       }