| 3 | | = Build Types and Goals = |
| 4 | | |
| 5 | | == Novice User == |
| 6 | | |
| 7 | | In this build type, a user downloads the tahoe source and everything is as automatic as possible. Internet access is assumed, and there is nothing wrong with using it. |
| 8 | | |
| 9 | | == Developer == |
| 10 | | |
| 11 | | In this build type, someone would like to make changes to tahoe, and gets source from git. TODO |
| 12 | | |
| 13 | | == Packaging System == |
| 14 | | |
| 15 | | In this build type, the build user is a packager of rpms/debs or pkgsrc. Rather than convenience, the concern is a stable and repeatable build that produces exactly the same output bits regardless of which prereqs were already installed. Using the network is not acceptable. |
| 16 | | |
| 17 | | Within a packaging system, there are typically build phases, loosely derived from how autoconf works. |
| 18 | | |
| 19 | | * fetch: obtain the "distfiles" (tarballs published by e.g. the tahoe project) |
| 20 | | * patch: apply OS-local/pkgsrc-local changes (goal is to drive these to zero) |
| 21 | | * configure: search for dependencies and configure paths |
| 22 | | * build: compile sources to object form, run nroff to make man pages, etc. |
| 23 | | * install: place bits either in the running system or in a destdir, suitable for running |
| 24 | | * package: create a binary package from the installed bits |