[SCM] Git repository for devscripts branch, master, updated. v2.12.2-50-g2afe289
James McCoy
jamessan at debian.org
Sat Sep 15 19:42:37 UTC 2012
The following commit has been merged in the master branch:
commit d7a9b3cfa4dbec53f27e9285c83310dc45d37bc9
Author: James McCoy <jamessan at debian.org>
Date: Sat Sep 15 14:45:36 2012 -0400
Revert origtargz related commits.
Signed-off-by: James McCoy <jamessan at debian.org>
diff --git a/.gitignore b/.gitignore
index 167cfb4..03ca629 100644
--- a/.gitignore
+++ b/.gitignore
@@ -79,8 +79,6 @@ scripts/mk-build-deps.1
scripts/namecheck
scripts/namecheck.1
scripts/nmudiff
-scripts/origtargz
-scripts/origtargz.1
scripts/plotchangelog
scripts/pts-subscribe
scripts/rc-alert
diff --git a/Makefile.common b/Makefile.common
index 3f04732..3ffa4b4 100644
--- a/Makefile.common
+++ b/Makefile.common
@@ -1,7 +1,7 @@
GEN_MAN1S := bts.1 build-rdeps.1 chdist.1 dcontrol.1 debcheckout.1 debcommit.1 \
deb-reversion.1 desktop2menu.1 dget.1 licensecheck.1 mass-bug.1 \
mk-build-deps.1 namecheck.1 rmadison.1 svnpath.1 tagpending.1 \
- origtargz.1 transition-check.1
+ transition-check.1
PERLMOD_DIR = /usr/share/devscripts
EXAMPLES_DIR = /usr/share/devscripts
diff --git a/README b/README
index 43d8836..39ea41d 100644
--- a/README
+++ b/README
@@ -191,9 +191,6 @@ And now, in mostly alphabetical order, the scripts:
previously released version (as per the changelog) and submit the diff
to the BTS. [patchutils, mutt]
-- origtargz: fetch the orig tarball of a Debian package from various sources,
- and unpack it
-
- plotchangelog: display information from a changelog graphically using
gnuplot. [libtimedate-perl, gnuplot]
diff --git a/debian/changelog b/debian/changelog
index e9773b0..b3b471c 100644
--- a/debian/changelog
+++ b/debian/changelog
@@ -29,8 +29,6 @@ devscripts (2.12.3) UNRELEASED; urgency=low
* debcheckout: When --package is given, use this package name rather than
trying to guess it from the url. Useful for URLs like
http://anonscm.debian.org/bzr/pkg-postgresql/postgresql-9.2/sid-pgapt/.
- * origtargz: New script: fetch the orig tarball of a Debian package from
- various sources, and unpack it
* po4a/Makefile: use po4a --keep=0 so the build system doesn't die with
untranslated scripts
* dcmd: Reimplement endswith() with case. The original missed quoting and
diff --git a/debian/control b/debian/control
index 1e53809..0c555a3 100644
--- a/debian/control
+++ b/debian/control
@@ -171,8 +171,6 @@ Description: scripts to make the life of a Debian Package maintainer easier
- namecheck: Check project names are not already taken.
- nmudiff: mail a diff of the current package against the previous version
to the BTS to assist in tracking NMUs [patchutils, mutt]
- - origtargz: fetch the orig tarball of a Debian package from various sources,
- and unpack it
- plotchangelog: view a nice plot of the data in a changelog file
[libtimedate-perl, gnuplot]
- pts-subscribe: subscribe to the PTS for a limited period of time
diff --git a/po4a/devscripts-po4a.conf b/po4a/devscripts-po4a.conf
index acac392..c3e13d9 100644
--- a/po4a/devscripts-po4a.conf
+++ b/po4a/devscripts-po4a.conf
@@ -100,8 +100,6 @@
fr:fr/namecheck.fr.pl add_fr:add_fr/translator_pod.add
[type:man] ../scripts/nmudiff.1 \
fr:fr/nmudiff.fr.1 add_fr:add_fr/translator_man.add
-[type:pod] ../scripts/origtargz.pl \
- fr:fr/origtargz.fr.pl add_fr:add_fr/translator_pod.add
[type:man] ../scripts/plotchangelog.1 \
fr:fr/plotchangelog.fr.1 add_fr:add_fr/translator_man.add
[type:man] ../scripts/pts-subscribe.1 \
diff --git a/scripts/origtargz.pl b/scripts/origtargz.pl
deleted file mode 100755
index bdfab5d..0000000
--- a/scripts/origtargz.pl
+++ /dev/null
@@ -1,348 +0,0 @@
-#!/usr/bin/perl
-#
-# origtargz: fetch the orig tarball of a Debian package from various sources,
-# and unpack it
-# Copyright (C) 2012 Christoph Berg <myon at debian.org>
-#
-# This program is free software: you can redistribute it and/or modify
-# it under the terms of the GNU General Public License as published by
-# the Free Software Foundation, either version 2 of the License, or
-# (at your option) any later version.
-#
-# This program is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-# GNU General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with this program. If not, see <http://www.gnu.org/licenses/>.
-
-=head1 NAME
-
-origtargz - fetch the orig tarball of a Debian package from various sources, and unpack it
-
-=head1 SYNOPSIS
-
-=over
-
-=item B<origtargz> [I<OPTIONS>] [B<--unpack>[=B<no>|B<once>|B<yes>]]
-
-=item B<origtargz> B<--help>
-
-=back
-
-=head1 DESCRIPTION
-
-B<origtargz> downloads the orig tarball of a Debian package, and optionally
-unpacks it into the current directory. The version number to be used is
-determined from F<debian/changelog>. The main use for B<origtargz> is with
-debian-dir-only repository checkouts. It should be invoked from the top level
-directory of an unpacked Debian source package.
-
-Various download locations are tried:
-
-=over 4
-
-=item * First, an existing file is looked for.
-
-=item * Directories given with B<--path> are searched.
-
-=item * B<apt-get source> is tried when B<apt-cache showsrc> reports a matching version.
-
-=item * Finally, B<uscan --download-current-version> is tried.
-
-=back
-
-When asked to unpack the orig tarball, B<origtargz> will remove all files and
-directories from the current directory, except the debian directory, and the
-VCS repository directories. Some files outside F<debian/> which are often stored
-in VCS even for debian-dir-only repositories are also preserved (F<.bzr-builddeb>,
-F<.gitignore>, F<.hgignore>). I<Note that this will drop all non-committed changes>
-for the patch system in use (e.g. source format "3.0 (quilt)"), and will even
-remove all patches from the package when no patch system is in use (the
-original "1.0" source format).
-
-The default behavior is to unpack the orig tarball on the first invocation of
-B<origtargz> in a debian-dir-only checkout.
-
-=head1 NOTES
-
-Despite B<origtargz> being called "targz", it will work with any compression
-scheme used for the tarball.
-
-A similar tool to unpack orig tarballs is B<uupdate>(1). B<uupdate> creates a
-new working directory, unpacks the tarball, and applies the Debian F<.diff.gz>
-changes. In contrast, B<origtargz> uses the current directory, keeping VCS
-metadata.
-
-For Debian package repositories that keep the full upstream source, other tools
-should be used to upgrade the repository from the new tarball. See
-B<git-import-orig>(1) and B<svn-upgrade>(1) for examples. B<origtargz> is still
-useful for downloading the current tarball.
-
-=head1 OPTIONS
-
-=over
-
-=item B<-p>, B<--path> I<directory>
-
-Add I<directory> to the list of locations to search for an existing tarball.
-When found, a hardlink is created if possible, otherwise a symlink.
-
-=item B<-u>, B<--unpack>[=B<no>|B<once>|B<yes>]
-
-Unpack the downloaded orig tarball to the current directory, replacing
-everything except the debian directory. Valid choices are:
-
-=over
-
-=item B<no>
-
-Do not unpack the orig tarball.
-
-=item B<once> (default when B<--unpack> is not used)
-
-If the current directory contains only a F<debian> directory (and possibly some
-dotfiles), unpack the orig tarball. This is the default behavior.
-
-=item B<yes> (default for B<--unpack> without argument)
-
-Always unpack the orig tarball. Existing files are removed, except for F<debian/>
-and VCS files. Preserved are: F<.bzr>, F<.bzrignore>, F<.bzr-builddeb>, F<.git>,
-F<.gitignore>, F<.hg>, F<.hgignore>, and F<.svn>.
-
-=back
-
-=item B<-d>, B<--download-only>
-
-Alias for B<--unpack=no>.
-
-=item B<-t>, B<--tar-only>
-
-When using B<apt-get source>, pass B<--tar-only> to it. The default is to
-download the full source package including F<.dsc> and F<.diff.gz> or
-F<.debian.tar.gz> components so B<debdiff> can be used to diff the last upload
-to the next one. With B<--tar-only>, only download the F<.orig.tar.*> file.
-
-=back
-
-=cut
-
-#=head1 CONFIGURATION VARIABLES
-#
-#The two configuration files F</etc/devscripts.conf> and
-#F<~/.devscripts> are sourced by a shell in that order to set
-#configuration variables. Command line options can be used to override
-#configuration file settings. Environment variable settings are ignored
-#for this purpose. The currently recognised variables are:
-
-=head1 SEE ALSO
-
-B<debcheckout>(1), B<git-import-orig>(1), B<svn-upgrade>(1), B<uupdate>(1)
-
-=head1 AUTHOR
-
-B<origtargz> and this manpage have been written by Christoph Berg
-<I<myon at debian.org>>.
-
-=cut
-
-# option parsing
-
-use strict;
-use warnings;
-use File::Temp qw/tempdir/;
-use Getopt::Long qw(:config gnu_getopt);
-use Pod::Usage;
-
-my @dirs = ();
-my $tar_only = 0;
-my $unpack = 'once'; # default when --unpack is not used
-
-GetOptions(
- "path|p=s" => \@dirs,
- "download-only|d" => sub { $unpack = 'no' },
- "help|h" => sub { pod2usage({-exitval => 0, -verbose => 1}); },
- "tar-only|t" => \$tar_only,
- "unpack|u:s" => \$unpack,
-) or pod2usage({-exitval => 3});
-
-$unpack = 'yes' if (defined $unpack and $unpack eq ''); # default for --unpack without argument
-pod2usage({-exitval => 3}) if (@ARGV > 0 or $unpack !~ /^(no|once|yes)$/);
-
-# get package name and version number
-
-my ($package, $version, $origversion, $fileversion);
-
-open F, "debian/changelog" or die "debian/changelog: $!\n";
-my $line = <F>;
-close F;
-unless ($line =~ /^(\S+) \((\S+)\)/) {
- die "could not parse debian/changelog:1: $line";
-}
-($package, $version) = ($1, $2);
-unless ($version =~ /-/) {
- print "Package with native version number $version, skipping orig.tar.* download\n";
- exit 0;
-}
-$origversion = $version;
-$origversion =~ s/(.*)-.*/$1/; # strip everything from the last dash
-$fileversion = $origversion;
-$fileversion =~ s/^\d+://; # strip epoch
-
-sub download_origtar ()
-{
- # look for an existing file
-
- if (my @f = glob "../${package}_$fileversion.orig.tar.*") {
- print "Using existing $f[0]\n";
- return $f[0];
- }
-
- # try other directories
-
- foreach my $dir (@dirs) {
- $dir =~ s!/$!!;
-
- if (my @f = glob "$dir/${package}_$fileversion.orig.tar.*") {
- print "Using $f[0]\n";
- my $basename = $f[0];
- $basename =~ s!.*/!!;
- link $f[0], "../$basename" or
- symlink $f[0], "../$basename" or
- die "symlink: $!";
- return $f[0];
- }
- }
-
- # TODO: try pristine-tar
-
- # try apt-get source
-
- open S, "apt-cache showsrc '$package' |";
- my @showsrc;
- {
- local $/;
- @showsrc = <S>;
- }
- close S;
-
- my $bestsrcversion;
- foreach my $src (@showsrc) {
- $src =~ /^Package: (.*)/m or next;
- next if ($1 ne $package); ; # should never trigger, but who knows
- $src =~ /^Version: (.*)/m or next;
- my $srcversion = $1;
- my $srcorigversion = $srcversion;
- $srcorigversion =~ s/(.*)-.*/$1/; # strip everything from the last dash
-
- if ($srcorigversion eq $origversion) { # loop through all matching versions
- $bestsrcversion = $srcversion;
- last if ($srcversion eq $version); # break if exact match
- }
- }
-
- if ($bestsrcversion) {
- print "Trying apt-get source $package=$bestsrcversion ...\n";
- my $t = $tar_only ? '--tar-only' : '';
- system "cd .. && apt-get source --only-source --download-only $t '$package=$bestsrcversion'";
- }
-
- if (my @f = glob "../${package}_$fileversion.orig.tar.*") {
- return $f[0];
- }
-
- # try uscan
-
- if (-f "debian/watch") {
- print "Trying uscan --download-current-version ...\n";
- system "uscan --download-current-version\n";
- }
-
- if (my @f = glob "../${package}_$fileversion.orig.tar.*") {
- return $f[0];
- }
-
- print "Could not find any location for ${package}_$fileversion.orig.tar.*\n";
- return undef;
-}
-
-sub clean_checkout ()
-{
- # delete all files except debian/, our VCS checkout, and some files
- # often in VCS outside debian/ even in debian-dir-only repositories
- opendir DIR, '.' or die "opendir: $!";
- my @rm;
- while (my $file = readdir DIR) {
- next if ($file eq '.' or $file eq '..');
- next if ($file eq 'debian');
- next if ($file =~ /^(\.bzr|\.git|\.hg|\.svn|CVS)$/);
- if ($file =~ /^(\.bzr(ignore|-builddeb)|\.gitignore|\.hgignore)$/) {
- print "Notice: not deleting $file (likely to come from VCS checkout)\n";
- next;
- }
- push @rm, $file;
- }
- close DIR;
- system ('rm', '-rf', @rm);
-}
-
-sub unpack_tarball ($)
-{
- my $origtar = shift;
- my $tmpdir = File::Temp->newdir(DIR => ".", CLEANUP => 1);
-
- print "Unpacking $origtar\n";
-
- # unpack
- chdir $tmpdir or die "chdir $tmpdir: $!";
- system ('tar', 'xf', "../$origtar");
- if ($? >> 8) {
- print STDERR "tar xf $origtar failed\n";
- return 0;
- }
- chdir '..';
-
- # figure out which directory was created
- my @dirs = glob "$tmpdir/*/";
- unless (@dirs) {
- print STDERR "tar xf $origtar did not create any directory\n";
- return 0;
- }
- my $directory = $dirs[0];
- chop $directory;
-
- # move all files over, except the debian directory
- opendir DIR, $directory or die "opendir $directory: $!";
- foreach my $file (readdir DIR) {
- if ($file eq 'debian') {
- system ('rm', '-rf', "$directory/$file");
- next;
- } elsif ($file eq '.' or $file eq '..') {
- next;
- }
- unless (rename "$directory/$file", "$file") {
- print STDERR "rename $directory/$file $file: $!\n";
- return 0;
- }
- }
- closedir DIR;
- rmdir $directory;
-
- return 1;
-}
-
-my $origtar = download_origtar;
-exit 1 unless ($origtar);
-
-if ($unpack eq 'once') {
- my @files = glob '*'; # ignores dotfiles
- if (@files == 1) { # this is debian/, we have already opened debian/changelog
- unpack_tarball ($origtar) or exit 1;
- }
-} elsif ($unpack eq 'yes') {
- clean_checkout;
- unpack_tarball ($origtar) or exit 1;
-}
-
-exit 0;
--
Git repository for devscripts
More information about the devscripts-devel
mailing list