* cmdline/apt-get.cc:
authorMichael Vogt <michael.vogt@ubuntu.com>
Mon, 18 Jun 2007 12:19:13 +0000 (14:19 +0200)
committerMichael Vogt <michael.vogt@ubuntu.com>
Mon, 18 Jun 2007 12:19:13 +0000 (14:19 +0200)
  - merged http://people.ubuntu.com/~mvo/bzr/apt/xs-vcs-bzr/
    this will warn when Vcs- headers are found on apt-get source
    (Fixes LP:#115959)

cmdline/apt-get.cc
debian/changelog

index 554677f..51bcfde 100644 (file)
@@ -2114,6 +2114,28 @@ bool DoSource(CommandLine &CmdL)
       if (Last == 0)
         return _error->Error(_("Unable to find a source package for %s"),Src.c_str());
       
+      string srec = Last->AsStr();
+      string::size_type pos = srec.find("\nVcs-");
+      if (pos != string::npos )
+      {
+        pos += strlen("\nVcs-");
+        string vcs = srec.substr(pos,srec.find(":",pos)-pos);
+        pos += vcs.length()+2;
+        string::size_type epos = srec.find("\n", pos);
+        string uri = srec.substr(pos,epos-pos).c_str();
+        ioprintf(c1out, _("WARNING: '%s' is maintained in "
+                          "the '%s' version control system at:\n"
+                          "'%s'\n"),
+                 Src.c_str(), vcs.c_str(), uri.c_str());
+        if(vcs == "Bzr") 
+           ioprintf(c1out,_("Please use: 'bzr get %s'\n"
+                            "to modify the package.\n"),
+                    uri.c_str());
+        ioprintf(c1out, "Are you sure you want to continue [yN]? ");
+        if(!YnPrompt(false))
+           return _error->Error(_("Abort."));
+      }
+
       // Back track
       vector<pkgSrcRecords::File> Lst;
       if (Last->Files(Lst) == false)
index c86f8ab..0482dff 100644 (file)
@@ -3,6 +3,10 @@ apt (0.7.2ubuntu1) gutsy; urgency=low
   * apt-pkg/deb/dpkgpm.cc:
     - apport integration added, this means that a apport
       report is written on dpkg failures
+  * cmdline/apt-get.cc:
+    - merged http://people.ubuntu.com/~mvo/bzr/apt/xs-vcs-bzr/
+      this will warn when Vcs- headers are found on apt-get source
+      (Fixes LP:#115959)
   * merged from debian/unstable, remaining changes:
     - maintainer field changed