Index: en_US.ISO8859-1/books/porters-handbook/Makefile =================================================================== --- en_US.ISO8859-1/books/porters-handbook/Makefile +++ en_US.ISO8859-1/books/porters-handbook/Makefile @@ -20,6 +20,9 @@ # XML content SRCS= book.xml +SRCS+= ph-introduction/chapter.xml +SRCS+= ph-build-process/chapter.xml +SRCS+= ph-working-with-files/chapter.xml SRCS+= porting-why/chapter.xml SRCS+= new-port/chapter.xml SRCS+= quick-porting/chapter.xml Index: en_US.ISO8859-1/books/porters-handbook/book.xml =================================================================== --- en_US.ISO8859-1/books/porters-handbook/book.xml +++ en_US.ISO8859-1/books/porters-handbook/book.xml @@ -66,8 +66,14 @@ &chap.porting-why; &chap.new-port; + + &chap.ph-introduction; + &chap.ph-build-process; + &chap.ph-working-with-files; + &chap.quick-porting; &chap.slow-porting; + &chap.makefiles; &chap.special; &chap.flavors; Index: en_US.ISO8859-1/books/porters-handbook/chapters.ent =================================================================== --- en_US.ISO8859-1/books/porters-handbook/chapters.ent +++ en_US.ISO8859-1/books/porters-handbook/chapters.ent @@ -10,6 +10,9 @@ $FreeBSD$ --> + + + Index: en_US.ISO8859-1/books/porters-handbook/ph-build-process/Makefile =================================================================== --- en_US.ISO8859-1/books/porters-handbook/ph-build-process/Makefile +++ en_US.ISO8859-1/books/porters-handbook/ph-build-process/Makefile @@ -0,0 +1,15 @@ +# +# Build the Porters Handbook with just the content from this chapter. +# +# $FreeBSD: head/en_US.ISO8859-1/books/porters-handbook/slow-porting/Makefile 43840 2014-02-09 01:50:53Z trhodes $ +# + +CHAPTERS= ph-build-process/chapter.xml + +VPATH= .. + +MASTERDOC= ${.CURDIR}/../${DOC}.${DOCBOOKSUFFIX} + +DOC_PREFIX?= ${.CURDIR}/../../../.. + +.include "../Makefile" Index: en_US.ISO8859-1/books/porters-handbook/ph-build-process/chapter.xml =================================================================== --- en_US.ISO8859-1/books/porters-handbook/ph-build-process/chapter.xml +++ en_US.ISO8859-1/books/porters-handbook/ph-build-process/chapter.xml @@ -0,0 +1,393 @@ + + + + + Build Process and Port Contents + + + How FreeBSD Makes Ports + + + The FreeBSD ports system uses the make(?) build tool and contains pre-created "build targets" for most of the things that you will need for a given port. Build targets are instructions that tell make(?) how to perform tasks. These tasks include downloading sources, building the software and installation. Build targets for the ports system live under the ports tree under mk/. These files also reference the base FreeBSD make files at ?. For those curious about how the specific targets work, the full documentation is available in the source code. Please refer to the bsd.port.mk file as it is well commented. + + + + + Sage advice from the previous author: + + But do not worry, not many people understand exactly how + bsd.port.mk is working... + :-) + + + + + First, let us describe the sequence of events which occurs when the + user types make for the first time in a given port directory. + + + + + + The fetch target is run. The + fetch target is responsible for + making sure that the tarball exists locally in + DISTDIR. If + fetch cannot find the required + files in DISTDIR it will look up the URL + MASTER_SITES, which is set in the + Makefile, as well as our FTP mirrors where we put distfiles + as backup. It will then attempt to fetch the named + distribution file with FETCH, assuming + that the requesting site has direct access to the Internet. + If that succeeds, it will save the file in + DISTDIR for future use and + proceed. + + + + The extract target is run. + It looks for the port's distribution file (typically a + gzipped tarball) in + DISTDIR and unpacks it into a temporary + subdirectory specified by WRKDIR + (defaults to work). + + + + The patch target is run. + First, any patches defined in PATCHFILES + are applied. Second, if any patch files named + patch-* are + found in PATCHDIR (defaults to the + files subdirectory), they are applied + at this time in alphabetical order. + + + + The configure target is run. + This can do any one of many different things. + + + + If it exists, scripts/configure + is run. + + + + If HAS_CONFIGURE or + GNU_CONFIGURE is set, + WRKSRC/configure is run. + + + + + + The build target is run. + This is responsible for descending into the port's private + working directory (WRKSRC) and building + it. + + + + The stage target is run. + This puts the final set of built files into a temporary + directory (STAGEDIR, see + ). The hierarchy of this directory + mirrors that of the system on which the package will be + installed. + + + + The package target is run. + This creates a package using the files from the temporary + directory created during the + stage target and the port's + pkg-plist. + + + + The install target is run. + This installs the package created during the + package target into the host + system. + + + + + + If more control over the build process is required, additional pre-* and post-* targets can be added to the process + either in the Makefile or by creating a script named as above in the scripts subdirectory. These targets/scripts will be run prior-to or subsequently-to the named target as the prefix implies. + + + For example, if there is a + post-extract target defined in the + Makefile, and a file + pre-build in the + scripts subdirectory, the + post-extract target will be called + after the regular extraction actions, and + pre-build will be executed before + the default build rules are done. It is recommended to + use Makefile targets if the actions are + simple enough, because it will be easier for someone to figure + out what kind of non-default action the port requires. + + + The default actions are done by the + do-something + targets from bsd.port.mk. + For example, the commands to extract a port are in the target + do-extract. If + the default target does not do the job right, redefine the + do-something + target in the Makefile. + + + + +*Authors Note: Should we really be talking about modifying bsd.ports.mk here? + + + + + + + Never modify the main targets (for example, + extract, + configure, etc.). These targets are groupings + that make sure all prior stages are completed and then + call the real targets or scripts. If there is an issue in the extraction process, fix + do-extract, but never ever change + the way extract operates! + Additionally, the target + post-deinstall is invalid and is + not run by the ports infrastructure. + + + + + Now that we have an understanding of what happens when the user executes make + install, let us go through the + recommended steps to create the perfect port. + + + + + + + Basic port structure + +A port is a directory of source files that contains all the information the ports build system needs to generate a new executable on FreeBSD. The following sections describe a typical port containing a package description, the list of files to be installed, a checksum file to validate the items downloaded, a directory of patch files, and of course, a make file. + + + + + <filename>pkg-descr</filename> + + pkg-descr contains a description of the port. The file should concisely explaining what the port does.It should be at least one paragraph, but should not be more than four or five paragraphs. + + + This is not a manual or an + in-depth description on how to use or compile the port! + Please be careful when copying from the + README or manpage. Too + often they are not a concise description of the port or + are in an awkward format. For example, manpages have + justified spacing, which looks particularly bad with + monospaced fonts. + + On the other hand, the content of + pkg-descr must be longer than the COMMENT + line from the Makefile. It must explain in more depth what + the port is all about. + + + A well-written pkg-descr describes + the port completely enough that users would not have to + consult the documentation or visit the website to understand + what the software does, how it can be useful, or what + particularly nice features it has. Mentioning certain + requirements like a graphical toolkit, heavy dependencies, + runtime environment, or implementation languages help users + decide whether this port will work for them. + + Include a URL to the official WWW homepage. Prepend + one of the websites (pick the most + common one) with WWW: (followed by single + space) so that automated tools will work correctly. If the + URI is the root of the website or directory, it must be + terminated with a slash. + + + If the listed webpage for a port is not available, try + to search the Internet first to see if the official site + moved, was renamed, or is hosted elsewhere. + + + This example shows how + pkg-descr looks: + + This is a port of oneko, in which a cat chases a poor mouse all over +the screen. + : +(etc.) + +WWW: http://www.oneko.org/ + + + + <filename>pkg-plist</filename> + + This file lists all the files installed by the port. It + is also called the packing list because the + package is generated by packing the files listed here. The + pathnames are relative to the installation prefix (usually + /usr/local). + + Here is a small example: + + bin/oneko +man/man1/oneko.1.gz +lib/X11/app-defaults/Oneko +lib/X11/oneko/cat1.xpm +lib/X11/oneko/cat2.xpm +lib/X11/oneko/mouse.xpm + + Refer to the &man.pkg-create.8; manual page for details + on the packing list. + + + It is recommended to keep all the filenames in + this file sorted alphabetically. It will make verifying + changes when upgrading the port much easier. + + + + Creating a packing list manually can be a very tedious + task. If the port installs a large numbers of files, + creating the packing list + automatically might save time. + + + There is only one case when + pkg-plist can be omitted from a port. + If the port installs just a handful of files, list them in + PLIST_FILES, within the + port's Makefile. For instance, we + could get along without pkg-plist in + the above oneko port by adding these + lines to the Makefile: + + PLIST_FILES= bin/oneko \ + man/man1/oneko.1.gz \ + lib/X11/app-defaults/Oneko \ + lib/X11/oneko/cat1.xpm \ + lib/X11/oneko/cat2.xpm \ + lib/X11/oneko/mouse.xpm + + + Usage of PLIST_FILES should not be + abused. When looking for the origin of a file, people + usually try to grep through the + pkg-plist files in the ports tree. + Listing files in PLIST_FILES in the + Makefile makes that search more + difficult. + + + + If a port needs to create an empty directory, or creates + directories outside of ${PREFIX} during + installation, refer to + for more information. + + + The price for this way of listing a port's files and + directories is that the keywords described in + &man.pkg-create.8; and cannot + be used. Therefore, it is suitable + only for simple ports and makes them even simpler. At the + same time, it has the advantage of reducing the number of + files in the ports collection. Please consider using this + technique before resorting to + pkg-plist. + + Later we will see how pkg-plist + and PLIST_FILES can be used to fulfill + more sophisticated + tasks. + + + + + The checksum File + + The checksum file contains a number based on a calculation of all the files within the port. This number is used as a tool to verify the contents to ensure the expected files are present. While not a perfect mechanism, it is accurate enough to fulfill the roll of validation but not necessarily tampering protection. Checksum files are created by running the make checksum command within the port folder. + + + + + The Files directory + + The files directory contains the patch files used to update the original sources to allow the system to run on FreeBSD. There are other reasons to create and include patch files but for the sake of this section, "patching the original sources" is an adequate description. The files contained in this directory are "required" to be generated by the make patch target. However, this is a software requirement and manual patching is still an option. + + + + + The <filename>Makefile</filename> + +The Makefile is the entrypoint for the ports system to build the binary package. This makefile is NOT the target application makefile. Rather, this makefile is a meta-package that contains the FreeBSD instructions outlined in the first section of this chapter. This file can contain very complex instructions, but typically includes variables for: +- The port name +- The port version +- Port "meta info" (information about the port) +- Master sources site +- Source code version to retrieve +- Additional build instructions +- Additional make targets + + The minimal Makefile would look + something like this: + + # $FreeBSD$ + +PORTNAME= oneko +DISTVERSION= 1.1b +CATEGORIES= games +MASTER_SITES= ftp://ftp.cs.columbia.edu/archives/X11R5/contrib/ + +MAINTAINER= youremail@example.com +COMMENT= Cat chasing a mouse all over the screen + +.include <bsd.port.mk> + + + In some cases, the Makefile of an + existing port may contain additional lines in the header, + such as the name of the port and the date it was created. + This additional information has been declared obsolete, and + is being phased out. + + + Try to figure it out. Do not worry about the + contents of the $FreeBSD$ + line, it will be filled in automatically by + Subversion when the port is + imported to our main ports tree. A more detailed + example is shown in the + sample Makefile + section. + + + This section is by no means a complete reference to porting. This is intended to give the reader enough information to understand what a port looks like and how the system works. Once again, it is recommended that those seeking more information on the build process and the file contents review the build target information in the bsd.ports.mk file. Now, let us look at the steps to maintain a port. + + + + Index: en_US.ISO8859-1/books/porters-handbook/ph-introduction/Makefile =================================================================== --- en_US.ISO8859-1/books/porters-handbook/ph-introduction/Makefile +++ en_US.ISO8859-1/books/porters-handbook/ph-introduction/Makefile @@ -0,0 +1,15 @@ +# +# Build the Porters Handbook with just the content from this chapter. +# +# $FreeBSD: head/en_US.ISO8859-1/books/porters-handbook/porting-why/Makefile 43840 2014-02-09 01:50:53Z trhodes $ +# + +CHAPTERS= ph-introduction/chapter.xml + +VPATH= .. + +MASTERDOC= ${.CURDIR}/../${DOC}.${DOCBOOKSUFFIX} + +DOC_PREFIX?= ${.CURDIR}/../../../.. + +.include "../Makefile" Index: en_US.ISO8859-1/books/porters-handbook/ph-introduction/chapter.xml =================================================================== --- en_US.ISO8859-1/books/porters-handbook/ph-introduction/chapter.xml +++ en_US.ISO8859-1/books/porters-handbook/ph-introduction/chapter.xml @@ -0,0 +1,134 @@ + + + + + + + + Introduction + The &os; ports system is a combination of tools and source files designed to build and install applications on &os;. While any user is free to download and build the sources themselves, some applications do not target &os; and may require minor modifications to enable them to work correctly. These modifications are known as patches. The ports system allows users to package these patches and distribute them with the correct build instructions, thus allowing other users to duplicate the fixes and run the application. + +The Ports system is a fundamental part of &os;. All binary installations performed by the &man.pkg.8; system pull applications from repositories built with ports (see &man.poudriere.8;). Amazingly, all the port packages are maintained by the user base themselves. Users decide which applications they want included in the ports system and provide a port to share their user experience. It is also users that monitor the upstream application repositories (i.e. the people that created the software) and create fixes to keep the Ports system up to date. + + + +This handbook is designed to explain how the Ports system works at an intermediate to advanced level, and how you can help contribute to the maintenance of this fundamental system on FreeBSD. + + + The Ports Collection appeared in FreeBSD 1.0. It has since spread to + NetBSD and OpenBSD. + + + + + +Porting Tools + +Background Tools + +This handbook requires basic working knowledge of the Ports tools. For more information about the Ports system, please see: + + +https://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/ports.html + + +Ports man link? + + +A complete list of ports is available on the FreeBSD website ports page. + + +More detailed information about the state of various ports can be found through the excellent freshports.org website (The search is in the right hand column halfway down the page): + + +Freshports also provides a view into the building and maintenance of all ports for all Architectures[1] through access to the PortsMon. The PortsMon system plugs into the overall Release Engineering structure to provide notification of build failures and ensure the software is available. To see an example of a port and it's RE information, find a port in freshports and click on the PortsMon link. + + + + +Development Tools + + +In order to create or maintain a "port", there are tools with which the user should be familiar. + + + +Ports Tree - Ports Tree + + +The ports tree is the directory structure of build tools and build instructions (source files) that are used to create the binaries on the target computer. + + +Subversion - Subversion download site + + +While any user with wheel privilege is able to modify the ports files under /usr/loca/ports, this pattern creates complications. If any user on the computer performs a portsnap update, all modifications will be lost. Also, updating these files requires wheel privilege. Performing development using elevated privilege can be both frustrating and dangerous. It is therefore recommended that users download a "development" copy of the ports tree using subversion. This alternate tree can be placed under the users home directory, which gives the user write privileges and differentiates the "base" ports and a users working copies. + + +Information about how to use subversion with FreeBSD is available here: +Using Subversion with FreeBSD +With more detailed instructions at Subversion handbook + + +Getting the Ports Tree Through Subversion +The typical user will want to checkout the latest ports tree. + +#Install subversion +sudo pkg install subversion +... +#Create structure. +#The work folder gives you a place to collect /scripts and /notes directories applicable to your changes and your ports tree. +mkdir -p ~/work/ports +cd ~/work/ports +svn svn://svn.freebsd.org/ports/head/ . + + + + +Issue tracking and Review Tools + +Bugzillahttp://bugs.freebsd.org + + +Bugzilla is the bug tracker used by FreeBSD to keep a master list of issues and tasks pertaining to the maintenance and development of FreeBSD. Users that have issues in the functionality of FreeBSD are encouraged to search the bug list for similar problems. While general internet searches can typically find answers to simple problems, deeper technical problems may have already been identified. If the issue is not in the list, users are encouraged to create a new account and create a bug entry. Duplicates are quickly identified and support can many times be offered. + + +Bugzilla is the tool you will use to make sure your port is working correctly, or look for other ports that you are interested in that may need work. If a port is un-maintained, bugzilla is the place to go to volunteer to maintain the package. + + + +Phabricator - https://reviews.freebsd.org/ + + +Phabricator is a code review tool that has been integrated into the FreeBSD release process to streamline community review and help nurture new developers. FreeBSD users are encouraged (lots of encouragement!) to create an account and observe the development/review/development process that takes place to ensure the quality of the software released. This iterative feedback process is your gateway to getting your port update submitted, and to give you the skills to eventually become a full maintainer with a "Ports Commit Bit". [*] + + + + + +Example Development Process + +An example of how a typical port might be maintained would look like this: + + +Suppose you were using the Lua scripting language and came across a bug on FreeBSD. After doing some research, you noted that the bug has been patched by the upstream maintainer (i.e. the authors) but the port does not seem to contain the fix. + + +Your first stop would be bugs.freebsd.org to search to see if someone else has reported the problem. Depending on the circumstance, there may be some discussions, or perhaps the port doesn't seem to be maintained. After said discussion on the forum, you decide that the patch (and Lua) is important to you and you want others to share your work. Perhaps you discussed it with the port maintainer, and that person asked you to put together a patch. Or perhaps the port is currently un-maintained. Either way, you decide to update the port. + + +After some simple modifications and proper verification using the tools provided, you will have a patch file. This patch file is then submitted through reviews.freebsd.org with a brief written overview of what you have done and why. One or more people will review the patch files and then make comments asking you to make some changes/fixes. Once those changes are in place and everyone is satisfied, the patch is committed to the head revision and is now available after a user updates the ports tree using "ports update". + + +That's it, you've maintained a Port! + + +The next section will describe how the ports system builds the application, what a basic (new) port would look like, and the steps you will take to make changes to a port. Happy Porting! + + Index: en_US.ISO8859-1/books/porters-handbook/ph-working-with-files/Makefile =================================================================== --- en_US.ISO8859-1/books/porters-handbook/ph-working-with-files/Makefile +++ en_US.ISO8859-1/books/porters-handbook/ph-working-with-files/Makefile @@ -0,0 +1,15 @@ +# +# Build the Porters Handbook with just the content from this chapter. +# +# $FreeBSD: head/en_US.ISO8859-1/books/porters-handbook/porting-why/Makefile 43840 2014-02-09 01:50:53Z trhodes $ +# + +CHAPTERS= ph-working-with-files/chapter.xml + +VPATH= .. + +MASTERDOC= ${.CURDIR}/../${DOC}.${DOCBOOKSUFFIX} + +DOC_PREFIX?= ${.CURDIR}/../../../.. + +.include "../Makefile" Index: en_US.ISO8859-1/books/porters-handbook/ph-working-with-files/chapter.xml =================================================================== --- en_US.ISO8859-1/books/porters-handbook/ph-working-with-files/chapter.xml +++ en_US.ISO8859-1/books/porters-handbook/ph-working-with-files/chapter.xml @@ -0,0 +1,152 @@ + + + + + Working With Files + + + Using the Built In Patching Tools + + + Creating a new port involves generating the port files from scratch or copying an existing, similar port. Maintaining a port involves retrieving the latest revisions of the sources, making changes to those sources, and then extracting those changes as a "meta-patch" for the port. The following sections describe the steps involved in maintaining a patch file, with notes to new port maintainers. + + + + The Work Directory + + The work directory is created under the port directory and is used to store "working data". Working data consists of the source files downloaded from the upstream repository, inetermediate build output, as well as the build output itself that can be tested and installed. Source files are downloaded and unpacked to this directory and optionally patched depending on the target. This directory is where you will be performing the majority of your changes to the upstream source files. By using the built in mechanisms and directory structures, you ensure that the tools available can assist in streamlining the update process. + + + + + + + The ports framework provides a makepatch + target, which when run, + automatically creates correctly named and formatted patch files in the + correct location from the modified sources. Here are the steps to maintain a port + + + + + + First, retrieve the source files and optionally apply patches. + + If you wish to preserve or update the existing patches in the port, use the patch target. This target retrieves sources and applies all patches in the + files directory. + + + If you wish to discard the current patches use the + extract target. This target will only + retreive and extract the sources. + + + + + If you chose to run extract and then + decide afterwards that you do want to use the patches, + the best way forward is to ? + + + + + + New port note: + You will need to generate a minimum port structure and Makefile that downloads the sources before you can execute these steps. + + + + + + &prompt.user; cd port-dir + &prompt.user; make patch + &prompt.user; cd work/src-dir + + + + Prior to making changes to the sources files, manually copy the files and add an *.orig extension. + This preserves the original file and allows the system to diff your changes and produce a new port patch. + + + &prompt.user; cp file.ext file.ext.orig + + + *Authors note. I had this work successfully without having done that. I built the patch, made my changes, then ran make makepatch and it worked? + + + + Again, Repeat the above steps for each file at any location within WRKSRC + that needs a patch file created. + + + + + Once your changes are complete, return to the main port directory: + + + &prompt.user; cd port-dir + + + + + + *** make checksum, portlink, ? + + + + + + Finally, run the makepatch target. + + + + &prompt.user; make makepatch + + + + The makepatch target recursively searches WRKSRC for file/file.orig + pairs within WRKSRC, and creates a patch file in PATCHDIR from each pair + (using diff). + + + + + Any pre-existing patches in PATCHDIR that are *not* regenerated + during the above process are placed in a backup location in WRKDIR. This + backup location is deleted on clean. This may occur when not + using patch to extract the sources, because existing patches + are or were not applied, or if there are existing patch files that make + edits to multiple files in a single patch file, which will now be in + separate patch files after makepatch regeneration. Inspect and review + the patch files in PATCHDIR to ensure they have been created as expected. + + + + + + Patch files are stored in PATCHDIR, by default files in the port + directory, which are automatically applied in the patch stage + + + + + + + + + +Submitting a patch + + +The FreeBSD phabrictor review board is the place to submit patches. To submit a patch, create an account and log in. Navigate to Applications -> Code Review. Click the Create Diff file and submit the file generate by makepatch. At this point, others will review and comment on your work. If you are persistent, your patch will be accepted. Make no mistake, changes and difficulty are a normal part of the process of develop/test/report/develop. The people commenting on your work *want* you to be successful and are using their time to help you. If you accept their help and be persistent, you can become a better developer and FreeBSD gains another active port maintainer. + + + + + +