Date: Mon, 19 Jul 2004 10:59:36 +0100 From: Matthew Seaman <m.seaman@infracaninophile.co.uk> To: Kris Kennaway <kris@obsecurity.org> Cc: Travis Poppe <tlp@LiquidX.org> Subject: Re: Our package system: "Fundamentally Flawed" - A Linux User. Message-ID: <20040719095936.GA21175@happy-idiot-talk.infracaninophile.co.uk> In-Reply-To: <20040719070953.GA69143@xor.obsecurity.org> References: <20040719002221.21b6b9a3@maya.liquidx.org> <20040719070953.GA69143@xor.obsecurity.org>
next in thread | previous in thread | raw e-mail | index | archive | help
--6TrnltStXW4iwmi0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline Content-Transfer-Encoding: quoted-printable On Mon, Jul 19, 2004 at 12:09:53AM -0700, Kris Kennaway wrote: > On Mon, Jul 19, 2004 at 12:22:21AM -0600, Travis Poppe wrote: > For i386 they're updated every week or so, sometimes more frequently. >=20 > > Are these new > > packages that are being rebuilt automatically defaulted to by pkg_add -= r?=20 >=20 > If you're using -STABLE or -CURRENT, yes. -RELEASE gets package sets > produced at the time of release, which means they are unchanging. However packages for 4.10-STABLE should work on a 4.10-RELEASE box. It seems odd to me that there's no way of overriding the logic in 'pkg_add -r' that chooses the subdirectory of the FTP sites to search for packages. Before I go and try and chip some of the rust off my C programming skills, how does this sound: Add another environment variable 'PACKAGECOLLECTION' that pkg_add(1) refers to. This should be set to the name of one of the subdirectories under ftp://ftp.freebsd.org/pub/FreeBSD/ports/i386/ (Or whatever architecture is appropriate). Values might be: packages-4-stable packages-5.2.1-release packages-current In fact, wotthehell: takes more time to describe than to do. Here's the patch to usr.sbin/pkg_install/add/main.c: --- main.c.orig Mon Jul 19 10:31:16 2004 +++ main.c Mon Jul 19 10:46:17 2004 @@ -256,13 +256,20 @@ if (strlcat(sitepath, u.machine, sizeof(sitepath)) >=3D sizeof(sitepat= h)) return NULL; =20 - reldate =3D getosreldate(); - for(i =3D 0; releases[i].directory !=3D NULL; i++) { - if (reldate >=3D releases[i].lowver && reldate <=3D releases[i].hiver) { - if (strlcat(sitepath, releases[i].directory, sizeof(sitepath)) - >=3D sizeof(sitepath)) - return NULL; - break; + if (getenv("PACKAGECOLLECTION")) { + if (strlcat(sitepath, "/", sizeof(sitepath)) >=3D sizeof(sitepath) || + strlcat(sitepath, getenv("PACKAGECOLLECTION"), sizeof(sitepath)) + >=3D sizeof(sitepath)) + return NULL; + } else { + reldate =3D getosreldate(); + for(i =3D 0; releases[i].directory !=3D NULL; i++) { + if (reldate >=3D releases[i].lowver && reldate <=3D releases[i].hiver= ) { + if (strlcat(sitepath, releases[i].directory, sizeof(sitepath)) + >=3D sizeof(sitepath)) + return NULL; + break; + } } } =20 On this 4.10-STABLE system that gives this effect: % env PACKAGECOLLECTION=3Dpackages-4.10-release pkg_add -n -v -r cvsup-= without-gui looking up ftp.freebsd.org connecting to ftp.freebsd.org:21 setting passive mode opening data connection initiating transfer Fetching ftp://ftp.freebsd.org/pub/FreeBSD/ports/i386/packages-4.10-rel= ease/Latest/cvsup-without-gui.tgz...+CONTENTS +COMMENT +DESC +MTREE_DIRS man/man1/cvpasswd.1.gz man/man1/cvsup.1.gz man/man8/cvsupd.8.gz bin/cvpasswd bin/cvsup sbin/cvsupd share/cvsup/License tar command returns 0 status Done. Cheers, Matthew --=20 Dr Matthew J Seaman MA, D.Phil. 26 The Paddocks Savill Way PGP: http://www.infracaninophile.co.uk/pgpkey Marlow Tel: +44 1628 476614 Bucks., SL7 1TH UK --6TrnltStXW4iwmi0 Content-Type: application/pgp-signature Content-Disposition: inline -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.2.4 (FreeBSD) iD8DBQFA+5uIiD657aJF7eIRAszUAJ9lqNFUGRksHQyA9hNup1PvoE4IfwCfWs70 /7QdFr5ZAVaIU+h8jSj8FMA= =CJum -----END PGP SIGNATURE----- --6TrnltStXW4iwmi0--
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20040719095936.GA21175>