Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 3 Dec 2008 23:19:03 +0100
From:      Peter Schuller <peter.schuller@infidyne.com>
To:        Sean McAfee <smcafee@collaborativefusion.com>
Cc:        freebsd-ports@freebsd.org
Subject:   Re: Deterministic package building with ports
Message-ID:  <20081203221903.GA57472@hyperion.scode.org>
In-Reply-To: <4936F9A4.8030504@collaborativefusion.com>
References:  <20081203210233.GA55633@hyperion.scode.org> <20081203211627.GA56450@hyperion.scode.org> <4936F9A4.8030504@collaborativefusion.com>

next in thread | previous in thread | raw e-mail | index | archive | help

--yrj/dFKFPuw6o+aM
Content-Type: text/plain; charset=us-ascii
Content-Disposition: inline
Content-Transfer-Encoding: quoted-printable

> On the "donor" system:
> 1. portupgrade -a
> 2. for a in `pkg_info -ao | awk '{ print $1 }'` ; do pkg_create -b $a ; d=
one
> 3. Push packages up to NFS'ed ports tree host's /usr/ports/packages
>=20
> On the remaining systems, it's just a matter of running portupgrade -aPP.

Thanks! It helps to know what people are doing in practice.

The problem I have with this is the 'portupgrade -a'
step. portupgrade, in my experience, has sever issues with consistenty
relative to the actual ports tree in dependencies and figuring out
correctly what needs to be built and not. In addition, '-a' only
upgrades individual ports that have changed; not ports depending on
them.

You can do -arR instead or similar, but that does not help because the
process is not re-startable. I have not found out a way to make
portupgrade ensure that installed packages are what you would have
gotten had you installed your packages on a clean system from scratch.

This latter is what portmanager tries to do. While I like the idea for
in-place updating on a system, it has no supports for building
packages, and it too has its own set of issues with respect to
deciding what to upgrade and in what order.

portupgrade also does not support the concept of maintaining a list of
packages that you specifically want. This leads to problems over time
as dependency ports move around, disappear and have files moving
between them.

Both tools, portmanager and portupgrade, have always ended up, for me,
leading to a subset of broken packages that won't build or install for
various reasons - with said set growing larger over time.

The only method I have found which allows me to build and install
ports in a way which mostly works, assuming the port is not broken, is
to do "clean slate" installations.

However, just doing "for origin in $(cat somelist) ; do cd ... ; make
package-recusrive clean" and similar solutions have issues, including
non-restability and issues with recursion and duplicate work/package
creation. This is what I am trying to automate with my shell
hacks... which again *mostly* work, but not quite either.

--=20
/ Peter Schuller

PGP userID: 0xE9758B7D or 'Peter Schuller <peter.schuller@infidyne.com>'
Key retrieval: Send an E-Mail to getpgpkey@scode.org
E-Mail: peter.schuller@infidyne.com Web: http://www.scode.org


--yrj/dFKFPuw6o+aM
Content-Type: application/pgp-signature
Content-Disposition: inline

-----BEGIN PGP SIGNATURE-----
Version: GnuPG v2.0.9 (FreeBSD)

iEYEARECAAYFAkk3BdYACgkQDNor2+l1i31ETQCg8DuWh8eLEMpbdyCak2v4gkqw
sk0An2yQnp8HVM6pA00XmslvIlxgoYJS
=RT8z
-----END PGP SIGNATURE-----

--yrj/dFKFPuw6o+aM--



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20081203221903.GA57472>