Remove delta support from repo-add
Signed-off-by: Allan McRae <allan@archlinux.org>
This commit is contained in:
parent
377d47142f
commit
9adb0d5b37
2 changed files with 15 additions and 175 deletions
|
@ -8,27 +8,25 @@ repo-add - package database maintenance utility
|
|||
|
||||
Synopsis
|
||||
--------
|
||||
'repo-add' [options] <path-to-db> <package|delta> [<package|delta> ...]
|
||||
'repo-add' [options] <path-to-db> <package> [<package> ...]
|
||||
|
||||
'repo-remove' [options] <path-to-db> <packagename|delta> [<packagename|delta> ...]
|
||||
'repo-remove' [options] <path-to-db> <packagename> [<packagename> ...]
|
||||
|
||||
|
||||
Description
|
||||
-----------
|
||||
'repo-add' and 'repo-remove' are two scripts to help build a package database for
|
||||
packages built with linkman:makepkg[8] and installed with linkman:pacman[8].
|
||||
They also handle package deltas produced by linkman:pkgdelta[8].
|
||||
|
||||
'repo-add' will update a package database by reading a built package or package
|
||||
delta file. Multiple packages and/or deltas to add can be specified on the
|
||||
command line.
|
||||
'repo-add' will update a package database by reading a built package file.
|
||||
Multiple packages to add can be specified on the command line.
|
||||
|
||||
If a matching ``.sig'' file is found alongside a package file, the signature
|
||||
will automatically be embedded into the database.
|
||||
|
||||
'repo-remove' will update a package database by removing the package name or
|
||||
delta specified on the command line. Multiple packages and/or delta to remove
|
||||
can be specified on the command line.
|
||||
'repo-remove' will update a package database by removing the package name
|
||||
specified on the command line. Multiple packages to remove can be specified
|
||||
on the command line.
|
||||
|
||||
A package database is a tar file, optionally compressed. Valid extensions are
|
||||
``.db'' followed by an archive extension of ``.tar'', ``.tar.gz'', ``.tar.bz2'',
|
||||
|
@ -64,10 +62,6 @@ Common Options
|
|||
|
||||
repo-add Options
|
||||
----------------
|
||||
*-d, \--delta*::
|
||||
Automatically generate and add a delta file between the old entry and the
|
||||
new one, if the old package file is found next to the new one.
|
||||
|
||||
*-n, \--new*::
|
||||
Only add packages that are not already in the database. Warnings will be
|
||||
printed upon detection of existing packages, but they will not be re-added.
|
||||
|
@ -89,6 +83,6 @@ db.tar* extension), there is currently no additional benefit for the larger down
|
|||
|
||||
See Also
|
||||
--------
|
||||
linkman:makepkg[8], linkman:pacman[8], linkman:pkgdelta[8]
|
||||
linkman:makepkg[8], linkman:pacman[8]
|
||||
|
||||
include::footer.asciidoc[]
|
||||
|
|
|
@ -31,7 +31,6 @@ declare -r confdir='@sysconfdir@'
|
|||
LIBRARY=${LIBRARY:-'@libmakepkgdir@'}
|
||||
|
||||
QUIET=0
|
||||
DELTA=0
|
||||
ONLYADDNEW=0
|
||||
RMEXISTING=0
|
||||
SIGN=0
|
||||
|
@ -55,18 +54,17 @@ usage() {
|
|||
cmd=${0##*/}
|
||||
printf -- "%s (pacman) %s\n\n" "$cmd" "$myver"
|
||||
if [[ $cmd == "repo-add" ]] ; then
|
||||
printf -- "$(gettext "Usage: repo-add [options] <path-to-db> <package|delta> ...\n")"
|
||||
printf -- "$(gettext "Usage: repo-add [options] <path-to-db> <package> ...\n")"
|
||||
printf -- "\n"
|
||||
printf -- "$(gettext "\
|
||||
repo-add will update a package database by reading a package file.\n\
|
||||
Multiple packages to add can be specified on the command line.\n")"
|
||||
printf -- "\n"
|
||||
printf -- "$(gettext "Options:\n")"
|
||||
printf -- "$(gettext " -d, --delta generate and add delta for package update\n")"
|
||||
printf -- "$(gettext " -n, --new only add packages that are not already in the database\n")"
|
||||
printf -- "$(gettext " -R, --remove remove old package file from disk after updating database\n")"
|
||||
elif [[ $cmd == "repo-remove" ]] ; then
|
||||
printf -- "$(gettext "Usage: repo-remove [options] <path-to-db> <packagename|delta> ...\n")"
|
||||
printf -- "$(gettext "Usage: repo-remove [options] <path-to-db> <packagename> ...\n")"
|
||||
printf -- "\n"
|
||||
printf -- "$(gettext "\
|
||||
repo-remove will update a package database by removing the package name\n\
|
||||
|
@ -131,90 +129,6 @@ find_pkgentry() {
|
|||
return 1
|
||||
}
|
||||
|
||||
# Get the package name from the delta filename
|
||||
get_delta_pkgname() {
|
||||
local tmp
|
||||
|
||||
tmp=${1##*/}
|
||||
echo ${tmp%-*-*_to*}
|
||||
}
|
||||
|
||||
# write a delta entry
|
||||
# arg1 - path to delta file
|
||||
db_write_delta() {
|
||||
deltafile=$1
|
||||
pkgname=$(get_delta_pkgname "$deltafile")
|
||||
|
||||
pkgentry=$(find_pkgentry "$pkgname")
|
||||
if [[ -z $pkgentry ]]; then
|
||||
error "$(gettext "No database entry for package '%s'.")" "$pkgname"
|
||||
return 1
|
||||
fi
|
||||
deltas=$pkgentry/deltas
|
||||
if [[ ! -f $deltas ]]; then
|
||||
echo -e "%DELTAS%" >"$deltas"
|
||||
fi
|
||||
# get md5sum and compressed size of package
|
||||
md5sum=$(md5sum "$deltafile")
|
||||
md5sum=${md5sum%% *}
|
||||
csize=$(wc -c "$deltafile" | cut -d' ' -f1)
|
||||
|
||||
oldfile=$(xdelta3 printhdr "$deltafile" | sed -n 's/XDELTA filename (source):\s\+\(\.*\)/\1/p')
|
||||
newfile=$(xdelta3 printhdr "$deltafile" | sed -n 's/XDELTA filename (output):\s\+\(\.*\)/\1/p')
|
||||
|
||||
if grep -q "$oldfile.*$newfile" "$deltas"; then
|
||||
sed -i.backup "/$oldfile.*$newfile/d" "$deltas" && rm -f "$deltas.backup"
|
||||
fi
|
||||
msg2 "$(gettext "Adding 'deltas' entry : %s -> %s")" "$oldfile" "$newfile"
|
||||
echo "${deltafile##*/} $md5sum $csize $oldfile $newfile" >> "$deltas"
|
||||
|
||||
# copy updated deltas entry into "files" database
|
||||
local filesentry=$(echo "$pkgentry" | sed 's/\(.*\)\/db\//\1\/files\//')
|
||||
mkdir -p "$filesentry"
|
||||
cp $deltas "$filesentry"
|
||||
|
||||
return 0
|
||||
} # end db_write_delta
|
||||
|
||||
# remove a delta entry
|
||||
# arg1 - path to delta file
|
||||
db_remove_delta() {
|
||||
deltafile=$1
|
||||
filename=${deltafile##*/}
|
||||
pkgname=$(get_delta_pkgname "$deltafile")
|
||||
|
||||
pkgentry=$(find_pkgentry "$pkgname")
|
||||
if [[ -z $pkgentry ]]; then
|
||||
return 1
|
||||
fi
|
||||
deltas=$pkgentry/deltas
|
||||
if [[ ! -f $deltas ]]; then
|
||||
return 1
|
||||
fi
|
||||
if grep -q "$filename" "$deltas"; then
|
||||
sed -i.backup "/$filename/d" "$deltas" && rm -f "$deltas.backup"
|
||||
msg2 "$(gettext "Removing existing entry '%s'...")" "$filename"
|
||||
# empty deltas file contains only "%DELTAS%"
|
||||
if (( $(wc -l < "$deltas") == 1 )); then
|
||||
msg2 "$(gettext "Removing empty deltas file...")"
|
||||
rm "$deltas"
|
||||
fi
|
||||
|
||||
# copy updated deltas entry into "files" database
|
||||
local filesentry=$(echo "$pkgentry" | sed 's/\(.*\)\/db\//\1\/files\//')
|
||||
if [[ -f $deltas ]]; then
|
||||
mkdir -p "$filesentry"
|
||||
cp $deltas "$filesentry"
|
||||
else
|
||||
rm -f "$filesentry/deltas"
|
||||
fi
|
||||
|
||||
return 0
|
||||
fi
|
||||
|
||||
return 1
|
||||
} # end db_remove_delta
|
||||
|
||||
check_gpg() {
|
||||
if ! type -p gpg >/dev/null; then
|
||||
error "$(gettext "Cannot find the gpg binary! Is GnuPG installed?")"
|
||||
|
@ -233,30 +147,6 @@ check_gpg() {
|
|||
fi
|
||||
}
|
||||
|
||||
check_xdelta() {
|
||||
local need_xdelta=0
|
||||
|
||||
if (( DELTA )); then
|
||||
need_xdelta=1
|
||||
else
|
||||
if [[ $cmd == "repo-add" ]]; then
|
||||
for f in ${args[@]:1}; do
|
||||
case $f in
|
||||
*.delta) need_xdelta=1 ;;
|
||||
*) ;;
|
||||
esac
|
||||
done
|
||||
fi
|
||||
fi
|
||||
|
||||
if (( need_xdelta )); then
|
||||
if ! type xdelta3 &>/dev/null; then
|
||||
error "$(gettext "Cannot find the xdelta3 binary! Is xdelta3 installed?")"
|
||||
exit 1
|
||||
fi
|
||||
fi
|
||||
}
|
||||
|
||||
# sign the package database once repackaged
|
||||
create_signature() {
|
||||
(( ! SIGN )) && return
|
||||
|
@ -358,7 +248,7 @@ db_write_entry() {
|
|||
return 0
|
||||
fi
|
||||
else
|
||||
if (( DELTA || RMEXISTING )); then
|
||||
if (( RMEXISTING )); then
|
||||
pkgentry=$(find_pkgentry "$pkgname")
|
||||
if [[ -n $pkgentry ]]; then
|
||||
local oldfilename="$(sed -n '/^%FILENAME%$/ {n;p;q;}' "$pkgentry/desc")"
|
||||
|
@ -399,9 +289,6 @@ db_write_entry() {
|
|||
mkdir "$pkgname-$pkgver"
|
||||
pushd "$pkgname-$pkgver" >/dev/null
|
||||
|
||||
# restore an eventual deltas file
|
||||
[[ -f ../$pkgname.deltas ]] && mv "../$pkgname.deltas" deltas
|
||||
|
||||
# create desc entry
|
||||
msg2 "$(gettext "Creating '%s' db entry...")" 'desc'
|
||||
{
|
||||
|
@ -439,20 +326,6 @@ db_write_entry() {
|
|||
popd >/dev/null
|
||||
popd >/dev/null
|
||||
|
||||
# create a delta file
|
||||
if (( DELTA )); then
|
||||
if [[ -n $oldfilename ]]; then
|
||||
if [[ -f $oldfile ]]; then
|
||||
delta=$(pkgdelta -q "$oldfile" "$1")
|
||||
if [[ -f $delta ]]; then
|
||||
db_write_delta "$delta"
|
||||
fi
|
||||
else
|
||||
warning "$(gettext "Old package file not found: %s")" "$oldfilename"
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
|
||||
# copy updated package entry into "files" database
|
||||
cp -a "$tmpdir/db/$pkgname-$pkgver" "$tmpdir/files/$pkgname-$pkgver"
|
||||
|
||||
|
@ -478,9 +351,7 @@ db_remove_entry() {
|
|||
local pkgentry=$(find_pkgentry "$pkgname")
|
||||
while [[ -n $pkgentry ]]; do
|
||||
notfound=0
|
||||
if [[ -f $pkgentry/deltas ]]; then
|
||||
mv "$pkgentry/deltas" "$tmpdir/db/$pkgname.deltas"
|
||||
fi
|
||||
|
||||
msg2 "$(gettext "Removing existing entry '%s'...")" \
|
||||
"${pkgentry##*/}"
|
||||
rm -rf "$pkgentry"
|
||||
|
@ -574,16 +445,6 @@ add() {
|
|||
return 1
|
||||
fi
|
||||
|
||||
if [[ $1 = *-*-*_to_*-*-*.delta ]]; then
|
||||
deltafile=$1
|
||||
msg "$(gettext "Adding delta '%s'")" "$deltafile"
|
||||
if db_write_delta "$deltafile"; then
|
||||
return 0
|
||||
else
|
||||
return 1
|
||||
fi
|
||||
fi
|
||||
|
||||
pkgfile=$1
|
||||
if ! bsdtar -tqf "$pkgfile" .PKGINFO >/dev/null 2>&1; then
|
||||
error "$(gettext "'%s' is not a package file, skipping")" "$pkgfile"
|
||||
|
@ -596,27 +457,15 @@ add() {
|
|||
}
|
||||
|
||||
remove() {
|
||||
if [[ $1 = *-*-*_to_*-*-*.delta ]]; then
|
||||
deltafile=$1
|
||||
msg "$(gettext "Searching for delta '%s'...")" "$deltafile"
|
||||
if db_remove_delta "$deltafile"; then
|
||||
return 0
|
||||
else
|
||||
error "$(gettext "Delta matching '%s' not found.")" "$deltafile"
|
||||
return 1
|
||||
fi
|
||||
fi
|
||||
|
||||
pkgname=$1
|
||||
msg "$(gettext "Searching for package '%s'...")" "$pkgname"
|
||||
|
||||
if db_remove_entry "$pkgname"; then
|
||||
rm -f "$tmpdir/db/$pkgname.deltas"
|
||||
return 0
|
||||
else
|
||||
if ! db_remove_entry "$pkgname"; then
|
||||
error "$(gettext "Package matching '%s' not found.")" "$pkgname"
|
||||
return 1
|
||||
fi
|
||||
|
||||
return 0
|
||||
}
|
||||
|
||||
rotate_db() {
|
||||
|
@ -755,7 +604,6 @@ declare -a args
|
|||
while (( $# )); do
|
||||
case $1 in
|
||||
-q|--quiet) QUIET=1;;
|
||||
-d|--delta) DELTA=1;;
|
||||
-n|--new) ONLYADDNEW=1;;
|
||||
-R|--remove) RMEXISTING=1;;
|
||||
--nocolor) USE_COLOR='n';;
|
||||
|
@ -806,8 +654,6 @@ if (( SIGN || VERIFY )); then
|
|||
check_gpg
|
||||
fi
|
||||
|
||||
check_xdelta
|
||||
|
||||
if (( VERIFY && ${#args[@]} == 1 )); then
|
||||
for repo in "db" "files"; do
|
||||
dbfile=${repodir}/$REPO_DB_PREFIX.$repo.$REPO_DB_SUFFIX
|
||||
|
|
Loading…
Add table
Reference in a new issue