NetBSD Problem Report #48620
From email@example.com Wed Feb 26 15:34:55 2014
Received: from mail.netbsd.org (mail.netbsd.org [220.127.116.11])
(using TLSv1 with cipher DHE-RSA-AES256-SHA (256/256 bits))
(Client CN "mail.netbsd.org", Issuer "Postmaster NetBSD.org" (verified OK))
by mollari.NetBSD.org (Postfix) with ESMTPS id 74133A583C
for <gnats-bugs@gnats.NetBSD.org>; Wed, 26 Feb 2014 15:34:55 +0000 (UTC)
Date: Wed, 26 Feb 2014 16:33:24 +0100 (CET)
From: Thomas Klausner <wiz@NetBSD.org>
Reply-To: Thomas Klausner <wiz@NetBSD.org>
Subject: pkgin loses dependency information in pkg_install database
>Synopsis: pkgin loses dependency information in pkg_install database
>Arrival-Date: Wed Feb 26 15:35:00 +0000 2014
>Last-Modified: Wed Feb 26 15:39:48 +0000 2014
>Originator: Thomas Klausner
>Release: NetBSD 6.99.32
Curiosity is the very basis of education and if you tell me that
curiosity killed the cat, I say only that the cat died nobly.
- Arnold Edinborough
When using 'pkgin fug' to update packages, they lose the information by what packages
they are needed, while the packages needing them still know about this.
This causes problems later-on. For example, when you do pkg_delete -r, not all
depending packages are removed.
Upgrade a package that is used by another one.
Example, after upgrading isl with 'pkgin fug':
# pkg_info isl
Information for isl-0.12.2:
Integer set library required by gcc graphite
isl is a library for manipulating sets and relations of integer
points bounded by linear constraints. Supported operations on sets
include intersection, union, set difference, emptiness check, convex
hull, (integer) affine hull, integer projection, and computing the
lexicographic minimum using parametric integer programming. It also
includes an ILP solver based on generalized basis reduction.
# pkg_info gcc48
Information for gcc48-4.8.2nb1:
The GNU Compiler Collection (GCC) - 4.8 Release Series
The GNU Compiler Collection (GCC) includes front ends for C, C++, Objective-C,
Fortran, Java, and Go, as well as libraries for these languages (libstdc++,
libgcj,...). This package provides the snapshot relases of version 4.8.
See http://gcc.gnu.org/gcc-4.8/changes.html for changes relative to 4.7.x.
So isl doesn't know that gcc48 needs it, but gcc48 still remembers.
Do what 'make replace' does.
Move the file with the dependency information aside and restore it after
updating the package.
For bonus points: mark the depending packages with unsafe_depends, like
Responsible-Changed-When: Wed, 26 Feb 2014 15:39:48 +0000
Please fix this!
$NetBSD: query-full-pr,v 1.39 2013/11/01 18:47:49 spz Exp $
$NetBSD: gnats_config.sh,v 1.8 2006/05/07 09:23:38 tsutsui Exp $
Copyright © 1994-2007
The NetBSD Foundation, Inc. ALL RIGHTS RESERVED.