[pacman-dev] [PATCH 2/4] repo-add : remove useless test_repo_db_file function
This function was used only once, was basically just one line, and was also
called with an unused argument.
Signed-off-by: Xavier Chantry
REPO_DB_FILE does not need to be an absolute path anymore so no need to
call realpath.
Signed-off-by: Xavier Chantry
Rework slightly db_write_entry so that $pkgfile is no longer referenced
from the temporary dir. This means $pkgfile can be a relative path and does
not need to be converted with realpath anymore.
Signed-off-by: Xavier Chantry
On Wed, Feb 18, 2009 at 10:19 AM, Xavier Chantry
REPO_DB_FILE does not need to be an absolute path anymore so no need to call realpath.
Signed-off-by: Xavier Chantry
--- scripts/repo-add.sh.in | 31 +++++++++++++++---------------- 1 files changed, 15 insertions(+), 16 deletions(-) diff --git a/scripts/repo-add.sh.in b/scripts/repo-add.sh.in index 6b10527..7a271c4 100644 --- a/scripts/repo-add.sh.in +++ b/scripts/repo-add.sh.in @@ -317,7 +317,7 @@ for arg in "$@"; do QUIET=1 elif [ -z "$REPO_DB_FILE" ]; then # store absolute path to repo DB - REPO_DB_FILE=$($realpath "$arg") + REPO_DB_FILE="$arg" if [ -f "$REPO_DB_FILE" ]; then if ! (bsdtar -tf "$REPO_DB_FILE" | grep -q "/desc"); then error "$(gettext "Repository file '%s' is not a proper pacman database.")" "$REPO_DB_FILE" @@ -359,27 +359,26 @@ done # if all operations were a success, re-zip database if [ $success -eq 1 ]; then msg "$(gettext "Creating updated database file '%s'")" "$REPO_DB_FILE" - pushd "$gstmpdir" 2>&1 >/dev/null
- if [ -n "$(ls)" ]; then - [ -f "${REPO_DB_FILE}.old" ] && rm "${REPO_DB_FILE}.old" - [ -f "$REPO_DB_FILE" ] && mv "$REPO_DB_FILE" "${REPO_DB_FILE}.old" - - case "$REPO_DB_FILE" in - *tar.gz) TAR_OPT="z" ;; - *tar.bz2) TAR_OPT="j" ;; - *) warning "$(gettext "'%s' does not have a valid archive extension.")" \ - "$REPO_DB_FILE" ;; - esac + case "$REPO_DB_FILE" in + *tar.gz) TAR_OPT="z" ;; + *tar.bz2) TAR_OPT="j" ;; + *) warning "$(gettext "'%s' does not have a valid archive extension.")" \ + "$REPO_DB_FILE" ;; + esac + + filename=$(basename "$REPO_DB_FILE")
- bsdtar -c${TAR_OPT}f "$REPO_DB_FILE" * + pushd "$gstmpdir" 2>&1 >/dev/null + if [ -n "$(ls)" ]; then + bsdtar -c${TAR_OPT}f "$filename" * else - # we should only end up with an empty db after a remove of the last package in the database error "$(gettext "All packages have been removed from the database. Deleting '%s'.")" "$REPO_DB_FILE" - rm "$REPO_DB_FILE" Huh? Why'd this get killed, or am I missing something?
fi - popd 2>&1 >/dev/null + + [ -f "$REPO_DB_FILE" ] && mv -f "$REPO_DB_FILE" "${REPO_DB_FILE}.old" + [ -f "$gstmpdir/$filename" ] && mv "$gstmpdir/$filename" "$REPO_DB_FILE" else msg "$(gettext "No packages modified, nothing to do.")" fi -- 1.6.1.3
_______________________________________________ pacman-dev mailing list pacman-dev@archlinux.org http://www.archlinux.org/mailman/listinfo/pacman-dev
On Thu, Feb 19, 2009 at 2:24 AM, Dan McGee
On Wed, Feb 18, 2009 at 10:19 AM, Xavier Chantry
wrote: REPO_DB_FILE does not need to be an absolute path anymore so no need to call realpath.
Signed-off-by: Xavier Chantry
--- scripts/repo-add.sh.in | 31 +++++++++++++++---------------- 1 files changed, 15 insertions(+), 16 deletions(-) - bsdtar -c${TAR_OPT}f "$REPO_DB_FILE" * + pushd "$gstmpdir" 2>&1 >/dev/null + if [ -n "$(ls)" ]; then + bsdtar -c${TAR_OPT}f "$filename" * else - # we should only end up with an empty db after a remove of the last package in the database error "$(gettext "All packages have been removed from the database. Deleting '%s'.")" "$REPO_DB_FILE" - rm "$REPO_DB_FILE" Huh? Why'd this get killed, or am I missing something?
I really cannot blame you for it, I knew this message would be confusing, but I was not sure how to change it. Because the result is still the same. In this case, "$filename" was not created, but "$REPO_DB_FILE" exists. So the first line below will move the $repodb to $repodb.old But $filename wont be moved to $repodb. As a result the database has been deleted (at least moved to .old)
fi - popd 2>&1 >/dev/null + + [ -f "$REPO_DB_FILE" ] && mv -f "$REPO_DB_FILE" "${REPO_DB_FILE}.old" + [ -f "$gstmpdir/$filename" ] && mv "$gstmpdir/$filename" "$REPO_DB_FILE" else msg "$(gettext "No packages modified, nothing to do.")" fi -- 1.6.1.3
On Thu, Feb 19, 2009 at 1:51 AM, Xavier
On Thu, Feb 19, 2009 at 2:24 AM, Dan McGee
wrote: On Wed, Feb 18, 2009 at 10:19 AM, Xavier Chantry
wrote: REPO_DB_FILE does not need to be an absolute path anymore so no need to call realpath.
Signed-off-by: Xavier Chantry
--- scripts/repo-add.sh.in | 31 +++++++++++++++---------------- 1 files changed, 15 insertions(+), 16 deletions(-) - bsdtar -c${TAR_OPT}f "$REPO_DB_FILE" * + pushd "$gstmpdir" 2>&1 >/dev/null + if [ -n "$(ls)" ]; then + bsdtar -c${TAR_OPT}f "$filename" * else - # we should only end up with an empty db after a remove of the last package in the database error "$(gettext "All packages have been removed from the database. Deleting '%s'.")" "$REPO_DB_FILE" - rm "$REPO_DB_FILE" Huh? Why'd this get killed, or am I missing something?
I really cannot blame you for it, I knew this message would be confusing, but I was not sure how to change it. Because the result is still the same. In this case, "$filename" was not created, but "$REPO_DB_FILE" exists. So the first line below will move the $repodb to $repodb.old But $filename wont be moved to $repodb. As a result the database has been deleted (at least moved to .old)
Mind writing that in comment form, inline in the code? That would keep me from being confused ever again. :)
fi - popd 2>&1 >/dev/null + + [ -f "$REPO_DB_FILE" ] && mv -f "$REPO_DB_FILE" "${REPO_DB_FILE}.old" + [ -f "$gstmpdir/$filename" ] && mv "$gstmpdir/$filename" "$REPO_DB_FILE" else msg "$(gettext "No packages modified, nothing to do.")" fi -- 1.6.1.3
The rest seems sane, make that fix and I'll pull it in.
On Thu, Feb 19, 2009 at 2:23 PM, Dan McGee
On Thu, Feb 19, 2009 at 1:51 AM, Xavier
wrote: On Thu, Feb 19, 2009 at 2:24 AM, Dan McGee
wrote: On Wed, Feb 18, 2009 at 10:19 AM, Xavier Chantry
wrote: REPO_DB_FILE does not need to be an absolute path anymore so no need to call realpath.
Signed-off-by: Xavier Chantry
--- scripts/repo-add.sh.in | 31 +++++++++++++++---------------- 1 files changed, 15 insertions(+), 16 deletions(-) - bsdtar -c${TAR_OPT}f "$REPO_DB_FILE" * + pushd "$gstmpdir" 2>&1 >/dev/null + if [ -n "$(ls)" ]; then + bsdtar -c${TAR_OPT}f "$filename" * else - # we should only end up with an empty db after a remove of the last package in the database error "$(gettext "All packages have been removed from the database. Deleting '%s'.")" "$REPO_DB_FILE" - rm "$REPO_DB_FILE" Huh? Why'd this get killed, or am I missing something?
I really cannot blame you for it, I knew this message would be confusing, but I was not sure how to change it. Because the result is still the same. In this case, "$filename" was not created, but "$REPO_DB_FILE" exists. So the first line below will move the $repodb to $repodb.old But $filename wont be moved to $repodb. As a result the database has been deleted (at least moved to .old)
Mind writing that in comment form, inline in the code? That would keep me from being confused ever again. :)
Sure, would this work? # the database will be moved to .old below, and there will be no new one to replace it error "$(gettext "All packages have been removed from the database. Deleting '%s'.")" "$REPO_DB_FILE" If yes, it is on my working branch :)
participants (3)
-
Dan McGee
-
Xavier
-
Xavier Chantry