]> git.saurik.com Git - apt.git/commitdiff
* cmdline/apt-get.cc
authorMichael Vogt <michael.vogt@ubuntu.com>
Mon, 9 Mar 2009 15:33:39 +0000 (16:33 +0100)
committerMichael Vogt <michael.vogt@ubuntu.com>
Mon, 9 Mar 2009 15:33:39 +0000 (16:33 +0100)
  - fix "apt-get source pkg" if there is a binary package and
    a source package of the same name but from different
    packages (LP: #330103)

cmdline/apt-get.cc
debian/changelog

index 2117a7f2ab75fb42a3e5f7ca4d3a178c64f22ee1..0339afdf1ffabc07503c63584cb20b48be70e2cb 100644 (file)
@@ -1272,16 +1272,23 @@ pkgSrcRecords::Parser *FindSrc(const char *Name,pkgRecords &Recs,
         }
       }   
    }
-   
-   // No source package name..
-   if (Src.empty() == true)
-      Src = TmpSrc;
-   
+
    // The best hit
    pkgSrcRecords::Parser *Last = 0;
    unsigned long Offset = 0;
    string Version;
    bool IsMatch = false;
+   bool MatchSrcOnly = false;
+
+   // No source package name..
+   if (Src.empty() == true)
+      Src = TmpSrc;
+   else 
+      // if we have a source pkg name, make sure to only search
+      // for srcpkg names, otherwise apt gets confused if there
+      // is a binary package "pkg1" and a source package "pkg1"
+      // with the same name but that comes from different packages
+      MatchSrcOnly = true;
    
    // If we are matching by version then we need exact matches to be happy
    if (VerTag.empty() == false)
@@ -1291,13 +1298,13 @@ pkgSrcRecords::Parser *FindSrc(const char *Name,pkgRecords &Recs,
       binary packages in the search */
    pkgSrcRecords::Parser *Parse;
    SrcRecs.Restart();
-   while ((Parse = SrcRecs.Find(Src.c_str(),false)) != 0)
+   while ((Parse = SrcRecs.Find(Src.c_str(), MatchSrcOnly)) != 0)
    {
       string Ver = Parse->Version();
       
       // show name mismatches
       if (IsMatch == true && Parse->Package() != Src) 
-        ioprintf(c1out,  _("No source package '%s' picking '%s' instead"), Parse->Package().c_str(), Src.c_str());
+        ioprintf(c1out,  _("No source package '%s' picking '%s' instead\n"), Parse->Package().c_str(), Src.c_str());
       
       if (VerTag.empty() == false)
       {
index b485c36aa2c22ad563f0997dde2654d5f68f24ba..bef5c3cad5e85bdd08137d810a874f615b123f96 100644 (file)
@@ -1,9 +1,13 @@
-apt (0.7.20.2ubuntu2) UNRELEASED; urgency=low
+apt (0.7.20.2ubuntu2) jaunty; urgency=low
 
   * apt-pkg/deb/dpkgpm.cc:
     - revert termios patch (LP: #338514)
+  * cmdline/apt-get.cc
+    - fix "apt-get source pkg" if there is a binary package and
+      a source package of the same name but from different 
+      packages (LP: #330103)
 
- -- Michael Vogt <michael.vogt@ubuntu.com>  Fri, 06 Mar 2009 10:15:15 +0100
+ -- Michael Vogt <michael.vogt@ubuntu.com>  Mon, 09 Mar 2009 16:33:28 +0100
 
 apt (0.7.20.2ubuntu1) jaunty; urgency=low