]> git.saurik.com Git - apt.git/commitdiff
* implement SourceVer() in pkgRecords
authorMichael Vogt <michael.vogt@ubuntu.com>
Wed, 23 May 2007 07:34:18 +0000 (09:34 +0200)
committerMichael Vogt <michael.vogt@ubuntu.com>
Wed, 23 May 2007 07:34:18 +0000 (09:34 +0200)
   (thanks to Daniel Burrows for the patch!)

apt-pkg/deb/debrecords.cc
apt-pkg/deb/debrecords.h
apt-pkg/pkgrecords.h
debian/changelog

index c3e579ad1366871636dd38ec114d0c79be8f3538..26ca3679992a52bf592dc810b32ababec2df69cc 100644 (file)
@@ -92,18 +92,44 @@ string debRecordParser::LongDesc()
    return Section.FindS("Description");
 }
                                                                        /*}}}*/
+
+static const char *SourceVerSeparators = " ()";
+
 // RecordParser::SourcePkg - Return the source package name if any     /*{{{*/
 // ---------------------------------------------------------------------
 /* */
 string debRecordParser::SourcePkg()
 {
    string Res = Section.FindS("Source");
-   string::size_type Pos = Res.find(' ');
+   string::size_type Pos = Res.find_first_of(SourceVerSeparators);
    if (Pos == string::npos)
       return Res;
    return string(Res,0,Pos);
 }
                                                                        /*}}}*/
+// RecordParser::SourceVer - Return the source version number if present       /*{{{*/
+// ---------------------------------------------------------------------
+/* */
+string debRecordParser::SourceVer()
+{
+   string Pkg = Section.FindS("Source");
+   string::size_type Pos = Pkg.find_first_of(SourceVerSeparators);
+   if (Pos == string::npos)
+      return "";
+
+   string::size_type VerStart = Pkg.find_first_not_of(SourceVerSeparators, Pos);
+   if(VerStart == string::npos)
+     return "";
+
+   string::size_type VerEnd = Pkg.find_first_of(SourceVerSeparators, VerStart);
+   if(VerEnd == string::npos)
+     // Corresponds to the case of, e.g., "foo (1.2" without a closing
+     // paren.  Be liberal and guess what it means.
+     return string(Pkg, VerStart);
+   else
+     return string(Pkg, VerStart, VerEnd - VerStart);
+}
+                                                                       /*}}}*/
 // RecordParser::GetRec - Return the whole record                      /*{{{*/
 // ---------------------------------------------------------------------
 /* */
index efef2e5882a01df63b5924ec820a64c001db947a..bb72275a577f9a24499d6964733b8f76ab4c7ec7 100644 (file)
@@ -38,6 +38,7 @@ class debRecordParser : public pkgRecords::Parser
    virtual string MD5Hash();
    virtual string SHA1Hash();
    virtual string SourcePkg();
+   virtual string SourceVer();
    
    // These are some general stats about the package
    virtual string Maintainer();
index 08f00441463e428da12e6268c9123a5116742f55..dcfec07ef6c636bf73a84050c8b770bf5eb82d8d 100644 (file)
@@ -58,6 +58,7 @@ class pkgRecords::Parser
    virtual string MD5Hash() {return string();};
    virtual string SHA1Hash() {return string();};
    virtual string SourcePkg() {return string();};
+   virtual string SourceVer() {return string();};
 
    // These are some general stats about the package
    virtual string Maintainer() {return string();};
index 8294c45d9bf08a275311f057530c0cb6518a3b2b..c487bc8dd595325035ee794b59670520a451d6a7 100644 (file)
@@ -1,5 +1,7 @@
 apt (0.6.47) UNRELEASED; urgency=low
 
+  * implement SourceVer() in pkgRecords 
+     (thanks to Daniel Burrows for the patch!)
   * apt-pkg/algorithm.cc:
     - use clog for all debugging
     - only increase the score of installed applications if they