| Index: third_party/dpkg-dev/scripts/Dpkg/Source/Package/V3/Git.pm
|
| diff --git a/third_party/dpkg-dev/scripts/Dpkg/Source/Package/V3/Git.pm b/third_party/dpkg-dev/scripts/Dpkg/Source/Package/V3/Git.pm
|
| deleted file mode 100644
|
| index 21eb667de15de7bb1fa3e5283cef0d43c123c46b..0000000000000000000000000000000000000000
|
| --- a/third_party/dpkg-dev/scripts/Dpkg/Source/Package/V3/Git.pm
|
| +++ /dev/null
|
| @@ -1,235 +0,0 @@
|
| -#
|
| -# git support for dpkg-source
|
| -#
|
| -# Copyright © 2007,2010 Joey Hess <joeyh@debian.org>.
|
| -# Copyright © 2008 Frank Lichtenheld <djpig@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 <https://www.gnu.org/licenses/>.
|
| -
|
| -package Dpkg::Source::Package::V3::Git;
|
| -
|
| -use strict;
|
| -use warnings;
|
| -
|
| -our $VERSION = '0.02';
|
| -
|
| -use parent qw(Dpkg::Source::Package);
|
| -
|
| -use Cwd qw(abs_path getcwd);
|
| -use File::Basename;
|
| -use File::Temp qw(tempdir);
|
| -
|
| -use Dpkg;
|
| -use Dpkg::Gettext;
|
| -use Dpkg::ErrorHandling;
|
| -use Dpkg::Exit qw(push_exit_handler pop_exit_handler);
|
| -use Dpkg::Source::Functions qw(erasedir);
|
| -
|
| -our $CURRENT_MINOR_VERSION = '0';
|
| -
|
| -# Remove variables from the environment that might cause git to do
|
| -# something unexpected.
|
| -delete $ENV{GIT_DIR};
|
| -delete $ENV{GIT_INDEX_FILE};
|
| -delete $ENV{GIT_OBJECT_DIRECTORY};
|
| -delete $ENV{GIT_ALTERNATE_OBJECT_DIRECTORIES};
|
| -delete $ENV{GIT_WORK_TREE};
|
| -
|
| -sub import {
|
| - foreach my $dir (split(/:/, $ENV{PATH})) {
|
| - if (-x "$dir/git") {
|
| - return 1;
|
| - }
|
| - }
|
| - error(_g('cannot unpack git-format source package because ' .
|
| - 'git is not in the PATH'));
|
| -}
|
| -
|
| -sub sanity_check {
|
| - my $srcdir = shift;
|
| -
|
| - if (! -d "$srcdir/.git") {
|
| - error(_g('source directory is not the top directory of a git ' .
|
| - 'repository (%s/.git not present), but Format git was ' .
|
| - 'specified'), $srcdir);
|
| - }
|
| - if (-s "$srcdir/.gitmodules") {
|
| - error(_g('git repository %s uses submodules; this is not yet supported'),
|
| - $srcdir);
|
| - }
|
| -
|
| - return 1;
|
| -}
|
| -
|
| -sub parse_cmdline_option {
|
| - my ($self, $opt) = @_;
|
| - return 1 if $self->SUPER::parse_cmdline_option($opt);
|
| - if ($opt =~ /^--git-ref=(.*)$/) {
|
| - push @{$self->{options}{git_ref}}, $1;
|
| - return 1;
|
| - } elsif ($opt =~ /^--git-depth=(\d+)$/) {
|
| - $self->{options}{git_depth} = $1;
|
| - return 1;
|
| - }
|
| - return 0;
|
| -}
|
| -
|
| -sub can_build {
|
| - my ($self, $dir) = @_;
|
| -
|
| - return (0, _g("doesn't contain a git repository")) unless -d "$dir/.git";
|
| - return 1;
|
| -}
|
| -
|
| -sub do_build {
|
| - my ($self, $dir) = @_;
|
| - my $diff_ignore_regex = $self->{options}{diff_ignore_regex};
|
| -
|
| - $dir =~ s{/+$}{}; # Strip trailing /
|
| - my ($dirname, $updir) = fileparse($dir);
|
| - my $basenamerev = $self->get_basename(1);
|
| -
|
| - sanity_check($dir);
|
| -
|
| - my $old_cwd = getcwd();
|
| - chdir($dir) or syserr(_g("unable to chdir to `%s'"), $dir);
|
| -
|
| - # Check for uncommitted files.
|
| - # To support dpkg-source -i, get a list of files
|
| - # equivalent to the ones git status finds, and remove any
|
| - # ignored files from it.
|
| - my @ignores = '--exclude-per-directory=.gitignore';
|
| - my $core_excludesfile = `git config --get core.excludesfile`;
|
| - chomp $core_excludesfile;
|
| - if (length $core_excludesfile && -e $core_excludesfile) {
|
| - push @ignores, "--exclude-from=$core_excludesfile";
|
| - }
|
| - if (-e '.git/info/exclude') {
|
| - push @ignores, '--exclude-from=.git/info/exclude';
|
| - }
|
| - open(my $git_ls_files_fh, '-|', 'git', 'ls-files', '--modified', '--deleted',
|
| - '-z', '--others', @ignores) or subprocerr('git ls-files');
|
| - my @files;
|
| - { local $/ = "\0";
|
| - while (<$git_ls_files_fh>) {
|
| - chomp;
|
| - if (! length $diff_ignore_regex ||
|
| - ! m/$diff_ignore_regex/o) {
|
| - push @files, $_;
|
| - }
|
| - }
|
| - }
|
| - close($git_ls_files_fh) or syserr(_g('git ls-files exited nonzero'));
|
| - if (@files) {
|
| - error(_g('uncommitted, not-ignored changes in working directory: %s'),
|
| - join(' ', @files));
|
| - }
|
| -
|
| - # If a depth was specified, need to create a shallow clone and
|
| - # bundle that.
|
| - my $tmp;
|
| - my $shallowfile;
|
| - if ($self->{options}{git_depth}) {
|
| - chdir($old_cwd) or syserr(_g("unable to chdir to `%s'"), $old_cwd);
|
| - $tmp = tempdir("$dirname.git.XXXXXX", DIR => $updir);
|
| - push_exit_handler(sub { erasedir($tmp) });
|
| - my $clone_dir = "$tmp/repo.git";
|
| - # file:// is needed to avoid local cloning, which does not
|
| - # create a shallow clone.
|
| - info(_g('creating shallow clone with depth %s'),
|
| - $self->{options}{git_depth});
|
| - system('git', 'clone', '--depth=' . $self->{options}{git_depth},
|
| - '--quiet', '--bare', 'file://' . abs_path($dir), $clone_dir);
|
| - subprocerr('git clone') if $?;
|
| - chdir($clone_dir)
|
| - or syserr(_g("unable to chdir to `%s'"), $clone_dir);
|
| - $shallowfile = "$basenamerev.gitshallow";
|
| - system('cp', '-f', 'shallow', "$old_cwd/$shallowfile");
|
| - subprocerr('cp shallow') if $?;
|
| - }
|
| -
|
| - # Create the git bundle.
|
| - my $bundlefile = "$basenamerev.git";
|
| - my @bundle_arg=$self->{options}{git_ref} ?
|
| - (@{$self->{options}{git_ref}}) : '--all';
|
| - info(_g('bundling: %s'), join(' ', @bundle_arg));
|
| - system('git', 'bundle', 'create', "$old_cwd/$bundlefile",
|
| - @bundle_arg,
|
| - 'HEAD', # ensure HEAD is included no matter what
|
| - '--', # avoids ambiguity error when referring to eg, a debian branch
|
| - );
|
| - subprocerr('git bundle') if $?;
|
| -
|
| - chdir($old_cwd) or syserr(_g("unable to chdir to `%s'"), $old_cwd);
|
| -
|
| - if (defined $tmp) {
|
| - erasedir($tmp);
|
| - pop_exit_handler();
|
| - }
|
| -
|
| - $self->add_file($bundlefile);
|
| - if (defined $shallowfile) {
|
| - $self->add_file($shallowfile);
|
| - }
|
| -}
|
| -
|
| -sub do_extract {
|
| - my ($self, $newdirectory) = @_;
|
| - my $fields = $self->{fields};
|
| -
|
| - my $dscdir = $self->{basedir};
|
| - my $basenamerev = $self->get_basename(1);
|
| -
|
| - my @files = $self->get_files();
|
| - my ($bundle, $shallow);
|
| - foreach my $file (@files) {
|
| - if ($file =~ /^\Q$basenamerev\E\.git$/) {
|
| - if (! defined $bundle) {
|
| - $bundle = $file;
|
| - } else {
|
| - error(_g('format v3.0 (git) uses only one .git file'));
|
| - }
|
| - } elsif ($file =~ /^\Q$basenamerev\E\.gitshallow$/) {
|
| - if (! defined $shallow) {
|
| - $shallow = $file;
|
| - } else {
|
| - error(_g('format v3.0 (git) uses only one .gitshallow file'));
|
| - }
|
| - } else {
|
| - error(_g('format v3.0 (git) unknown file: %s', $file));
|
| - }
|
| - }
|
| - if (! defined $bundle) {
|
| - error(_g('format v3.0 (git) expected %s'), "$basenamerev.git");
|
| - }
|
| -
|
| - erasedir($newdirectory);
|
| -
|
| - # Extract git bundle.
|
| - info(_g('cloning %s'), $bundle);
|
| - system('git', 'clone', '--quiet', $dscdir . $bundle, $newdirectory);
|
| - subprocerr('git bundle') if $?;
|
| -
|
| - if (defined $shallow) {
|
| - # Move shallow info file into place, so git does not
|
| - # try to follow parents of shallow refs.
|
| - info(_g('setting up shallow clone'));
|
| - system('cp', '-f', $dscdir . $shallow, "$newdirectory/.git/shallow");
|
| - subprocerr('cp') if $?;
|
| - }
|
| -
|
| - sanity_check($newdirectory);
|
| -}
|
| -
|
| -1;
|
|
|