diff --git a/doc/manual/conf-file.xml b/doc/manual/conf-file.xml index 82bc025bcd..f56cc27264 100644 --- a/doc/manual/conf-file.xml +++ b/doc/manual/conf-file.xml @@ -364,6 +364,18 @@ build-use-chroot = /dev /proc /bin + force-manifest + + If this option is set to false + (default) and a Nix channel provides both a manifest and a binary + cache, only the binary cache will be used. If set to + true, the manifest will be fetched as well. + This is useful if you want to use binary patches (which are + currently not supported by binary caches). + + + + system This option specifies the canonical Nix system diff --git a/scripts/nix-channel.in b/scripts/nix-channel.in index 7e50dac1e3..61ac823eb1 100755 --- a/scripts/nix-channel.in +++ b/scripts/nix-channel.in @@ -6,6 +6,8 @@ use File::Path qw(mkpath); use Nix::Config; use Nix::Manifest; +Nix::Config::readConfig; + my $manifestDir = $Nix::Config::manifestDir; @@ -102,10 +104,15 @@ sub update { # Check if the channel advertises a binary cache. my $binaryCacheURL = `$Nix::Config::curl --silent '$url'/binary-cache-url`; my $extraAttrs = ""; + my $getManifest = ($Nix::Config::config{"force-manifest"} // "false") eq "true"; if ($? == 0 && $binaryCacheURL ne "") { $extraAttrs .= "binaryCacheURL = \"$binaryCacheURL\"; "; deleteOldManifests($origUrl, undef); } else { + $getManifest = 1; + } + + if ($getManifest) { # No binary cache, so pull the channel manifest. mkdir $manifestDir, 0755 unless -e $manifestDir; die "$0: you do not have write permission to `$manifestDir'!\n" unless -W $manifestDir;