From 00b2f7c1419b4a60f7bc7f25e693436e5e7932fc Mon Sep 17 00:00:00 2001 From: Eelco Dolstra Date: Thu, 4 Mar 2010 13:25:12 +0000 Subject: [PATCH] * Don't access /nix/var/nix/db directly but use the Nix Perl bindings. --- src/lib/Hydra/Helper/Nix.pm | 35 +++++------------------------------ 1 file changed, 5 insertions(+), 30 deletions(-) diff --git a/src/lib/Hydra/Helper/Nix.pm b/src/lib/Hydra/Helper/Nix.pm index 6022a0cd..206903e6 100644 --- a/src/lib/Hydra/Helper/Nix.pm +++ b/src/lib/Hydra/Helper/Nix.pm @@ -4,6 +4,7 @@ use strict; use Exporter; use File::Path; use File::Basename; +use Nix; our @ISA = qw(Exporter); our @EXPORT = qw( @@ -17,42 +18,16 @@ our @EXPORT = qw( sub isValidPath { my $path = shift; - #$SIG{CHLD} = 'DEFAULT'; # !!! work around system() failing if SIGCHLD is ignored - #return system("nix-store --check-validity $path 2> /dev/null") == 0; - - # This is faster than calling nix-store, but it breaks abstraction... - return -e ("/nix/var/nix/db/info/" . basename $path); + return Nix::isValidPath($path); } sub queryPathInfo { my $path = shift; - # !!! like above, this breaks abstraction. What we really need is - # Perl bindings for libstore :-) - - open FH, ") { - if (/^Hash: (\S+)$/) { - $hash = $1; - } - elsif (/^Deriver: (\S+)$/) { - $deriver = $1; - } - elsif (/^References: (.*)$/) { - @refs = split / /, $1; - } - } - - close FH; - - die "path $path does not have a hash" unless defined $hash; + my $hash = Nix::queryPathHash($path); + my $deriver = Nix::queryDeriver($path); + my @refs = Nix::queryReferences($path); return ($hash, $deriver, \@refs); }