feat(tools/tvlc): pass list of derivations to depot-scanner
You can now provide a list of Nix derivations to tvlc to get a git worktree + sparse-checkout containing only the paths needed to build the specified derivations. Known bugs: even though //third_party is only passed to readdir(), git doesn't know this and includes all of //third_party/*. Change-Id: I9dccebd3fbff4bb04ebd568175cf0a7e37d71ab3 Reviewed-on: https://cl.tvl.fyi/c/depot/+/1826 Tested-by: BuildkiteCI Reviewed-by: tazjin <mail@tazj.in>
This commit is contained in:
parent
e539242032
commit
a9650041bb
4 changed files with 36 additions and 7 deletions
|
@ -18,6 +18,7 @@ var nixStoreRoot = flag.String("store-path", "/nix/store/", "prefix for all vali
|
||||||
|
|
||||||
var modeFlag = flag.String("mode", modeArchive, "operation mode. valid values: tar, print")
|
var modeFlag = flag.String("mode", modeArchive, "operation mode. valid values: tar, print")
|
||||||
var onlyFlag = flag.String("only", "", "only enable the listed output types, comma separated. valid values: DEPOT, STORE, CORE, UNKNOWN")
|
var onlyFlag = flag.String("only", "", "only enable the listed output types, comma separated. valid values: DEPOT, STORE, CORE, UNKNOWN")
|
||||||
|
var relativeFlag = flag.Bool("relpath", false, "when printing paths, print them relative to the root of their path type")
|
||||||
|
|
||||||
const (
|
const (
|
||||||
modeArchive = "tar"
|
modeArchive = "tar"
|
||||||
|
@ -164,16 +165,25 @@ func main() {
|
||||||
if *modeFlag == "print" {
|
if *modeFlag == "print" {
|
||||||
if enabledPathTypes[pb.PathType_STORE] {
|
if enabledPathTypes[pb.PathType_STORE] {
|
||||||
for k, _ := range results[nixStorePath] {
|
for k, _ := range results[nixStorePath] {
|
||||||
|
if *relativePath {
|
||||||
|
k = strings.TrimPrefix(k, *nixStoreRoot)
|
||||||
|
k = strings.TrimPrefix(k, "/")
|
||||||
|
}
|
||||||
fmt.Println(k)
|
fmt.Println(k)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if enabledPathTypes[pb.PathType_DEPOT] {
|
if enabledPathTypes[pb.PathType_DEPOT] {
|
||||||
for k, _ := range results[depotPath] {
|
for k, _ := range results[depotPath] {
|
||||||
|
if *relativeFlag {
|
||||||
|
k = strings.TrimPrefix(k, *depotRoot)
|
||||||
|
k = strings.TrimPrefix(k, "/")
|
||||||
|
}
|
||||||
fmt.Println(k)
|
fmt.Println(k)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if enabledPathTypes[pb.PathType_CORE] {
|
if enabledPathTypes[pb.PathType_CORE] {
|
||||||
for k, _ := range results[corePkgsPath] {
|
for k, _ := range results[corePkgsPath] {
|
||||||
|
// TODO relativeFlag
|
||||||
fmt.Println(k)
|
fmt.Println(k)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,9 +3,12 @@
|
||||||
set -eu
|
set -eu
|
||||||
set -o pipefail
|
set -o pipefail
|
||||||
|
|
||||||
|
source path-scripts
|
||||||
|
|
||||||
XDG_DATA_HOME="${XDG_DATA_HOME:-$HOME/.local/share}"
|
XDG_DATA_HOME="${XDG_DATA_HOME:-$HOME/.local/share}"
|
||||||
tvlc_root="$XDG_DATA_HOME/tvlc"
|
tvlc_root="$XDG_DATA_HOME/tvlc"
|
||||||
|
|
||||||
|
nice_checkout_root=
|
||||||
if [ -f "$tvlc_root"/nice_checkout_root ]; then
|
if [ -f "$tvlc_root"/nice_checkout_root ]; then
|
||||||
nice_checkout_root="$(cat "$tvlc_root"/nice_checkout_root)"
|
nice_checkout_root="$(cat "$tvlc_root"/nice_checkout_root)"
|
||||||
fi
|
fi
|
||||||
|
|
|
@ -1,17 +1,31 @@
|
||||||
{ pkgs, depot, ... }:
|
{ pkgs, depot, ... }:
|
||||||
|
|
||||||
let
|
let
|
||||||
commonsh = ./common.sh;
|
|
||||||
|
|
||||||
# TODO(riking): path deduction
|
|
||||||
#tvix-instantiate="${third_party.nix}/bin/nix-instantiate"
|
|
||||||
pathScripts = pkgs.writeShellScript "imports" ''
|
pathScripts = pkgs.writeShellScript "imports" ''
|
||||||
|
export tvix_instantiate="${depot.third_party.nix}/bin/nix-instantiate"
|
||||||
|
export depot_scanner="${depot.tools.depot-scanner}/bin/depot-scanner"
|
||||||
'';
|
'';
|
||||||
|
|
||||||
# setup: git rev-parse --show-toplevel > $tvlc_root/depot_root
|
# setup: git rev-parse --show-toplevel > $tvlc_root/depot_root
|
||||||
# setup: mkdir $tvlc_root/clients
|
# setup: mkdir $tvlc_root/clients
|
||||||
# setup: echo 1 > $tvlc_root/next_clientid
|
# setup: echo 1 > $tvlc_root/next_clientid
|
||||||
|
|
||||||
|
commonsh = pkgs.stdenv.mkDerivation {
|
||||||
|
name = "common.sh";
|
||||||
|
src = ./common.sh;
|
||||||
|
doCheck = true;
|
||||||
|
unpackPhase = "true";
|
||||||
|
buildPhase = ''
|
||||||
|
substitute ${./common.sh} $out --replace path-scripts ${pathScripts}
|
||||||
|
'';
|
||||||
|
checkPhase = ''
|
||||||
|
${pkgs.shellcheck}/bin/shellcheck $out ${pathScripts} && echo "SHELLCHECK OK"
|
||||||
|
'';
|
||||||
|
installPhase = ''
|
||||||
|
chmod +x $out
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
tvlcNew = pkgs.stdenv.mkDerivation {
|
tvlcNew = pkgs.stdenv.mkDerivation {
|
||||||
name = "tvlc-new";
|
name = "tvlc-new";
|
||||||
src = ./tvlc-new;
|
src = ./tvlc-new;
|
||||||
|
@ -22,7 +36,7 @@ let
|
||||||
substitute ${./tvlc-new} $out --replace common.sh ${commonsh}
|
substitute ${./tvlc-new} $out --replace common.sh ${commonsh}
|
||||||
'';
|
'';
|
||||||
checkPhase = ''
|
checkPhase = ''
|
||||||
${pkgs.shellcheck}/bin/shellcheck $out ${commonsh} && echo "SHELLCHECK OK"
|
${pkgs.shellcheck}/bin/shellcheck $out ${commonsh} ${pathScripts} && echo "SHELLCHECK OK"
|
||||||
'';
|
'';
|
||||||
installPhase = ''
|
installPhase = ''
|
||||||
chmod +x $out
|
chmod +x $out
|
||||||
|
@ -30,6 +44,7 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
in pkgs.stdenv.mkDerivation rec {
|
in pkgs.stdenv.mkDerivation rec {
|
||||||
|
inherit pathScripts;
|
||||||
inherit commonsh;
|
inherit commonsh;
|
||||||
inherit tvlcNew;
|
inherit tvlcNew;
|
||||||
}
|
}
|
||||||
|
|
|
@ -79,7 +79,8 @@ if [ -f "$DEPOT_ROOT/.git/refs/heads/$branch_name" ]; then
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# TODO(riking): tvlc-get-depends
|
# The big one: call into Nix to figure out what paths the desired derivations depend on.
|
||||||
|
readarray -t includedPaths < <("$depot_scanner" --mode 'print' --only 'DEPOT' --relpath --depot "$DEPOT_ROOT" --nix-bin "$tvix_instantiate" "$@")
|
||||||
|
|
||||||
# bash math
|
# bash math
|
||||||
checkout_id=$(("$(cat "$tvlc_root/next_clientid")"))
|
checkout_id=$(("$(cat "$tvlc_root/next_clientid")"))
|
||||||
|
@ -95,7 +96,7 @@ mkdir "$DEPOT_ROOT/.git/worktrees/$checkout_id/info"
|
||||||
|
|
||||||
cd "$checkout_dir"
|
cd "$checkout_dir"
|
||||||
git sparse-checkout init --cone
|
git sparse-checkout init --cone
|
||||||
git sparse-checkout set "$@"
|
git sparse-checkout set "${includedPaths[@]}"
|
||||||
|
|
||||||
ln -s "$checkout_dir" "$nice_checkout_root"/"$checkout_name"
|
ln -s "$checkout_dir" "$nice_checkout_root"/"$checkout_name"
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue