Use nix-master
This commit is contained in:
parent
aec148383a
commit
059ee08f5c
4 changed files with 49 additions and 21 deletions
13
flake.lock
13
flake.lock
|
@ -1,5 +1,18 @@
|
||||||
{
|
{
|
||||||
"inputs": {
|
"inputs": {
|
||||||
|
"nix": {
|
||||||
|
"inputs": {
|
||||||
|
"nixpkgs": {
|
||||||
|
"inputs": {},
|
||||||
|
"narHash": "sha256-HKuPcp/pBpKNBOnDlrSzObee5eB0LdzhI0RpRjTVxik=",
|
||||||
|
"originalUrl": "nixpkgs/release-19.09",
|
||||||
|
"url": "github:edolstra/nixpkgs/03f3def66a104a221aac8b751eeb7075374848fd"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"narHash": "sha256-wiOmdFFMhuBGEcAURvj7c1LAcVbO82QjcFr+5WjuNzM=",
|
||||||
|
"originalUrl": "nix",
|
||||||
|
"url": "github:NixOS/nix/c7866733d7ce2836fbb43de90dd64d17b0d20753"
|
||||||
|
},
|
||||||
"nixpkgs": {
|
"nixpkgs": {
|
||||||
"inputs": {},
|
"inputs": {},
|
||||||
"narHash": "sha256-HKuPcp/pBpKNBOnDlrSzObee5eB0LdzhI0RpRjTVxik=",
|
"narHash": "sha256-HKuPcp/pBpKNBOnDlrSzObee5eB0LdzhI0RpRjTVxik=",
|
||||||
|
|
26
flake.nix
26
flake.nix
|
@ -5,7 +5,7 @@
|
||||||
|
|
||||||
inputs.nixpkgs.url = "nixpkgs/release-19.09";
|
inputs.nixpkgs.url = "nixpkgs/release-19.09";
|
||||||
|
|
||||||
outputs = { self, nixpkgs }:
|
outputs = { self, nixpkgs, nix }:
|
||||||
|
|
||||||
{
|
{
|
||||||
|
|
||||||
|
@ -14,8 +14,22 @@
|
||||||
nixos-channel-scripts = with final; stdenv.mkDerivation {
|
nixos-channel-scripts = with final; stdenv.mkDerivation {
|
||||||
name = "nixos-channel-scripts";
|
name = "nixos-channel-scripts";
|
||||||
|
|
||||||
buildInputs = with perlPackages;
|
buildInputs = with final.perlPackages;
|
||||||
[ pkgconfig nix sqlite makeWrapper perl FileSlurp LWP LWPProtocolHttps ListMoreUtils DBDSQLite NetAmazonS3 boehmgc nlohmann_json boost ];
|
[ pkgconfig
|
||||||
|
final.nix
|
||||||
|
sqlite
|
||||||
|
makeWrapper
|
||||||
|
perl
|
||||||
|
FileSlurp
|
||||||
|
LWP
|
||||||
|
LWPProtocolHttps
|
||||||
|
ListMoreUtils
|
||||||
|
DBDSQLite
|
||||||
|
NetAmazonS3
|
||||||
|
boehmgc
|
||||||
|
nlohmann_json
|
||||||
|
boost
|
||||||
|
];
|
||||||
|
|
||||||
buildCommand = ''
|
buildCommand = ''
|
||||||
mkdir -p $out/bin
|
mkdir -p $out/bin
|
||||||
|
@ -27,13 +41,13 @@
|
||||||
$(pkg-config --libs nix-main) \
|
$(pkg-config --libs nix-main) \
|
||||||
$(pkg-config --libs nix-expr) \
|
$(pkg-config --libs nix-expr) \
|
||||||
$(pkg-config --libs nix-store) \
|
$(pkg-config --libs nix-store) \
|
||||||
-lsqlite3 -lgc
|
-lsqlite3 -lgc -lnixrust
|
||||||
|
|
||||||
g++ -Os -g ${./index-debuginfo.cc} -Wall -std=c++14 -o $out/bin/index-debuginfo -I . \
|
g++ -Os -g ${./index-debuginfo.cc} -Wall -std=c++14 -o $out/bin/index-debuginfo -I . \
|
||||||
$(pkg-config --cflags nix-main) \
|
$(pkg-config --cflags nix-main) \
|
||||||
$(pkg-config --libs nix-main) \
|
$(pkg-config --libs nix-main) \
|
||||||
$(pkg-config --libs nix-store) \
|
$(pkg-config --libs nix-store) \
|
||||||
-lsqlite3
|
-lsqlite3 -lnixrust
|
||||||
|
|
||||||
cp ${./mirror-nixos-branch.pl} $out/bin/mirror-nixos-branch
|
cp ${./mirror-nixos-branch.pl} $out/bin/mirror-nixos-branch
|
||||||
wrapProgram $out/bin/mirror-nixos-branch --set PERL5LIB $PERL5LIB --prefix PATH : ${wget}/bin:${git}/bin:${nix}/bin:${gnutar}/bin:${xz}/bin:${rsync}/bin:${openssh}/bin:$out/bin
|
wrapProgram $out/bin/mirror-nixos-branch --set PERL5LIB $PERL5LIB --prefix PATH : ${wget}/bin:${git}/bin:${nix}/bin:${gnutar}/bin:${xz}/bin:${rsync}/bin:${openssh}/bin:$out/bin
|
||||||
|
@ -46,7 +60,7 @@
|
||||||
|
|
||||||
defaultPackage.x86_64-linux = (import nixpkgs {
|
defaultPackage.x86_64-linux = (import nixpkgs {
|
||||||
system = "x86_64-linux";
|
system = "x86_64-linux";
|
||||||
overlays = [ self.overlay ];
|
overlays = [ nix.overlay self.overlay ];
|
||||||
}).nixos-channel-scripts;
|
}).nixos-channel-scripts;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
|
@ -49,13 +49,13 @@ void mainWrapped(int argc, char * * argv)
|
||||||
auto binaryCache = openStore(binaryCacheUri).cast<BinaryCacheStore>();
|
auto binaryCache = openStore(binaryCacheUri).cast<BinaryCacheStore>();
|
||||||
|
|
||||||
/* Get the allowed store paths to be included in the database. */
|
/* Get the allowed store paths to be included in the database. */
|
||||||
auto allowedPaths = tokenizeString<PathSet>(readFile(storePathsFile, true));
|
auto allowedPaths = binaryCache->parseStorePathSet(tokenizeString<PathSet>(readFile(storePathsFile, true)));
|
||||||
|
|
||||||
PathSet allowedPathsClosure;
|
StorePathSet allowedPathsClosure;
|
||||||
binaryCache->computeFSClosure(allowedPaths, allowedPathsClosure);
|
binaryCache->computeFSClosure(allowedPaths, allowedPathsClosure);
|
||||||
|
|
||||||
printMsg(lvlInfo, format("%d top-level paths, %d paths in closure")
|
printMsg(lvlInfo, "%d top-level paths, %d paths in closure",
|
||||||
% allowedPaths.size() % allowedPathsClosure.size());
|
allowedPaths.size(), allowedPathsClosure.size());
|
||||||
|
|
||||||
FileCache fileCache(cacheDbPath);
|
FileCache fileCache(cacheDbPath);
|
||||||
|
|
||||||
|
@ -104,24 +104,25 @@ void mainWrapped(int argc, char * * argv)
|
||||||
|
|
||||||
/* For each store path, figure out the package with the shortest
|
/* For each store path, figure out the package with the shortest
|
||||||
attribute name. E.g. "nix" is preferred over "nixStable". */
|
attribute name. E.g. "nix" is preferred over "nixStable". */
|
||||||
std::map<Path, DrvInfo *> packagesByPath;
|
std::map<StorePath, DrvInfo *> packagesByPath;
|
||||||
|
|
||||||
for (auto & package : packages)
|
for (auto & package : packages)
|
||||||
try {
|
try {
|
||||||
auto outputs = package.queryOutputs(true);
|
auto outputs = package.queryOutputs(true);
|
||||||
|
|
||||||
for (auto & output : outputs) {
|
for (auto & output : outputs) {
|
||||||
if (!allowedPathsClosure.count(output.second)) continue;
|
auto storePath = binaryCache->parseStorePath(output.second);
|
||||||
auto i = packagesByPath.find(output.second);
|
if (!allowedPathsClosure.count(storePath)) continue;
|
||||||
|
auto i = packagesByPath.find(storePath);
|
||||||
if (i != packagesByPath.end() &&
|
if (i != packagesByPath.end() &&
|
||||||
(i->second->attrPath.size() < package.attrPath.size() ||
|
(i->second->attrPath.size() < package.attrPath.size() ||
|
||||||
(i->second->attrPath.size() == package.attrPath.size() && i->second->attrPath < package.attrPath)))
|
(i->second->attrPath.size() == package.attrPath.size() && i->second->attrPath < package.attrPath)))
|
||||||
continue;
|
continue;
|
||||||
packagesByPath[output.second] = &package;
|
packagesByPath.emplace(std::move(storePath), &package);
|
||||||
}
|
}
|
||||||
} catch (AssertionError & e) {
|
} catch (AssertionError & e) {
|
||||||
} catch (Error & e) {
|
} catch (Error & e) {
|
||||||
e.addPrefix(format("in package ‘%s’: ") % package.attrPath);
|
e.addPrefix(fmt("in package ‘%s’: ", package.attrPath));
|
||||||
throw;
|
throw;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -203,7 +204,7 @@ void mainWrapped(int argc, char * * argv)
|
||||||
ThreadPool threadPool(16);
|
ThreadPool threadPool(16);
|
||||||
|
|
||||||
for (auto & i : packagesByPath)
|
for (auto & i : packagesByPath)
|
||||||
threadPool.enqueue(std::bind(doPath, i.first, i.second));
|
threadPool.enqueue(std::bind(doPath, binaryCache->printStorePath(i.first), i.second));
|
||||||
|
|
||||||
threadPool.process();
|
threadPool.process();
|
||||||
|
|
||||||
|
|
|
@ -29,7 +29,7 @@ void mainWrapped(int argc, char * * argv)
|
||||||
if (hasSuffix(binaryCacheUri, "/")) binaryCacheUri.pop_back();
|
if (hasSuffix(binaryCacheUri, "/")) binaryCacheUri.pop_back();
|
||||||
auto binaryCache = openStore(binaryCacheUri).cast<S3BinaryCacheStore>();
|
auto binaryCache = openStore(binaryCacheUri).cast<S3BinaryCacheStore>();
|
||||||
|
|
||||||
auto storePaths = tokenizeString<PathSet>(readFile(storePathsFile, true));
|
auto storePaths = binaryCache->parseStorePathSet(tokenizeString<PathSet>(readFile(storePathsFile, true)));
|
||||||
|
|
||||||
std::regex debugFileRegex("^lib/debug/\\.build-id/[0-9a-f]{2}/[0-9a-f]{38}\\.debug$");
|
std::regex debugFileRegex("^lib/debug/\\.build-id/[0-9a-f]{2}/[0-9a-f]{38}\\.debug$");
|
||||||
|
|
||||||
|
@ -68,7 +68,7 @@ void mainWrapped(int argc, char * * argv)
|
||||||
std::string(file.first, prefix.size(), 2) +
|
std::string(file.first, prefix.size(), 2) +
|
||||||
std::string(file.first, prefix.size() + 3, 38);
|
std::string(file.first, prefix.size() + 3, 38);
|
||||||
|
|
||||||
auto info = binaryCache->queryPathInfo(storePath).cast<const NarInfo>();
|
auto info = binaryCache->queryPathInfo(binaryCache->parseStorePath(storePath)).cast<const NarInfo>();
|
||||||
|
|
||||||
assert(hasPrefix(info->url, "nar/"));
|
assert(hasPrefix(info->url, "nar/"));
|
||||||
|
|
||||||
|
@ -84,8 +84,8 @@ void mainWrapped(int argc, char * * argv)
|
||||||
};
|
};
|
||||||
|
|
||||||
for (auto & storePath : storePaths)
|
for (auto & storePath : storePaths)
|
||||||
if (hasSuffix(storePath, "-debug"))
|
if (hasSuffix(storePath.name(), "-debug"))
|
||||||
threadPool.enqueue(std::bind(doPath, storePath));
|
threadPool.enqueue(std::bind(doPath, binaryCache->printStorePath(storePath)));
|
||||||
|
|
||||||
threadPool.process();
|
threadPool.process();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue