| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148 | Paper Build System==================Entry Point-----------The entry point for using the paper build system is the main script in the rootdirectory, named after the build system (paper, libreboot, etc).Running the main script with no argument will show its general usage.Configuration-------------The paper build system can be configured with a script named after the buildsystem (paper, libreboot, etc) with a ".conf" suffix. It is automatically loadedby the build system when running the main script.It contains environment variables assigned to the desired values. The list ofenvironment variables is shown in the main script's general usage.Project and Tool Targets------------------------The build system works around the concepts of projects and tools, that definespecific components that can be used to produce either:* sources* systems* images* toolsVarious actions are available for each project and tool targets, many of whichare shown in the main script's general usage. Each project and tool may providea usage action that allows to see the specific usage for it. Actions areexecuted recursively when no targets are specified.Each project and tool target has its own directory (either in projects or tools)that contain a script named after the target and possible a helper script, namedafter the script with a "-helper" suffix. The helper script is automaticallyincluded by the build system. Functions in helper scripts are usually prefixedwith the name of the target, where "-" symbols are replaced with "_" symbols.Each project and tool target's actions are functions defined in the target'sspecific script, with names matching the target's actions.Meta-Targets------------Meta targets are project and tool targets that apply the requested action toindividual targets, allowing to execute an action to many targets at once.For instance, a meta-target named after the build system with a "-all" suffixwould call other meta-targets, prefixed with "-images", "-tools", etc that wouldthen perform the requested action to all underlying targets.Projects Actions----------------Various generic actions allow preparing projects through a series of steps:* downloading, extracting or updating the project's sources* building the project to a build directory* installing the project to an install directory* releasing the project to a release directory* cleaning the build, install and release directoriesActions can be checked by a matching project-specific function, named after thefunction to check with a "_check" suffix, to determine whether it is necessaryto run them again to follow the steps. An environment variable can force actionsto be executed, by specifying a space-separated list of projects:PROJECTS_FORCE.Projects Configuration and Patches----------------------------------Configuration for each project is stored in each project's own directory.Targets for each project are defined with a "targets" file in each directoryof the "configs" directory. Targets are read recursively, followingsub-directory names for project targets.Each project's configuration directory can be used to hold target-specificinformation and configuration.An "install" file in each sub-directory indicated which files to grab from thebuild files and where to install them in the install directory.Projects Sources----------------Each project can either download specific sources or use another project'ssources, possibly providing its own revision and patches.Sources are downloaded with the "download" action or can be extracted fromreleased sources (after placing the sources in the sources directory) with the"extract" action.Projects may also keep their sources in a "sources" directory in theirproject-specific directory.Projects Build--------------Each project is built to a build directory, named after the project, with thelist of targets separated by a "-" symbol.An environment variable allows controlling the number of tasks to run at thesame time: TASKS.Projects Install----------------Projects are installed from "install" files in the project directory, thatcopies the selected built files to the install directory, named after theproject, with the list of targets separated by a "-" symbol. These install filesare read recursively, following sub-directory names for project targets.Additional files to install can be specified in the "install" directory anddescribed in an "install" file. These install files are read recursively,following sub-directory names for project targets.Projects Release----------------Projects are released to a release directory, named after the project, with thelist of targets separated by a "-" symbol. Each project's install files arepacked into a tarball to the corresponding release directory. A checksum and aGPG detached signature (if the RELEASE_KEY environment variable is set) are alsogenerated.Tarballs are generated reproducibly, from a list of files stored in the".tarfiles" file. They may also contain the ".epoch", git ".revision" and".version" files.Tools Actions-------------Tools are used for maintaining the build system, for performing routine tasksthat can be automated. They may have specific actions and not implement any ofthe generic actions.Actions can be checked by a matching tool-specific function, named after thefunction to check with a "_check" suffix, to determine whether it is necessaryto run them again to follow the steps. An environment variable can force actionsto be executed, by specifying a space-separated list of tasks: TASKS_FORCE.Tools Sources-------------Tools may keep their sources in a "sources" directory in their tool-specificdirectory. These sources may be updated with the "update" action.
 |