diff --git a/doc/manual.xml b/doc/manual.xml index 2b4f47aff1c..de663fcd5b6 100644 --- a/doc/manual.xml +++ b/doc/manual.xml @@ -12,6 +12,7 @@ + diff --git a/doc/multiple-output.xml b/doc/multiple-output.xml new file mode 100644 index 00000000000..00b6614775a --- /dev/null +++ b/doc/multiple-output.xml @@ -0,0 +1,91 @@ + + +]> + + +Multiple-output packages + +
Introduction + The Nix language allows a derivation to produce multiple outputs, which is similar to what is utilized by other Linux distribution packaging systems. The outputs reside in separate nix store paths, so they can be mostly handled independently of each other, including passing to build inputs, garbage collection or binary substitution. The exception is that building from source always produces all the outputs. + The main motivation is to save disk space by reducing runtime closure sizes; consequently also sizes of substituted binaries get reduced. Splitting can be used to have more granular runtime dependencies, for example the typical reduction is to split away development-only files, as those are typically not needed during runtime. As a result, closure sizes of many packages can get reduced to a half or even much less. + Similarly to other packaging systems, the reduction effects could be instead achieved by building the parts in completely separate derivations. That would often additionally reduce build-time closures, but it would be much harder to write such derivations, due to build systems assuming all parts are being built at once. +
+ +
Installing a split package + When installing a package via systemPackages or nix-env you have several options: + Currently nix-env almost always installs all outputs until https://github.com/NixOS/nix/pull/815 gets merged. + + You can install particular outputs explicitly, as each is available in the Nix language as an attribute of the package. The outputs attribute contains a list of output names. + You can let it use the default outputs. These are handled by meta.outputsToInstall attribute that contains a list of output names. + TODO: more about tweaking the attribute, etc. + NixOS provides configuration option environment.extraOutputsToInstall that allows adding extra outputs of environment.systemPackages atop the default ones. It's mainly meant for documentation and debug symbols, and it's also modified by specific options. + At this moment there is no similar configurability for packages installed by nix-env. You can still use approach from to override meta.outputsToInstall attributes, but that's a rather inconvenient way. + + +
+ +
Using a split package + In the Nix language the individual outputs can be reached explicitly as attributes, e.g. coreutils.info, but the typical case is just using packages as build inputs. + When a multiple-output derivation gets into a build input of another derivation, the first output is added (.dev by convention) and also propagatedBuildOutputs of that package which by default contain $outputBin and $outputLib. (See .) +
+ + +
Writing a split derivation + Here you find how to write a derivation that produces multiple outputs. + In nixpkgs there is a framework supporting multiple-output derivations. It tries to cover most cases by default behavior. You can find the source separated in <nixpkgs/pkgs/build-support/setup-hooks/multiple-outputs.sh>; it's relatively well-readable. The whole machinery is triggered by defining the outputs attribute to contain the list of desired output names (strings). + outputs = [ "dev" "out" "bin" "doc" ]; + Often such a single line is enough. For each output an equally named environment variable is passed to the builder and contains the path in nix store for that output. By convention, the first output should usually be dev; typically you also want to have the main out output, as it catches any files that didn't get elsewhere. + + There is a special handling of the debug output, described at . + +
+ File type groups + The support code currently recognizes some particular kinds of outputs and either instructs the build system of the package to put files into their desired outputs or it moves the files during the fixup phase. Each group of file types has an outputFoo variable specifying the output name where they should go. If that variable isn't defined by the derivation writer, it is guessed – a default output name is defined, falling back to other possibilities if the output isn't defined. + + + $outputDev + is for development-only files. These include C(++) headers, pkg-config, cmake and aclocal files. They go to dev or out by default. + + + $outputBin + is meant for user-facing binaries, typically residing in bin/. They go to bin or out by default. + + + $outputLib + is meant for libraries, typically residing in lib/ and libexec/. They go to lib or out by default. + + + $outputDoc + is for user documentation, typically residing in share/doc/. It goes to doc or out by default. + + + $outputDocdev + is for developer documentation. Currently we count gtk-doc and man3 pages in there. It goes to docdev or is removed (!) by default. This is because e.g. gtk-doc tends to be rather large and completely unused by nixpkgs users. + + + $outputMan + is for man pages (except for section 3). They go to man or doc or $outputBin by default. + + + $outputInfo + is for info pages. They go to info or doc or $outputMan by default. + + +
+ +
Common caveats + + Some configure scripts don't like some of the parameters passed by default by the framework, e.g. --docdir=/foo/bar. You can disable this by setting setOutputFlags = false;. + The outputs of a single derivation can retain references to each other, but note that circular references are not allowed. (And each strongly-connected component would act as a single output anyway.) + Most of split packages contain their core functionality in libraries. These libraries tend to refer to various kind of data that typically gets into out, e.g. locale strings, so there is often no advantage in separating the libraries into lib, as keeping them in out is easier. + Some packages have hidden assumptions on install paths, which complicates splitting. + +
+ +
+ +
+ diff --git a/doc/stdenv.xml b/doc/stdenv.xml index f8d9acb2fb0..136e83ee0cd 100644 --- a/doc/stdenv.xml +++ b/doc/stdenv.xml @@ -956,7 +956,7 @@ following: phase. - + separateDebugInfo If set to true, the standard environment will enable debug information in C/C++ builds. After