Subject: pkg/34836: undo-replace is nonfunctional when new PKGNAME != old PKGNAME
To: None <pkg-manager@netbsd.org, gnats-admin@netbsd.org,>
From: None <tv@pobox.com>
List: pkgsrc-bugs
Date: 10/16/2006 21:00:00
>Number: 34836
>Category: pkg
>Synopsis: undo-replace is nonfunctional when new PKGNAME != old PKGNAME
>Confidential: no
>Severity: serious
>Priority: medium
>Responsible: pkg-manager
>State: open
>Class: sw-bug
>Submitter-Id: net
>Arrival-Date: Mon Oct 16 21:00:00 +0000 2006
>Originator: Todd Vierling
>Release: NetBSD 2.1.0_STABLE
>Organization:
DUH.ORG: Pointing out the obvious since 1994.
>Environment:
N/A
>Description:
"make undo-replace" does not work if the original package version was not
identical to the one being installed by "make replace". Due to the
hyper-overloading of the oldname/newname files in flavor/pkg/replace.mk,
the oldname doesn't even exist anywhere once "undo-replace-names" runs
(as that clobbers the oldname file with the new package name).
>How-To-Repeat:
Install a package, say, "somepkg-1.0".
In pkgsrc reflecting a new version, say, "somepkg-1.1", do "make replace".
"make undo-replace".
See "Re-adding somepkg-1.1 ..." and an error, where it should have
re-added "somepkg-1.0".
>Fix:
I started to work on this, but got lost in the reused code of replace-*
centered around the reuse of the oldname/newname files. Perhaps instead
a separate "from"/"to" name pair should be used for the shared ops?