1afb33690SMurray Stokely.\" Copyright (c) 2002 Murray Stokely <murray@FreeBSD.org> 2afb33690SMurray Stokely.\" All rights reserved. 3de26e0adSMurray Stokely.\" 4de26e0adSMurray Stokely.\" Redistribution and use in source and binary forms, with or without 5de26e0adSMurray Stokely.\" modification, are permitted provided that the following conditions 6de26e0adSMurray Stokely.\" are met: 7de26e0adSMurray Stokely.\" 1. Redistributions of source code must retain the above copyright 8de26e0adSMurray Stokely.\" notice, this list of conditions and the following disclaimer. 9de26e0adSMurray Stokely.\" 2. Redistributions in binary form must reproduce the above copyright 10de26e0adSMurray Stokely.\" notice, this list of conditions and the following disclaimer in the 11de26e0adSMurray Stokely.\" documentation and/or other materials provided with the distribution. 12de26e0adSMurray Stokely.\" 13de26e0adSMurray Stokely.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND 14de26e0adSMurray Stokely.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 15de26e0adSMurray Stokely.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 16de26e0adSMurray Stokely.\" ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE 17de26e0adSMurray Stokely.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 18de26e0adSMurray Stokely.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 19de26e0adSMurray Stokely.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 20de26e0adSMurray Stokely.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 21de26e0adSMurray Stokely.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 22de26e0adSMurray Stokely.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 23de26e0adSMurray Stokely.\" SUCH DAMAGE. 24de26e0adSMurray Stokely.\" 25de26e0adSMurray Stokely.\" $FreeBSD$ 26de26e0adSMurray Stokely.\" 27e8423d00SNathan Whitehorn.Dd March 18, 2011 28de26e0adSMurray Stokely.Dt RELEASE 7 29de26e0adSMurray Stokely.Os 30de26e0adSMurray Stokely.Sh NAME 31de26e0adSMurray Stokely.Nm release 32afb33690SMurray Stokely.Nd "release building infrastructure" 33de26e0adSMurray Stokely.Sh DESCRIPTION 34de26e0adSMurray Stokely.Fx 35de26e0adSMurray Stokelyprovides a complete build environment suitable for users to make 36de26e0adSMurray Stokelyfull releases of the 37de26e0adSMurray Stokely.Fx 38994c71f0SMurray Stokelyoperating system. 39de26e0adSMurray StokelyAll of the tools necessary to build a release are available from the 40feacd98eSNathan Whitehorn.Fx 41feacd98eSNathan Whitehornsource code repository in 42de26e0adSMurray Stokely.Pa src/release . 43de26e0adSMurray StokelyA complete release can actually be built with only a single command, 44eee69fccSMurray Stokelyincluding the creation of ISO images suitable for burning to CD-ROM, 45feacd98eSNathan Whitehornmemory stick images, and an FTP install directory. 46de26e0adSMurray StokelyThis command is aptly named 47afb33690SMurray Stokely.Dq Li "make release" . 48de26e0adSMurray Stokely.Pp 49e8423d00SNathan WhitehornFor some users, it may be desirable to provide an absolutely clean 50e8423d00SNathan Whitehornbuild environment, with no local modifications to the source tree or to 51e8423d00SNathan Whitehorn.Xr make.conf 5 , 52e8423d00SNathan Whitehornand with clean checkouts of specific versions of the doc, src, and ports 53e8423d00SNathan Whitehorntrees. For this purpose, a script 54e8423d00SNathan Whitehorn.Pq Pa src/release/generate-release.sh 55e8423d00SNathan Whitehornis provided to automate these checkouts and then execute 56e8423d00SNathan Whitehorn.Dq Li "make release" 57e8423d00SNathan Whitehornin a clean 58e8423d00SNathan Whitehorn.Xr chroot 8 . 59e8423d00SNathan Whitehorn.Pp 60de26e0adSMurray StokelyBefore attempting to build a release, the user is expected to be 61994c71f0SMurray Stokelyfamiliar with the contents of 62de26e0adSMurray Stokely.Xr build 7 , 6347280c4bSRuslan Ermilovand should have experience upgrading systems from source. 64e8423d00SNathan Whitehorn.Pp 65de26e0adSMurray StokelyThe release build process requires that 66de26e0adSMurray Stokely.Pa /usr/obj 67de26e0adSMurray Stokelybe populated with the output of 68*d408a341SNathan Whitehorn.Dq Li "make buildworld" 69*d408a341SNathan Whitehornand 70*d408a341SNathan Whitehorn.Dq Li "make buildkernel" . 71e8423d00SNathan WhitehornThis is necessary to provide the object files for the release or, when 72e8423d00SNathan Whitehornusing 73e8423d00SNathan Whitehorn.Pa generate-release.sh , 74e8423d00SNathan Whitehornso that the object files for a complete system can be installed into a clean 75de26e0adSMurray Stokely.Xr chroot 8 76e8423d00SNathan Whitehornenvironment. In this second case, the built world must be capable of running 77e8423d00SNathan Whitehornon the build system (i.e. it must be for the same architecture and be 78e8423d00SNathan Whitehorncompatible with the installed kernel). 79e8423d00SNathan WhitehornThe release procedure on some architectures may also require that the 80994c71f0SMurray Stokely.Xr md 4 81994c71f0SMurray Stokely(memory disk) device driver be present in the kernel 82919b0026SDavid E. O'Brien(either by being compiled in or available as a module). 83de26e0adSMurray Stokely.Pp 84de26e0adSMurray StokelyThis document does not cover source code management, quality 85de26e0adSMurray Stokelyassurance, or other aspects of the release engineering process. 86e8423d00SNathan Whitehorn.Sh CLEAN RELEASE GENERATION 87e8423d00SNathan WhitehornOfficial releases of FreeBSD are produced in a totally clean environment to 88e8423d00SNathan Whitehornensure consistency between the versions of the src, ports, and doc trees 89e8423d00SNathan Whitehornand to avoid contamination from the host system (e.g. local patches, changes 90e8423d00SNathan Whitehornto 91e8423d00SNathan Whitehorn.Xr make.conf 5 , 92e8423d00SNathan Whitehornetc.). This is accomplished using the wrapper script 93e8423d00SNathan Whitehorn.Pa src/release/generate-release.sh . 94e8423d00SNathan Whitehorn.Pp 95e8423d00SNathan Whitehorn.Ic generate-release.sh 96e8423d00SNathan Whitehornsvn-branch scratch-dir 97e8423d00SNathan Whitehorn.Pp 98e8423d00SNathan Whitehorn.Ic generate-release.sh 99e8423d00SNathan Whitehorncalls 100e8423d00SNathan Whitehorn.Dq Li "make installworld" 101e8423d00SNathan Whitehornto generate a 102e8423d00SNathan Whitehorn.Xr chroot 8 103e8423d00SNathan Whitehornenvironment in 104e8423d00SNathan Whitehorn.Ar scratch-dir . 105e8423d00SNathan WhitehornIt then checks out the src tree specified by 106e8423d00SNathan Whitehorn.Ar svn-branch 107e8423d00SNathan Whitehornusing 108e8423d00SNathan Whitehorn.Xr svn 1 109e8423d00SNathan Whitehornand (optionally) the ports and documentation trees using 110e8423d00SNathan Whitehorn.Xr csup 1 111e8423d00SNathan Whitehornor 112e8423d00SNathan Whitehorn.Xr cvs 1 . 113e8423d00SNathan WhitehornOnce the various source trees have been obtained, it executes 114e8423d00SNathan Whitehorn.Dq Li "make release" 115e8423d00SNathan Whitehornwithin the 116e8423d00SNathan Whitehorn.Xr chroot 8 117e8423d00SNathan Whitehornenvironment and places the result in 118e8423d00SNathan Whitehorn.Pa $scratch-dir/R . 119e8423d00SNathan WhitehornNote that because this uses a chroot, it cannot be used to cross-build 120e8423d00SNathan Whitehorn.Fx 121e8423d00SNathan Whitehornrelease media. 122e8423d00SNathan Whitehorn.Pp 123e8423d00SNathan WhitehornEnvironment variables: 124e8423d00SNathan Whitehorn.Bl -tag -width ".Cm MAKE_FLAGS" 125e8423d00SNathan Whitehorn.It Ev CVSUP_HOST 126e8423d00SNathan WhitehornThe CVSUP server to use for the doc and ports trees. One of 127e8423d00SNathan Whitehorn.Ev CVSUP_HOST 128e8423d00SNathan Whitehornor 129e8423d00SNathan Whitehorn.Ev CVSROOT 130e8423d00SNathan Whitehornmust be specified for ports and documentation to be included in the release. 131e8423d00SNathan Whitehorn.It Ev CVSROOT 132e8423d00SNathan WhitehornThe location of the 133e8423d00SNathan Whitehorn.Fx 134e8423d00SNathan WhitehornCVS repository to use for the doc and ports trees. One of 135e8423d00SNathan Whitehorn.Ev CVSUP_HOST 136e8423d00SNathan Whitehornor 137e8423d00SNathan Whitehorn.Ev CVSROOT 138e8423d00SNathan Whitehornmust be specified for ports and documentation to be included in the release. 139e8423d00SNathan Whitehorn.It Ev CVS_TAG 140e8423d00SNathan WhitehornIf the variable 141e8423d00SNathan Whitehorn.Ev CVS_TAG 142e8423d00SNathan Whitehornis set, that tag will be used for CVS checkouts (doc and ports), otherwise 143e8423d00SNathan Whitehorn.Ic generate-release.sh 144e8423d00SNathan Whitehornwill use HEAD. 145e8423d00SNathan Whitehorn.It Ev MAKE_FLAGS 146e8423d00SNathan WhitehornThis environment variable can be set to pass flags (e.g. -j) to 147e8423d00SNathan Whitehorn.Xr make 1 148e8423d00SNathan Whitehornwhen invoked by the script. 149e8423d00SNathan Whitehorn.It Ev SVNROOT 150e8423d00SNathan WhitehornThe location of the FreeBSD SVN source repository. Defaults to 151e8423d00SNathan Whitehorn.Pa svn://svn.freebsd.org/base . 152e8423d00SNathan Whitehorn.El 153e8423d00SNathan Whitehorn.Sh MAKEFILE TARGETS 154de26e0adSMurray StokelyThe release makefile 155994c71f0SMurray Stokely.Pq Pa src/release/Makefile 156de26e0adSMurray Stokelyis fairly abstruse. 157de26e0adSMurray StokelyMost developers will only be concerned with the 158afb33690SMurray Stokely.Cm release 159299a8b95SNathan Whitehornand 160299a8b95SNathan Whitehorn.Cm install 161299a8b95SNathan Whitehorntargets. 162994c71f0SMurray Stokely.\" XXX: Some sort of introduction to this list? All the others have one. 163e8423d00SNathan Whitehorn.Bl -tag -width ".Cm packagesystem" 164afb33690SMurray Stokely.It Cm release 165e8423d00SNathan WhitehornMeta-target to build all release media and distributions applicable to this 166299a8b95SNathan Whitehornplatform. 167299a8b95SNathan Whitehorn.It Cm install 168299a8b95SNathan WhitehornCopy all produced release media to 169299a8b95SNathan Whitehorn.Pa ${DESTDIR} . 170e8423d00SNathan Whitehorn.It Cm cdrom 171e8423d00SNathan WhitehornBuilds installation CD-ROM images. On some systems, this may require that 172e8423d00SNathan Whitehorn.Xr mkisofs 8 173e8423d00SNathan Whitehornbe installed 174e8423d00SNathan Whitehorn.Pq Pa sysutils/cdrtools 175e8423d00SNathan Whitehornand possibly that the 176e8423d00SNathan Whitehorn.Xr md 4 177e8423d00SNathan Whitehorn(memory disk) device driver be present in the kernel 178e8423d00SNathan Whitehorn(either by being compiled in or available as a module). This target 179299a8b95SNathan Whitehornproduces files called 180e8423d00SNathan Whitehorn.Pa release.iso 181299a8b95SNathan Whitehornand 182299a8b95SNathan Whitehorn.Pa bootonly.iso 183e8423d00SNathan Whitehornas its output. 184e8423d00SNathan Whitehorn.It Cm memstick 185e8423d00SNathan WhitehornBuilds an installation memory stick image named 186e8423d00SNathan Whitehorn.Pa memstick . 187e8423d00SNathan WhitehornNot applicable on all platforms. Requires that the 188e8423d00SNathan Whitehorn.Xr md 4 189e8423d00SNathan Whitehorn(memory disk) device driver be present in the kernel 190e8423d00SNathan Whitehorn(either by being compiled in or available as a module). 191e8423d00SNathan Whitehorn.It Cm ftp 192e8423d00SNathan WhitehornCreates a directory named 193e8423d00SNathan Whitehorn.Pa ftp 194e8423d00SNathan Whitehorncontaining the distribution files used in network installations 195e8423d00SNathan Whitehornand suitable for upload to an FTP mirror. 196de26e0adSMurray Stokely.El 197de26e0adSMurray Stokely.Pp 198e8423d00SNathan WhitehornMajor subtargets called by targets above: 199e8423d00SNathan Whitehorn.Bl -tag -width ".Cm packagesystem" 200e8423d00SNathan Whitehorn.It Cm packagesystem 201e8423d00SNathan WhitehornGenerates all the distribution archives (e.g. base, kernel, ports, doc) 202e8423d00SNathan Whitehornapplicable on this platform. 203e8423d00SNathan Whitehorn.It Cm system 204e8423d00SNathan WhitehornBuilds a bootable installation system containing all the distribution files 205e8423d00SNathan Whitehornpackaged by the 206e8423d00SNathan Whitehorn.Cm packagesystem 207e8423d00SNathan Whitehorntarget, and suitable for imaging by the 208e8423d00SNathan Whitehorn.Cm cdrom 209e8423d00SNathan Whitehornand 210e8423d00SNathan Whitehorn.Cm memstick 211e8423d00SNathan Whitehorntargets. 212e8423d00SNathan Whitehorn.It Cm reldoc 213994c71f0SMurray StokelyBuilds the release documentation. 214994c71f0SMurray StokelyThis includes the release notes, 215e8423d00SNathan Whitehornhardware guide, and installation instructions. Other documentation (e.g. 216e8423d00SNathan Whitehornthe Handbook) is built during the 217e8423d00SNathan Whitehorn.Cm base.txz 218e8423d00SNathan Whitehorntarget invoked by 219e8423d00SNathan Whitehorn.Cm packagesystem. 220de26e0adSMurray Stokely.El 221de26e0adSMurray Stokely.Sh ENVIRONMENT 222de26e0adSMurray StokelyOptional variables: 223e8423d00SNathan Whitehorn.Bl -tag -width ".Va TARGET_ARCH" 224e8423d00SNathan Whitehorn.It Va WORLDDIR 225e8423d00SNathan WhitehornLocation of a directory containing the src tree. By default, the directory 226e8423d00SNathan Whitehornabove the one containing the makefile 227e8423d00SNathan Whitehorn.Pq Pa src . 228e8423d00SNathan Whitehorn.It Va PORTSDIR 229e8423d00SNathan WhitehornLocation of a directory containing the ports tree. By default, 230e8423d00SNathan Whitehorn.Pa /usr/ports . 231e8423d00SNathan WhitehornIf it is unset or cannot be found, ports will not be included in the release. 232e8423d00SNathan Whitehorn.It Va DOCDIR 233e8423d00SNathan WhitehornLocation of a directory containing the doc tree. By default, 234e8423d00SNathan Whitehorn.Pa /usr/doc . 235e8423d00SNathan WhitehornIf it is unset or cannot be found, most documentation will not be included in 236e8423d00SNathan Whitehornthe release; see 237e8423d00SNathan Whitehorn.Ev NODOC 238e8423d00SNathan Whitehornbelow. 239e8423d00SNathan Whitehorn.It Va NOPORTS 240e8423d00SNathan WhitehornIf defined, the Ports Collection will be omitted from the release. 241e8423d00SNathan Whitehorn.It Va NOSRC 242e8423d00SNathan WhitehornIf set, do not include system source code in the release. 2431bcf2f1aSMurray Stokely.It Va NODOC 2448d2a74b6SMurray StokelyIf defined, the SGML-based documentation from the 245de26e0adSMurray Stokely.Fx 246eee69fccSMurray StokelyDocumentation Project will not be built. 247eee69fccSMurray StokelyHowever, the 248eee69fccSMurray Stokely.Dq doc 249eee69fccSMurray Stokelydistribution will still be created with the minimal documentation set 250eee69fccSMurray Stokelyprovided in 251eee69fccSMurray Stokely.Pa src/share/doc . 25225923b97SRuslan Ermilov.It Va TARGET 25325923b97SRuslan ErmilovThe target hardware platform. 25425923b97SRuslan ErmilovThis is analogous to the 25525923b97SRuslan Ermilov.Dq Nm uname Fl m 25625923b97SRuslan Ermilovoutput. 25725923b97SRuslan ErmilovThis is necessary to cross-build some target architectures. 25825923b97SRuslan ErmilovFor example, cross-building for PC98 machines requires 25925923b97SRuslan Ermilov.Va TARGET_ARCH Ns = Ns Li i386 26025923b97SRuslan Ermilovand 26125923b97SRuslan Ermilov.Va TARGET Ns = Ns Li pc98 . 262e8423d00SNathan WhitehornIf not set, 263e8423d00SNathan Whitehorn.Va TARGET 264e8423d00SNathan Whitehorndefaults to the current hardware platform. 265e8423d00SNathan Whitehorn.It Va TARGET_ARCH 266e8423d00SNathan WhitehornThe target machine processor architecture. 267e8423d00SNathan WhitehornThis is analogous to the 268e8423d00SNathan Whitehorn.Dq Nm uname Fl p 269e8423d00SNathan Whitehornoutput. 270e8423d00SNathan WhitehornSet this to cross-build for a different architecture. 271e8423d00SNathan WhitehornIf not set, 272e8423d00SNathan Whitehorn.Va TARGET_ARCH 273e8423d00SNathan Whitehorndefaults to the current machine architecture, unless 274e8423d00SNathan Whitehorn.Va TARGET 275e8423d00SNathan Whitehornis also set, in which case it defaults to the appropriate 276e8423d00SNathan Whitehornvalue for that platform. 277e8423d00SNathan WhitehornTypically, one only needs to set 278e8423d00SNathan Whitehorn.Va TARGET . 279de26e0adSMurray Stokely.El 280de26e0adSMurray Stokely.Sh FILES 281de26e0adSMurray Stokely.Bl -tag -compact 282de26e0adSMurray Stokely.It Pa /usr/doc/Makefile 283de26e0adSMurray Stokely.It Pa /usr/doc/share/mk/doc.project.mk 284de26e0adSMurray Stokely.It Pa /usr/ports/Mk/bsd.port.mk 285de26e0adSMurray Stokely.It Pa /usr/ports/Mk/bsd.sites.mk 286de26e0adSMurray Stokely.It Pa /usr/share/examples/etc/make.conf 287de26e0adSMurray Stokely.It Pa /usr/src/Makefile 288de26e0adSMurray Stokely.It Pa /usr/src/Makefile.inc1 289de26e0adSMurray Stokely.It Pa /usr/src/release/Makefile 290e8423d00SNathan Whitehorn.It Pa /usr/src/release/generate-release.sh 291de26e0adSMurray Stokely.El 292de26e0adSMurray Stokely.Sh EXAMPLES 293e8423d00SNathan WhitehornThe following sequence of commands can be used to build a 294e8423d00SNathan Whitehorn.Dq "-CURRENT snapshot": 295de26e0adSMurray Stokely.Bd -literal -offset indent 296de26e0adSMurray Stokelycd /usr 297e8423d00SNathan Whitehornsvn co svn://svn.freebsd.org/base/head src 298de26e0adSMurray Stokelycd src 299*d408a341SNathan Whitehornmake buildworld buildkernel 300de26e0adSMurray Stokelycd release 3018ef63d0dSNathan Whitehornmake release 3028ef63d0dSNathan Whitehornmake install DESTDIR=/var/freebsd-snapshot 303de26e0adSMurray Stokely.Ed 304de26e0adSMurray Stokely.Pp 305299a8b95SNathan WhitehornAfter running these commands, all produced distribution files (tarballs 306299a8b95SNathan Whitehornfor FTP, CD-ROM images, etc.) are available in the 307299a8b95SNathan Whitehorn.Pa /var/freebsd-snapshot 308de26e0adSMurray Stokelydirectory. 309de26e0adSMurray Stokely.Pp 310994c71f0SMurray StokelyThe following sequence of commands can be used to build a 3111bcf2f1aSMurray Stokely.Dq "-CURRENT snapshot" 312e8423d00SNathan Whitehornin a clean environment, including ports and documentation: 313de26e0adSMurray Stokely.Bd -literal -offset indent 314de26e0adSMurray Stokelycd /usr/src 315de26e0adSMurray Stokelymake buildworld 316de26e0adSMurray Stokelycd release 317e8423d00SNathan Whitehornexport CVSUP_HOST=cvsupN.freebsd.org 318e8423d00SNathan Whitehornsh generate-release.sh head /local3/release 319de26e0adSMurray Stokely.Ed 320e8423d00SNathan Whitehorn.Pp 321e8423d00SNathan WhitehornAfter running these commands, all prepared release files are available in the 322e8423d00SNathan Whitehorn.Pa /local3/release/R 323e8423d00SNathan Whitehorndirectory. 324de26e0adSMurray Stokely.Sh SEE ALSO 325de26e0adSMurray Stokely.Xr cc 1 , 326afb33690SMurray Stokely.Xr cvs 1 , 327de26e0adSMurray Stokely.Xr install 1 , 328de26e0adSMurray Stokely.Xr make 1 , 329594ca9baSTom Rhodes.Xr svn 1 Pq Pa ports/devel/subversion-freebsd , 330de26e0adSMurray Stokely.Xr uname 1 , 331afb33690SMurray Stokely.Xr md 4 , 332de26e0adSMurray Stokely.Xr make.conf 5 , 333de26e0adSMurray Stokely.Xr build 7 , 334de26e0adSMurray Stokely.Xr ports 7 , 335afb33690SMurray Stokely.Xr chroot 8 , 336f5178c4fSMurray Stokely.Xr mtree 8 , 337f5178c4fSMurray Stokely.Xr sysctl 8 338994c71f0SMurray Stokely.Rs 3391bcf2f1aSMurray Stokely.%T "FreeBSD Release Engineering" 340aa4a335bSRuslan Ermilov.%U http://www.FreeBSD.org/doc/en_US.ISO8859-1/articles/releng/ 341994c71f0SMurray Stokely.Re 342994c71f0SMurray Stokely.Rs 3431bcf2f1aSMurray Stokely.%T "FreeBSD Release Engineering of Third Party Packages" 344aa4a335bSRuslan Ermilov.%U http://www.FreeBSD.org/doc/en_US.ISO8859-1/articles/releng-packages/ 345994c71f0SMurray Stokely.Re 346994c71f0SMurray Stokely.Rs 3471bcf2f1aSMurray Stokely.%T "FreeBSD Developers' Handbook" 348aa4a335bSRuslan Ermilov.%U http://www.FreeBSD.org/doc/en_US.ISO8859-1/books/developers-handbook/ 349994c71f0SMurray Stokely.Re 350de26e0adSMurray Stokely.Sh HISTORY 351de26e0adSMurray Stokely.Fx 352de26e0adSMurray Stokely1.x 3531bcf2f1aSMurray Stokelyused a manual checklist, compiled by 3541bcf2f1aSMurray Stokely.An Rod Grimes , 3551bcf2f1aSMurray Stokelyto produce a release. 356de26e0adSMurray StokelyApart from being incomplete, the list put a lot of specific demands on 357de26e0adSMurray Stokelyavailable file systems and was quite torturous to execute. 358de26e0adSMurray Stokely.Pp 359994c71f0SMurray StokelyAs part of the 360994c71f0SMurray Stokely.Fx 2.0 361994c71f0SMurray Stokelyrelease engineering effort, significant 362de26e0adSMurray Stokelyeffort was spent getting 363de26e0adSMurray Stokely.Pa src/release/Makefile 364de26e0adSMurray Stokelyinto a shape where it could at least automate most of the tediousness 365de26e0adSMurray Stokelyof building a release in a sterile environment. 366de26e0adSMurray Stokely.Pp 367e8423d00SNathan WhitehornFor the 368e8423d00SNathan Whitehorn.Fx 9.0 369e8423d00SNathan Whitehornrelease, 370e8423d00SNathan Whitehorn.Pa src/release/Makefile 371e8423d00SNathan Whitehornwas overhauled and the wrapper script 372e8423d00SNathan Whitehorn.Pa src/release/generate-release.sh 373e8423d00SNathan Whitehornintroduced to support the introduction of a new installer. 374e8423d00SNathan Whitehorn.Pp 375594ca9baSTom RhodesAt near 1000 revisions spread over multiple branches, the 376afb33690SMurray Stokely.Xr cvs 1 377994c71f0SMurray Stokelylog of 378994c71f0SMurray Stokely.Pa src/release/Makefile 379994c71f0SMurray Stokelycontains a vivid historical record of some 380de26e0adSMurray Stokelyof the hardships release engineers go through. 381de26e0adSMurray Stokely.Sh AUTHORS 382de26e0adSMurray Stokely.Pa src/release/Makefile 383afb33690SMurray Stokelywas originally written by 384afb33690SMurray Stokely.An -nosplit 385afb33690SMurray Stokely.An Rod Grimes , 386afb33690SMurray Stokely.An Jordan Hubbard , 387afb33690SMurray Stokelyand 388afb33690SMurray Stokely.An Poul-Henning Kamp . 389994c71f0SMurray StokelyThis manual page was written by 390de26e0adSMurray Stokely.An Murray Stokely Aq murray@FreeBSD.org . 391