- Fetcher::reset() should not reset cache directories.
authorDuncan Mac-Vicar P <dmacvicar@suse.de>
Sun, 17 Feb 2008 20:47:08 +0000 (20:47 +0000)
committerDuncan Mac-Vicar P <dmacvicar@suse.de>
Sun, 17 Feb 2008 20:47:08 +0000 (20:47 +0000)
  (bnc #348050)
- version 4.2.6

VERSION.cmake
package/libzypp.changes
zypp/Fetcher.cc
zypp/Fetcher.h
zypp/repo/yum/Downloader.h

index f650bb178bb062f6c4492ab568db27507c1a0f01..a4c02d44a2970a0adec5a0c4ebb751579ae08d59 100644 (file)
@@ -47,4 +47,4 @@
 SET(LIBZYPP_MAJOR "4")
 SET(LIBZYPP_MINOR "2")
 SET(LIBZYPP_COMPATMINOR "2")
-SET(LIBZYPP_PATCH "5")
+SET(LIBZYPP_PATCH "6")
index 4b06b058f5336765e182790c8d603104766b35b6..267db69dcdafc407eb7d8f64f0408ec1234e4ec9 100644 (file)
@@ -1,3 +1,10 @@
+Sun Feb 17 21:44:12 CET 2008 - dmacvicar@suse.de
+-------------------------------------------------------------------
+
+- Fetcher::reset() should not reset cache directories.
+  (bnc #348050)
+- version 4.2.6
+
 -------------------------------------------------------------------
 Fri Feb 16 15:47:00 CET 2008 - dmacvicar@suse.de
 
@@ -5,7 +12,7 @@ Fri Feb 16 15:47:00 CET 2008 - dmacvicar@suse.de
   for http and https, but this time set CURLOPT_HTTPGET back to 1
   so it actually works. This makes Media::doesFileExist
   efficient for http and https.
-  (bnc #348050)
+  (related to bnc #348050)
 - version 4.2.5
 
 -------------------------------------------------------------------
index fd444aca624c91022e17e7a9bf4b3ed937908cd9..b5c20c0032dafa234360a344258eae2c8b159abd 100644 (file)
@@ -12,6 +12,7 @@
 #include <iostream>
 #include <list>
 
+#include "zypp/base/Easy.h"
 #include "zypp/base/Logger.h"
 #include "zypp/base/PtrTypes.h"
 #include "zypp/base/DefaultIntegral.h"
@@ -53,11 +54,15 @@ namespace zypp
   //   CLASS NAME : Fetcher::Impl
   //
   /** Fetcher implementation. */
-  struct Fetcher::Impl
+  class Fetcher::Impl
   {
 
   public:
-
+    Impl() {}
+    ~Impl() {
+      MIL << endl;
+     }
+    
     void enqueue( const OnMediaLocation &resource, const FileChecker &checker  );
     void enqueueDigested( const OnMediaLocation &resource, const FileChecker &checker );
     void addCachePath( const Pathname &cache_dir );
@@ -84,7 +89,6 @@ namespace zypp
   };
   ///////////////////////////////////////////////////////////////////
 
-
   void Fetcher::Impl::enqueueDigested( const OnMediaLocation &resource, const FileChecker &checker )
   {
     FetcherJob_Ptr job;
@@ -108,7 +112,6 @@ namespace zypp
   void Fetcher::Impl::reset()
   {
     _resources.clear();
-    _caches.clear();
   }
 
   void Fetcher::Impl::addCachePath( const Pathname &cache_dir )
@@ -116,12 +119,13 @@ namespace zypp
     PathInfo info(cache_dir);
     if ( info.isDir() )
     {
+      DBG << "Adding fetcher cache: '" << cache_dir << "'." << endl;
       _caches.push_back(cache_dir);
     }
     else
     {
       // don't add bad cache directory, just log the error
-      ERR << "Not adding cache: '" << cache_dir << "'. Not a direcotry." << endl;
+      ERR << "Not adding cache: '" << cache_dir << "'. Not a directory." << endl;
     }
   }
 
@@ -135,16 +139,16 @@ namespace zypp
     for ( list<FetcherJob_Ptr>::const_iterator it_res = _resources.begin(); it_res != _resources.end(); ++it_res )
     {
       bool got_from_cache = false;
-      for ( list<Pathname>::const_iterator it_cache = _caches.begin(); it_cache != _caches.end(); ++it_cache )
+      
+      MIL << "start fetcher with " << _caches.size() << " cache directories." << endl;
+      for_ ( it_cache, _caches.begin(), _caches.end() )
       {
         // does the current file exists in the current cache?
         Pathname cached_file = *it_cache + (*it_res)->location.filename();
-       
-       MIL << "Trying cached file: " << cached_file << endl;
-       
+
         if ( PathInfo( cached_file ).isExist() )
         {
-         MIL << "File exist, testing checksum " << (*it_res)->location.checksum() << endl;
+          MIL << "File '" << cached_file << "' exist, testing checksum " << (*it_res)->location.checksum() << endl;
 
           // check the checksum
           if ( is_checksum( cached_file, (*it_res)->location.checksum() ) && (! (*it_res)->location.checksum().empty() ) )
@@ -156,9 +160,9 @@ namespace zypp
 
             // replicate the complete path in the target directory
             Pathname dest_full_path = dest_dir + (*it_res)->location.filename();
-           
-           if( dest_full_path != cached_file )
-           {
+
+            if( dest_full_path != cached_file )
+            {
               if ( assert_dir( dest_full_path.dirname() ) != 0 )
                 ZYPP_THROW( Exception("Can't create " + dest_full_path.dirname().asString()));
 
@@ -169,7 +173,7 @@ namespace zypp
                 // try next cache
                 continue;
               }
-           }
+            }
 
             got_from_cache = true;
             break;
@@ -266,7 +270,7 @@ namespace zypp
   //   METHOD TYPE : Ctor
   //
   Fetcher::Fetcher()
-  : _pimpl( Impl::nullimpl() )
+  : _pimpl( new Impl() )
   {}
 
   ///////////////////////////////////////////////////////////////////
index 78dd5e8dd35f9cde4c86810847d205ebffddece4..4d6d3e282a9c79fb80ed72f7280cfaa9258130b6 100644 (file)
@@ -105,8 +105,9 @@ namespace zypp
     void addCachePath( const Pathname &cache_dir );
     
     /**
-    * Reset the transfer list and cache list
-    */
+     * Reset the transfer (jobs) list
+     * \note It does not reset the cache directory list
+     */
     void reset();
     
     /**
index 186e2acfe95d4c71021e21a2a93da7177645628d..6ea6bd1598ab07ca15cda51a8cae20184afec19c 100644 (file)
@@ -69,7 +69,6 @@ namespace zypp
         bool patches_Callback( const OnMediaLocation &loc, const std::string &id );
        private:
         Pathname _path;
-        Fetcher _fetcher;
         Pathname _dest_dir;
         std::list<OnMediaLocation> _patches_files;