mirror of
https://gitlab.archlinux.org/archlinux/devtools.git
synced 2025-10-24 13:32:03 +02:00
Compare commits
5 Commits
v1.1.0
...
github/for
Author | SHA1 | Date | |
---|---|---|---|
![]() |
0cdabbe051 | ||
![]() |
1feaad345d | ||
![]() |
a6d8115908 | ||
![]() |
f90b5a523e | ||
![]() |
3765ea90a6 |
2
.gitignore
vendored
2
.gitignore
vendored
@@ -6,6 +6,8 @@ archrelease
|
||||
bash_completion
|
||||
checkpkg
|
||||
commitpkg
|
||||
devtools-config
|
||||
diffpkg
|
||||
finddeps
|
||||
lddd
|
||||
makechrootpkg
|
||||
|
4
Makefile
4
Makefile
@@ -12,6 +12,8 @@ IN_PROGS = \
|
||||
checkpkg \
|
||||
commitpkg \
|
||||
crossrepomove\
|
||||
devtools-config \
|
||||
diffpkg \
|
||||
finddeps \
|
||||
find-libdeps \
|
||||
lddd \
|
||||
@@ -76,6 +78,8 @@ MANS = \
|
||||
doc/makechrootpkg.1 \
|
||||
doc/lddd.1 \
|
||||
doc/checkpkg.1 \
|
||||
doc/devtools-config.1 \
|
||||
doc/diffpkg.1 \
|
||||
doc/offload-build.1 \
|
||||
doc/sogrep.1 \
|
||||
doc/makerepropkg.1 \
|
||||
|
46
devtools-config.in
Executable file
46
devtools-config.in
Executable file
@@ -0,0 +1,46 @@
|
||||
#!/bin/bash
|
||||
#
|
||||
# SPDX-License-Identifier: GPL-3.0-or-later
|
||||
|
||||
pkgdatadir='@pkgdatadir@'
|
||||
|
||||
# shellcheck disable=SC2059
|
||||
die() { printf "error: $1\n" "${@:2}" >&2; exit 1; }
|
||||
|
||||
usage() {
|
||||
cat <<- _EOF_
|
||||
Usage: ${BASH_SOURCE[0]##*/} [OPTION...]
|
||||
|
||||
Manage and print environment specific devtools information.
|
||||
|
||||
OPTIONS
|
||||
--pkgdatadir Print pkgdatadir location
|
||||
-h, --help Show this help text
|
||||
_EOF_
|
||||
}
|
||||
|
||||
print_pkgdatadir() {
|
||||
printf "%s\n" "${pkgdatadir}"
|
||||
}
|
||||
|
||||
if (( $# == 0 )); then
|
||||
usage
|
||||
exit 0
|
||||
fi
|
||||
|
||||
# option checking
|
||||
while (( $# )); do
|
||||
case $1 in
|
||||
-h|--help)
|
||||
usage
|
||||
exit 0
|
||||
;;
|
||||
--pkgdatadir)
|
||||
print_pkgdatadir
|
||||
exit 0
|
||||
;;
|
||||
*)
|
||||
die "invalid argument: %s" "$1"
|
||||
;;
|
||||
esac
|
||||
done
|
228
diffpkg.in
Normal file
228
diffpkg.in
Normal file
@@ -0,0 +1,228 @@
|
||||
#!/bin/bash
|
||||
#
|
||||
# SPDX-License-Identifier: GPL-3.0-or-later
|
||||
|
||||
shopt -s extglob
|
||||
|
||||
m4_include(lib/common.sh)
|
||||
|
||||
usage() {
|
||||
cat <<- _EOF_
|
||||
Usage: ${BASH_SOURCE[0]##*/} [OPTIONS] [MODES] [FILE|PKGNAME...]
|
||||
|
||||
Searches for a locally built package corresponding to the PKGBUILD, and
|
||||
downloads the last version of that package from the Pacman repositories.
|
||||
It then compares the package archives using different modes while using
|
||||
simple tar content list by default.
|
||||
|
||||
When given one package, use it to diff against the locally built one.
|
||||
When given two packages, diff both packages against each other.
|
||||
|
||||
In either case, a package name will be converted to a filename from the
|
||||
cache, and diffpkg will proceed as though this filename was initially
|
||||
specified.
|
||||
|
||||
OPTIONS
|
||||
-M, --makepkg-config Set an alternate makepkg configuration file
|
||||
-v, --verbose Provide more detailed/unfiltered output
|
||||
-h, --help Show this help text
|
||||
|
||||
MODES
|
||||
-l, --list Activate content list diff mode (default)
|
||||
-d, --diffoscope Activate diffoscope diff mode
|
||||
-p, --pkginfo Activate .PKGINFO diff mode
|
||||
-b, --buildinfo Activate .BUILDINFO diff mode
|
||||
_EOF_
|
||||
}
|
||||
|
||||
MAKEPKG_CONF=/etc/makepkg.conf
|
||||
VERBOSE=0
|
||||
TARLIST=0
|
||||
DIFFOSCOPE=0
|
||||
PKGINFO=0
|
||||
BUILDINFO=0
|
||||
|
||||
# option checking
|
||||
while (( $# )); do
|
||||
case $1 in
|
||||
-h|--help)
|
||||
usage
|
||||
exit 0
|
||||
;;
|
||||
-M|--makepkg-config)
|
||||
MAKEPKG_CONF="$2"
|
||||
shift 2
|
||||
;;
|
||||
-l|--list)
|
||||
TARLIST=1
|
||||
shift
|
||||
;;
|
||||
-d|--diffoscope)
|
||||
DIFFOSCOPE=1
|
||||
shift
|
||||
;;
|
||||
-p|--pkginfo)
|
||||
PKGINFO=1
|
||||
shift
|
||||
;;
|
||||
-b|--buildinfo)
|
||||
BUILDINFO=1
|
||||
shift
|
||||
;;
|
||||
-v|--verbose)
|
||||
VERBOSE=1
|
||||
shift
|
||||
;;
|
||||
--)
|
||||
shift
|
||||
break
|
||||
;;
|
||||
-*,--*)
|
||||
die "invalid argument: %s" "$1"
|
||||
;;
|
||||
*)
|
||||
break
|
||||
;;
|
||||
esac
|
||||
done
|
||||
|
||||
if ! (( DIFFOSCOPE || TARLIST || PKGINFO || BUILDINFO )); then
|
||||
TARLIST=1
|
||||
fi
|
||||
|
||||
# Source makepkg.conf; fail if it is not found
|
||||
if [[ -r "${MAKEPKG_CONF}" ]]; then
|
||||
# shellcheck source=makepkg-x86_64.conf
|
||||
source "${MAKEPKG_CONF}"
|
||||
else
|
||||
die "${MAKEPKG_CONF} not found!"
|
||||
fi
|
||||
|
||||
# Source user-specific makepkg.conf overrides
|
||||
if [[ -r "${XDG_CONFIG_HOME:-$HOME/.config}/pacman/makepkg.conf" ]]; then
|
||||
# shellcheck source=/dev/null
|
||||
source "${XDG_CONFIG_HOME:-$HOME/.config}/pacman/makepkg.conf"
|
||||
elif [[ -r "$HOME/.makepkg.conf" ]]; then
|
||||
# shellcheck source=/dev/null
|
||||
source "$HOME/.makepkg.conf"
|
||||
fi
|
||||
|
||||
STARTDIR=$(pwd)
|
||||
trap 'rm -rf $TMPDIR' EXIT INT TERM QUIT
|
||||
TMPDIR=$(mktemp -d --tmpdir diffpkg-script.XXXXXXXX)
|
||||
export TMPDIR
|
||||
|
||||
tar_list() {
|
||||
bsdtar tf "$*" | if (( VERBOSE )); then
|
||||
cat
|
||||
else
|
||||
sed -E 's|^usr/lib/modules/[0-9][^/]+|usr/lib/modules/[…]|g'
|
||||
fi | sort
|
||||
}
|
||||
|
||||
diff_pkgs() {
|
||||
local oldpkg newpkg
|
||||
oldpkg=$(readlink -m "$1")
|
||||
newpkg=$(readlink -m "$2")
|
||||
|
||||
[[ -f $oldpkg ]] || die "No such file: %s" "${oldpkg}"
|
||||
[[ -f $newpkg ]] || die "No such file: %s" "${newpkg}"
|
||||
|
||||
if (( TARLIST )); then
|
||||
tar_list "$oldpkg" > "$TMPDIR/filelist-old"
|
||||
tar_list "$newpkg" > "$TMPDIR/filelist"
|
||||
|
||||
sdiff -s "$TMPDIR/filelist-old" "$TMPDIR/filelist"
|
||||
fi
|
||||
|
||||
if (( PKGINFO )); then
|
||||
bsdtar xOqf "$oldpkg" .PKGINFO > "$TMPDIR/pkginfo-old"
|
||||
bsdtar xOqf "$newpkg" .PKGINFO > "$TMPDIR/pkginfo"
|
||||
|
||||
sdiff -s "$TMPDIR/pkginfo-old" "$TMPDIR/pkginfo"
|
||||
fi
|
||||
|
||||
if (( BUILDINFO )); then
|
||||
bsdtar xOqf "$oldpkg" .BUILDINFO > "$TMPDIR/buildinfo-old"
|
||||
bsdtar xOqf "$newpkg" .BUILDINFO > "$TMPDIR/buildinfo"
|
||||
|
||||
sdiff -s "$TMPDIR/buildinfo-old" "$TMPDIR/buildinfo"
|
||||
fi
|
||||
|
||||
if (( DIFFOSCOPE )); then
|
||||
diffoscope "$oldpkg" "$newpkg"
|
||||
fi
|
||||
}
|
||||
|
||||
fetch_pkg() {
|
||||
local pkg pkgdest pkgurl
|
||||
case $1 in
|
||||
*://*)
|
||||
pkgurl=$1 ;;
|
||||
/*|*/*)
|
||||
pkgurl=$(readlink -m "$1") ;;
|
||||
*.pkg.tar*)
|
||||
pkgurl=$1 ;;
|
||||
'')
|
||||
;;
|
||||
*)
|
||||
pkg=$1 ;;
|
||||
esac
|
||||
|
||||
[[ -n $pkgurl ]] || pkgurl=$(pacman -Spdd --print-format '%l' --noconfirm "$pkg") ||
|
||||
die "Couldn't download previous package for %s." "$pkg"
|
||||
|
||||
pkg=${pkgurl##*/}
|
||||
pkgdest=$(mktemp -t -d "${pkg}-XXXXXX")/${pkg}
|
||||
|
||||
if [[ $pkgurl = file://* || ( $pkgurl = /* && -f $pkgurl ) ]]; then
|
||||
ln -sf "${pkgurl#file://}" "$pkgdest"
|
||||
elif [[ -f "$PKGDEST/$pkg" ]]; then
|
||||
ln -sf "$PKGDEST/$pkg" "$pkgdest"
|
||||
elif [[ -f "$STARTDIR/$pkg" ]]; then
|
||||
ln -sf "$STARTDIR/$pkg" "$pkgdest"
|
||||
elif [[ $pkgurl = *://* ]]; then
|
||||
curl -fsLC - --retry 3 --retry-delay 3 -o "$pkgdest" "$pkgurl" || \
|
||||
die "Couldn't download %s" "$pkgurl"
|
||||
else
|
||||
die "File not found: %s" "$pkgurl"
|
||||
fi
|
||||
|
||||
echo "$pkgdest"
|
||||
}
|
||||
|
||||
if (( $# < 2 )); then
|
||||
if [[ ! -f PKGBUILD ]]; then
|
||||
die "This must be run in the directory of a built package.\nTry '$(basename "$0") --help' for more information."
|
||||
fi
|
||||
|
||||
# shellcheck source=PKGBUILD.proto
|
||||
. ./PKGBUILD
|
||||
if [[ ${arch[0]} == 'any' ]]; then
|
||||
CARCH='any'
|
||||
fi
|
||||
|
||||
for _pkgname in "${pkgname[@]}"; do
|
||||
comparepkg=$_pkgname
|
||||
pkgurl=
|
||||
target_pkgver=$(get_full_version "$_pkgname")
|
||||
if ! pkgfile=$(find_cached_package "$_pkgname" "$target_pkgver" "$CARCH"); then
|
||||
die 'tarball not found for package: %s' "${_pkgname}-$target_pkgver"
|
||||
fi
|
||||
|
||||
ln -s "$pkgfile" "$TMPDIR"
|
||||
|
||||
if (( $# )); then
|
||||
comparepkg="$1"
|
||||
fi
|
||||
|
||||
oldpkg=$(fetch_pkg "$comparepkg") || exit 1
|
||||
|
||||
diff_pkgs "$oldpkg" "$pkgfile"
|
||||
done
|
||||
else
|
||||
file1=$(fetch_pkg "$1") || exit 1
|
||||
file2=$(fetch_pkg "$2") || exit 1
|
||||
|
||||
diff_pkgs "$file1" "$file2"
|
||||
fi
|
26
doc/devtools-config.1.asciidoc
Normal file
26
doc/devtools-config.1.asciidoc
Normal file
@@ -0,0 +1,26 @@
|
||||
devtools-config(1)
|
||||
================
|
||||
|
||||
Name
|
||||
----
|
||||
devtools-config - Manage and print environment specific devtools information.
|
||||
|
||||
Synopsis
|
||||
--------
|
||||
devtools-config [OPTIONS]
|
||||
|
||||
Description
|
||||
-----------
|
||||
|
||||
Manage and print environment specific devtools information.
|
||||
|
||||
Options
|
||||
-------
|
||||
|
||||
*--pkgdatadir*::
|
||||
Print environment specific pkgdatadir location.
|
||||
|
||||
*-h, --help*::
|
||||
Show a help text.
|
||||
|
||||
include::footer.asciidoc[]
|
57
doc/diffpkg.1.asciidoc
Normal file
57
doc/diffpkg.1.asciidoc
Normal file
@@ -0,0 +1,57 @@
|
||||
diffpkg(1)
|
||||
===========
|
||||
|
||||
Name
|
||||
----
|
||||
diffpkg - Compare package files using different modes.
|
||||
|
||||
Synopsis
|
||||
--------
|
||||
diffpkg [OPTIONS] [MODES] [FILE|PKGNAME...]
|
||||
|
||||
Description
|
||||
-----------
|
||||
|
||||
Searches for a locally built package corresponding to the PKGBUILD, and
|
||||
downloads the last version of that package from the Pacman repositories.
|
||||
It then compares the package archives using different modes while using
|
||||
simple tar content list by default.
|
||||
|
||||
When given one package, use it to diff against the locally built one.
|
||||
When given two packages, diff both packages against each other.
|
||||
|
||||
In either case, a package name will be converted to a filename from the
|
||||
cache, and diffpkg will proceed as though this filename was initially
|
||||
specified.
|
||||
|
||||
Options
|
||||
-------
|
||||
|
||||
*-M, --makepkg-config*::
|
||||
Set an alternate makepkg configuration file
|
||||
|
||||
*-v, --verbose*::
|
||||
Provide more detailed/unfiltered output
|
||||
|
||||
*-h, --help*::
|
||||
Show a help text
|
||||
|
||||
Modes
|
||||
-----
|
||||
|
||||
*-l, --list*::
|
||||
Activate tar content list diff mode (default)
|
||||
|
||||
*-d, --diffoscope*::
|
||||
Activate diffoscope diff mode
|
||||
|
||||
*-p, --pkginfo*::
|
||||
Activate .PKGINFO diff mode
|
||||
|
||||
*-b, --buildinfo*::
|
||||
Activate .BUILDINFO diff mode
|
||||
|
||||
See Also
|
||||
--------
|
||||
|
||||
include::footer.asciidoc[]
|
@@ -101,10 +101,11 @@ mapfile -t files < <(
|
||||
printf "%s\n" "" "-> build complete" &&
|
||||
printf "\t%s\n" "$temp"/*
|
||||
} >&2 &&
|
||||
pkgdatadir="$(devtools-config --pkgdatadir||echo /usr/share/devtools)" &&
|
||||
makepkg_user_config="${XDG_CONFIG_HOME:-$HOME/.config}/pacman/makepkg.conf" &&
|
||||
makepkg_config="/usr/share/devtools/makepkg-'"${arch}"'.conf" &&
|
||||
if [[ -f /usr/share/devtools/makepkg-'"${repo}"'-'"${arch}"'.conf ]]; then
|
||||
makepkg_config="/usr/share/devtools/makepkg-'"${repo}"'-'"${arch}"'.conf"
|
||||
makepkg_config="${pkgdatadir}/makepkg-'"${arch}"'.conf" &&
|
||||
if [[ -f "${pkgdatadir}/makepkg-'"${repo}"'-'"${arch}"'.conf" ]]; then
|
||||
makepkg_config="${pkgdatadir}/makepkg-'"${repo}"'-'"${arch}"'.conf"
|
||||
fi &&
|
||||
makepkg --config <(cat "${makepkg_user_config}" "${makepkg_config}" 2>/dev/null) --packagelist &&
|
||||
printf "%s\n" "${temp}/PKGBUILD"
|
||||
|
@@ -1,4 +1,4 @@
|
||||
#compdef archbuild archco arch-nspawn archrelease commitpkg finddeps makechrootpkg mkarchroot rebuildpkgs extrapkg=commitpkg corepkg=commitpkg testingpkg=commitpkg stagingpkg=commitpkg communitypkg=commitpkg community-testingpkg=commitpkg community-stagingpkg=commitpkg multilibpkg=commitpkg multilib-testingpkg=commitpkg extra-x86_64-build=archbuild testing-x86_64-build=archbuild staging-x86_64-build=archbuild multilib-build=archbuild multilib-testing-build=archbuild multilib-staging-build=archbuild kde-unstable-x86_64-build=archbuild gnome-unstable-x86_64-build=archbuild communityco=archco checkpkg sogrep offload-build makerepropkg
|
||||
#compdef archbuild archco arch-nspawn archrelease commitpkg devtools-config diffpkg finddeps makechrootpkg mkarchroot rebuildpkgs extrapkg=commitpkg corepkg=commitpkg testingpkg=commitpkg stagingpkg=commitpkg communitypkg=commitpkg community-testingpkg=commitpkg community-stagingpkg=commitpkg multilibpkg=commitpkg multilib-testingpkg=commitpkg extra-x86_64-build=archbuild testing-x86_64-build=archbuild staging-x86_64-build=archbuild multilib-build=archbuild multilib-testing-build=archbuild multilib-staging-build=archbuild kde-unstable-x86_64-build=archbuild gnome-unstable-x86_64-build=archbuild communityco=archco checkpkg sogrep offload-build makerepropkg
|
||||
#
|
||||
# SPDX-License-Identifier: GPL-3.0-or-later
|
||||
|
||||
@@ -41,6 +41,22 @@ _commitpkg_args=(
|
||||
'1:commit_msg'
|
||||
)
|
||||
|
||||
_devtools_config_args=(
|
||||
'(--pkgdatadir)'{--pkgdatadir}'[Print pkgdatadir location]'
|
||||
'(-h --help)'{-h,--help}'[Display usage]'
|
||||
)
|
||||
|
||||
_diffpkg_args=(
|
||||
'(-l --list)'{-l,--list}'[Tar content list diff mode]'
|
||||
'(-d --diffoscope)'{-d,--diffoscope}'[Diffoscope diff mode]'
|
||||
'(-p --pkginfo)'{-p,--pkginfo}'[.PKGINFO diff mode]'
|
||||
'(-b --buildinfo)'{-b,--buildinfo}'[.BUILDINFO diff mode]'
|
||||
'(-m --makepkg-config)'{-m,--makepkg-config}'[Location of a makepkg config file]:makepkg_config:_files -g "*.conf(.)"'
|
||||
'(-v --verbose)'{-v,--verbose}'[Provide more detailed/unfiltered output]'
|
||||
'(-h --help)'{-h,--help}'[Display usage]'
|
||||
'*:packages:_devtools_completions_all_packages'
|
||||
)
|
||||
|
||||
_finddeps_args=(
|
||||
'1:packages:_devtools_completions_all_packages'
|
||||
)
|
||||
|
Reference in New Issue
Block a user