feat(nix/utils): handle toString-able sets produced by builtins.path

When preparing cl/4381 I noticed that we actually handle this case
properly. depot.nix.utils.storePathName depot.path now works as
expected.

Change-Id: Ice9329c67b2e2210852012f5abe82fbbb13193de
Reviewed-on: https://cl.tvl.fyi/c/depot/+/4382
Tested-by: BuildkiteCI
Reviewed-by: tazjin <mail@tazj.in>
Autosubmit: sterni <sternenseemann@systemli.org>
This commit is contained in:
sterni 2021-12-16 17:28:21 +01:00 committed by clbot
parent e25ef08c45
commit 887ac4d3d4
2 changed files with 8 additions and 3 deletions

View file

@ -21,17 +21,18 @@ let
then p.name
else if builtins.isPath p
then builtins.baseNameOf p
else if builtins.isString p
else if builtins.isString p || (builtins.isAttrs p && (p ? outPath || p ? __toString))
then
let
strPath = toString p;
# strip leading storeDir and trailing slashes
noStoreDir = lib.removeSuffix "/"
(lib.removePrefix "${builtins.storeDir}/" p);
(lib.removePrefix "${builtins.storeDir}/" strPath);
# a basename of a child of a store path isn't really
# referring to a store path, so removing the string
# context is safe (e. g. "hello" for "${hello}/bin/hello").
basename = builtins.unsafeDiscardStringContext
(builtins.baseNameOf p);
(builtins.baseNameOf strPath);
in
# If p is a direct child of storeDir, we need to remove
# the leading hash as well to make sure that: