Index: third_party/dpkg-dev/scripts/Dpkg/Path.pm |
diff --git a/third_party/dpkg-dev/scripts/Dpkg/Path.pm b/third_party/dpkg-dev/scripts/Dpkg/Path.pm |
deleted file mode 100644 |
index 969b1d6cc288741ff4748e642ab6bf4d943d7990..0000000000000000000000000000000000000000 |
--- a/third_party/dpkg-dev/scripts/Dpkg/Path.pm |
+++ /dev/null |
@@ -1,295 +0,0 @@ |
-# Copyright © 2007-2011 Raphaël Hertzog <hertzog@debian.org> |
-# Copyright © 2011 Linaro Limited |
-# |
-# 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::Path; |
- |
-use strict; |
-use warnings; |
- |
-our $VERSION = '1.02'; |
- |
-use Exporter qw(import); |
-use File::Spec; |
-use Cwd qw(realpath); |
- |
-use Dpkg::Arch qw(get_host_arch debarch_to_debtriplet); |
-use Dpkg::IPC; |
- |
-our @EXPORT_OK = qw(get_pkg_root_dir relative_to_pkg_root |
- guess_pkg_root_dir check_files_are_the_same |
- resolve_symlink canonpath find_command |
- get_control_path find_build_file); |
- |
-=encoding utf8 |
- |
-=head1 NAME |
- |
-Dpkg::Path - some common path handling functions |
- |
-=head1 DESCRIPTION |
- |
-It provides some functions to handle various path. |
- |
-=head1 METHODS |
- |
-=over 8 |
- |
-=item get_pkg_root_dir($file) |
- |
-This function will scan upwards the hierarchy of directory to find out |
-the directory which contains the "DEBIAN" sub-directory and it will return |
-its path. This directory is the root directory of a package being built. |
- |
-If no DEBIAN subdirectory is found, it will return undef. |
- |
-=cut |
- |
-sub get_pkg_root_dir($) { |
- my $file = shift; |
- $file =~ s{/+$}{}; |
- $file =~ s{/+[^/]+$}{} if not -d $file; |
- while ($file) { |
- return $file if -d "$file/DEBIAN"; |
- last if $file !~ m{/}; |
- $file =~ s{/+[^/]+$}{}; |
- } |
- return; |
-} |
- |
-=item relative_to_pkg_root($file) |
- |
-Returns the filename relative to get_pkg_root_dir($file). |
- |
-=cut |
- |
-sub relative_to_pkg_root($) { |
- my $file = shift; |
- my $pkg_root = get_pkg_root_dir($file); |
- if (defined $pkg_root) { |
- $pkg_root .= '/'; |
- return $file if ($file =~ s/^\Q$pkg_root\E//); |
- } |
- return; |
-} |
- |
-=item guess_pkg_root_dir($file) |
- |
-This function tries to guess the root directory of the package build tree. |
-It will first use get_pkg_root_dir(), but it will fallback to a more |
-imprecise check: namely it will use the parent directory that is a |
-sub-directory of the debian directory. |
- |
-It can still return undef if a file outside of the debian sub-directory is |
-provided. |
- |
-=cut |
- |
-sub guess_pkg_root_dir($) { |
- my $file = shift; |
- my $root = get_pkg_root_dir($file); |
- return $root if defined $root; |
- |
- $file =~ s{/+$}{}; |
- $file =~ s{/+[^/]+$}{} if not -d $file; |
- my $parent = $file; |
- while ($file) { |
- $parent =~ s{/+[^/]+$}{}; |
- last if not -d $parent; |
- return $file if check_files_are_the_same('debian', $parent); |
- $file = $parent; |
- last if $file !~ m{/}; |
- } |
- return; |
-} |
- |
-=item check_files_are_the_same($file1, $file2, $resolve_symlink) |
- |
-This function verifies that both files are the same by checking that the device |
-numbers and the inode numbers returned by stat()/lstat() are the same. If |
-$resolve_symlink is true then stat() is used, otherwise lstat() is used. |
- |
-=cut |
- |
-sub check_files_are_the_same($$;$) { |
- my ($file1, $file2, $resolve_symlink) = @_; |
- return 0 if ((! -e $file1) || (! -e $file2)); |
- my (@stat1, @stat2); |
- if ($resolve_symlink) { |
- @stat1 = stat($file1); |
- @stat2 = stat($file2); |
- } else { |
- @stat1 = lstat($file1); |
- @stat2 = lstat($file2); |
- } |
- my $result = ($stat1[0] == $stat2[0]) && ($stat1[1] == $stat2[1]); |
- return $result; |
-} |
- |
- |
-=item canonpath($file) |
- |
-This function returns a cleaned path. It simplifies double //, and remove |
-/./ and /../ intelligently. For /../ it simplifies the path only if the |
-previous element is not a symlink. Thus it should only be used on real |
-filenames. |
- |
-=cut |
- |
-sub canonpath($) { |
- my $path = shift; |
- $path = File::Spec->canonpath($path); |
- my ($v, $dirs, $file) = File::Spec->splitpath($path); |
- my @dirs = File::Spec->splitdir($dirs); |
- my @new; |
- foreach my $d (@dirs) { |
- if ($d eq '..') { |
- if (scalar(@new) > 0 and $new[-1] ne '..') { |
- next if $new[-1] eq ''; # Root directory has no parent |
- my $parent = File::Spec->catpath($v, |
- File::Spec->catdir(@new), ''); |
- if (not -l $parent) { |
- pop @new; |
- } else { |
- push @new, $d; |
- } |
- } else { |
- push @new, $d; |
- } |
- } else { |
- push @new, $d; |
- } |
- } |
- return File::Spec->catpath($v, File::Spec->catdir(@new), $file); |
-} |
- |
-=item $newpath = resolve_symlink($symlink) |
- |
-Return the filename of the file pointed by the symlink. The new name is |
-canonicalized by canonpath(). |
- |
-=cut |
- |
-sub resolve_symlink($) { |
- my $symlink = shift; |
- my $content = readlink($symlink); |
- return unless defined $content; |
- if (File::Spec->file_name_is_absolute($content)) { |
- return canonpath($content); |
- } else { |
- my ($link_v, $link_d, $link_f) = File::Spec->splitpath($symlink); |
- my ($cont_v, $cont_d, $cont_f) = File::Spec->splitpath($content); |
- my $new = File::Spec->catpath($link_v, $link_d . '/' . $cont_d, $cont_f); |
- return canonpath($new); |
- } |
-} |
- |
- |
-=item my $cmdpath = find_command($command) |
- |
-Return the path of the command if available on an absolute or relative |
-path or on the $PATH, undef otherwise. |
- |
-=cut |
- |
-sub find_command($) { |
- my $cmd = shift; |
- |
- if ($cmd =~ m{/}) { |
- return "$cmd" if -x "$cmd"; |
- } else { |
- foreach my $dir (split(/:/, $ENV{PATH})) { |
- return "$dir/$cmd" if -x "$dir/$cmd"; |
- } |
- } |
- return; |
-} |
- |
-=item my $control_file = get_control_path($pkg, $filetype) |
- |
-Return the path of the control file of type $filetype for the given |
-package. |
- |
-=item my @control_files = get_control_path($pkg) |
- |
-Return the path of all available control files for the given package. |
- |
-=cut |
- |
-sub get_control_path($;$) { |
- my ($pkg, $filetype) = @_; |
- my $control_file; |
- my @exec = ('dpkg-query', '--control-path', $pkg); |
- push @exec, $filetype if defined $filetype; |
- spawn(exec => \@exec, wait_child => 1, to_string => \$control_file); |
- chomp($control_file); |
- if (defined $filetype) { |
- return if $control_file eq ''; |
- return $control_file; |
- } |
- return () if $control_file eq ''; |
- return split(/\n/, $control_file); |
-} |
- |
-=item my $file = find_build_file($basename) |
- |
-Selects the right variant of the given file: the arch-specific variant |
-("$basename.$arch") has priority over the OS-specific variant |
-("$basename.$os") which has priority over the default variant |
-("$basename"). If none of the files exists, then it returns undef. |
- |
-=item my @files = find_build_file($basename) |
- |
-Return the available variants of the given file. Returns an empty |
-list if none of the files exists. |
- |
-=cut |
- |
-sub find_build_file($) { |
- my $base = shift; |
- my $host_arch = get_host_arch(); |
- my ($abi, $host_os, $cpu) = debarch_to_debtriplet($host_arch); |
- my @files; |
- foreach my $f ("$base.$host_arch", "$base.$host_os", "$base") { |
- push @files, $f if -f $f; |
- } |
- return @files if wantarray; |
- return $files[0] if scalar @files; |
- return; |
-} |
- |
-=back |
- |
-=head1 CHANGES |
- |
-=head2 Version 1.03 |
- |
-New function: find_build_file() |
- |
-=head2 Version 1.02 |
- |
-New function: get_control_path() |
- |
-=head2 Version 1.01 |
- |
-New function: find_command() |
- |
-=head1 AUTHOR |
- |
-Raphaël Hertzog <hertzog@debian.org>. |
- |
-=cut |
- |
-1; |