From owner-freebsd-hackers@FreeBSD.ORG Sat May 2 12:46:54 2009 Return-Path: Delivered-To: freebsd-hackers@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 5891A1065674 for ; Sat, 2 May 2009 12:46:53 +0000 (UTC) (envelope-from yanefbsd@gmail.com) Received: from yx-out-2324.google.com (yx-out-2324.google.com [74.125.44.28]) by mx1.freebsd.org (Postfix) with ESMTP id E141F8FC18 for ; Sat, 2 May 2009 12:46:52 +0000 (UTC) (envelope-from yanefbsd@gmail.com) Received: by yx-out-2324.google.com with SMTP id 8so1782542yxb.13 for ; Sat, 02 May 2009 05:46:52 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=gamma; h=domainkey-signature:mime-version:received:in-reply-to:references :date:message-id:subject:from:to:cc:content-type :content-transfer-encoding; bh=hLJW5AATvXNM48nW/9bm79sQMb7dAfcXdpy8OArrPxA=; b=jdqaIjZ175ca8wEVyBqx0VakXSeEKzzSkyBrKKskBUjBfF9++S3XPH/P69l2EDoRaA yDACJhKs6H4ss09ewxpZ+z3SS+kmelNMRy5AUuxFDrDsvhHxf7BqJkYh0onyajU6XBc4 KxItricenN1t8qqvqbnxJE5slLV5zb3CMbcnk= DomainKey-Signature: a=rsa-sha1; c=nofws; d=gmail.com; s=gamma; h=mime-version:in-reply-to:references:date:message-id:subject:from:to :cc:content-type:content-transfer-encoding; b=oSkcvPn2CxZVH72HH7bPdXCGsWx4nHdYVCmdiHlVFRxCxb/xGrIr3965LLpcghETWj l8rxweFnDRt/G9ouRknKxCX9b8180X8F816AVWzO9EaGujh7/GG51sphNkhZjNxEhekL RH6qI3InjkElDI0BZkdAPxiTTuGAyrzV43qtE= MIME-Version: 1.0 Received: by 10.150.189.2 with SMTP id m2mr7853363ybf.38.1241268412046; Sat, 02 May 2009 05:46:52 -0700 (PDT) In-Reply-To: <20090430214520.GA37974@flint.openpave.org> References: <20090430214520.GA37974@flint.openpave.org> Date: Sat, 2 May 2009 05:46:52 -0700 Message-ID: <7d6fde3d0905020546s697ad5f6r2098ff6c80a80e1e@mail.gmail.com> From: Garrett Cooper To: Jeremy Lea Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: quoted-printable Cc: David Forsythe , freebsd-hackers@freebsd.org, kientzle@freebsd.org Subject: Re: SoC2009: libpkg, pkg tools rewrite X-BeenThere: freebsd-hackers@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Technical Discussions relating to FreeBSD List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sat, 02 May 2009 12:46:54 -0000 On Thu, Apr 30, 2009 at 2:45 PM, Jeremy Lea wrote: > Hi, > > On Sat, Apr 25, 2009 at 03:20:59PM -0400, David Forsythe wrote: >> This summer I'll be working on creating a package library and using >> that library to rewrite the pkg tools. =A0A package library has been >> discussed and even started before, but FreeBSD still does not have >> one. =A0This summer I'd like to get enough of the library done to atle >> ast have a new set of pkg tools completed with the current features, >> but ideally I'd like to get far enough to splice in some of the ideas >> I have for new features. > > Since I've already done most of the work on this already, please, > please, please, don't ignore what I have done. =A0I know that it is not > perfect, and that it is now five plus years out of date. =A0But I have > covered half of the bullet points on your to-do list already. > > The code is at http://sourceforge.net/projects/fpkg and some README > stuff is at http://fpkg.sourceforge.net/ > > Some things which I think are critical: > > 1. The library needs a global "package manager". =A0This needs to perform > all of the tasks, and it should ideally do this through a task queue > (which I didn't implement). =A0See the lib/lib.h header in FreePKG. > > 2. The package manager must be able to separate out a structure of > variables which can be determined without opening the +CONTENTS file. > This must also include a package state, and the package manager must > move these package headers from state to state. > > 3. There needs to be proper depends handling in the packages, so that we > can maintain the correct dependency graph. =A0This is vital for upgrading= . > This means adding @libdep and @filedep types to the package file. > > 4. bsd.port.mk should do everything through the tools. =A0It should have > no knowledge of the contents of /var/db/pkg. > > These are all done, to some degree in the code. =A0The mistakes I made: > > 1. I made the file->pkg database to sensitive. =A0If there is a miss it > rebuilds the database for scratch - it should do a search through the > +CONTENTS files and only rebuild it if there was a hit (meaning the > database was wrong). > > 2. There needs to be a pkgname and origin database, which can be loaded > at startup to prime the package manager. =A0The dependency graph should > also be stored in a database. =A0These should be rebuilt if any directory > in /var/db/pkg has a mtime later than the database (so could the file > database). > > 3. There needs to be a set of flags which indicate how a package got > installed (as a dependency or by the user), and if it has been upgraded > in-place and might have old leftover libraries. =A0These could go in > +CONTENTS. > > In addition I also began the design of a new on disk package format. > This was back when there was a group called openpackages which was > trying to standardize ports/packages between the BSDs. =A0In particular i= t > has some ideas on package signing, which is an often requested feature. > > http://people.freebsd.org/~reg/opdesign.html > > Regards, > =A0-Jeremy There's also http://libpkg.berlios.de/ that you could use as a starting point, and please, PLEASE, don't neglect the SoC work that was done last year by Anders Nore. It was committed to p4, but hasn't made it upstream to CVS yet... Also, don't fall into the trap I fell into 2 years ago by trying to reinvent the wheel. Plenty of people have been down this road already, and can help you in finding your way if you ask. Best of luck, -Garrett