Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 20 Apr 2016 11:43:00 +0100
From:      Matthew Seaman <matthew@FreeBSD.org>
To:        freebsd-current@freebsd.org
Subject:   Re: [CFT] packaging the base system with pkg(8)
Message-ID:  <7c84f388-21dc-419f-70ce-c5369e294dab@freebsd.org>
In-Reply-To: <20160420094806.GJ6614@zxy.spb.ru>
References:  <E1asbZj-0003Ra-Qs@rmm6prod02.runbox.com> <76093.1461096570@critter.freebsd.dk> <5716AD65.8070007@shrew.net> <BF66EA01-E073-45F0-8F9E-22D57E8871B0@bsdimp.com> <5716FA70.4080604@freebsd.org> <57170E5D.1090701@freebsd.org> <5524F499-5042-407E-9180-43D15A53F3F0@FreeBSD.org> <7621BDAB-A409-456A-A3F1-A6CD9B371DBC@rdsor.ro> <20160420094806.GJ6614@zxy.spb.ru>

next in thread | previous in thread | raw e-mail | index | archive | help
This is an OpenPGP/MIME signed message (RFC 4880 and 3156)
--tlG9f5Rr7vK7Q3CGVPiHcaTdlfiQi4biJ
Content-Type: multipart/mixed; boundary="SSxxrwF6AJFh2g70qw03vxfxno9NVpXmD"
From: Matthew Seaman <matthew@freebsd.org>
To: freebsd-current@freebsd.org
Message-ID: <7c84f388-21dc-419f-70ce-c5369e294dab@freebsd.org>
Subject: Re: [CFT] packaging the base system with pkg(8)
References: <E1asbZj-0003Ra-Qs@rmm6prod02.runbox.com>
 <76093.1461096570@critter.freebsd.dk> <5716AD65.8070007@shrew.net>
 <BF66EA01-E073-45F0-8F9E-22D57E8871B0@bsdimp.com>
 <5716FA70.4080604@freebsd.org> <57170E5D.1090701@freebsd.org>
 <5524F499-5042-407E-9180-43D15A53F3F0@FreeBSD.org>
 <7621BDAB-A409-456A-A3F1-A6CD9B371DBC@rdsor.ro>
 <20160420094806.GJ6614@zxy.spb.ru>
In-Reply-To: <20160420094806.GJ6614@zxy.spb.ru>

--SSxxrwF6AJFh2g70qw03vxfxno9NVpXmD
Content-Type: text/plain; charset=utf-8
Content-Transfer-Encoding: quoted-printable

On 04/20/16 10:48, Slawa Olhovchenkov wrote:

> While number of packages don't see outside internal -- this is
> irrelevant.
> After possibility of update individual package -- nuber of packages is
> impotant.
> Take fresh 11.0. Before 11.1 update only kernel. What you system have?
> 11.0? 11.1-RC3? How you name it? How identify it for take support on
> forum or mail list?
>=20
> How name system, updated all w/o compiler? or only some services?
> Currently we have simple naming:
>=20
> 10.3-RC1, 10.3-RELEASE, 10.3-p7, 10.3-STABLE r123456.
> This is shortly and clearly identify system to anyone.
>=20
> How do this with many packages?

Hmmm.... Good point.

At release time, a set of packages will be generated.  These will all
have the version number of the release eg. 11.0.  That's simple and
unambiguous.

Subsequently adding patches will add a patch level to the version, so
11.0-p1, 11.0-p2 exactly as now.  Only patches that affect the kernel
will cause the output of uname(1) to show the new patch level, but
updates to user land should be reflected in the output of
freebsd-version(1).  That's exactly the same as now, and assuming you,
as an end user, install the default set of FreeBSD packages and apply
all the patches as they come out, then there should be no problem.

This implies that /every/ patchset will include an update to the package
containing freebsd-version.

What packaging base does do is allow you to be selective in the patches
you apply.  So, for instance if patch -p1 was not relevant to you, you
might not install it.  So you could end up with a system where you
hadn't installed patches -p1 -- -p9 but you did install patch -p10.  The
freebsd-version(1) output would presumably show the system as 11.0-p10
-- but that's certainly not the same as a system with all of those
patches -p1 to -p9 applied.  Or you could just install the updated
freebsd-version(1) package and have your system blatantly lie about its
patching status.

So, yes, this does change the meaning of the version number string.
It's morally equivalent to tracking the releng/11.0 branch in SVN but
compiling your system with various WITH_FOO or WITHOUT_BAR flags, and
possible local modifications to the code base to back out certain
commits.  It's still 11.0-SOMETHING but it's not clear exactly what that
something should  be.  Hopefully people that do such things will be
sufficiently technically sophisticated to be able to characterize their
problems based on the versions of any relevant FreeBSD packages.

On the release of 11.1 there would be a complete new set of system
packages generated, and the upgrade process would install the new
versions of those packages all round, even if the content of an
individual package was identical to the one in 11.0.  There's probably a
handy optimization where we compare the before and after checksums for
package files and don't overwrite on disk what is identical between
package versions, but do update all of the bookkeeping in the pkgdb.

	Cheers,

	Matthew







--SSxxrwF6AJFh2g70qw03vxfxno9NVpXmD--

--tlG9f5Rr7vK7Q3CGVPiHcaTdlfiQi4biJ
Content-Type: application/pgp-signature; name="signature.asc"
Content-Description: OpenPGP digital signature
Content-Disposition: attachment; filename="signature.asc"

-----BEGIN PGP SIGNATURE-----

iQIcBAEBCgAGBQJXF101AAoJEABRPxDgqeTnh1wP/RdWDzk1StzV5FY2apDAa7ww
SIhGfCHPnwRE4kGo9R2dTskHkhbLUCGvnhhycUf+XMOG6t1neG3h0esso3pF8WuS
8fl46O+u2gyUSPQ3OdkFvkrb5TMBiI4RdxeiOxS09eQRJZUrnq8n+i3o0l9cymVi
vJ7fhm95x8viIZo0jesGX7FvRZsWYNBTPW5ta1cZvLTX4y65JV2zjZoWoarfiJnH
xqOyPlgr6LStP5KA+au0og0yHcFWduXtVLX/xALEkoMFHYeWQ5YPk0qLAPi1xv4S
AAZ0tAn/y6p3Sc0J7Qs7rGBPZ5rccfcnJ6fEuOMWdEznCN8N0Fn3Q6vD6mpIy1vI
GlUKr2L7T1dPZib48gL6R1Z4HB/67y1gR5eCEeOuhTsuep5FhMc+xi7EoEHqCmFJ
HIOdZn44aOlqeP4AoupccA+LRSeohxMVX0hkjS8zP+yRgInE+RR/57kbUU4hOEB9
7reXqVxSQ4IByfO80VTa5deme1MpJEs5f2IRuQjp8+fpj2OYIeU3CcX4qkrJVz2k
cMYy9KRKhA/YYOQaWJ4OaD0Z1ZINElX5cfoyobCHTFnNsu7cTJGNjIThxJ3KQx2F
QdcJMjBWZ+07FeyAsHEEvQYmv/j0cYijoc9PiXTdp7wYTFKGJlg5qnrwiNBn73P0
0Itxg/iANPBzbxcgFBBt
=9hRt
-----END PGP SIGNATURE-----

--tlG9f5Rr7vK7Q3CGVPiHcaTdlfiQi4biJ--



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?7c84f388-21dc-419f-70ce-c5369e294dab>