refactor(users/grfn/gws.fyi): implement isDirectory in pure nix
Another day, another import from derivation avoided by builtins.unsafeDiscardStringContext! Change-Id: I67274b1ba13ba980bb3346b22f2955c702aa3151 Reviewed-on: https://cl.tvl.fyi/c/depot/+/3372 Tested-by: BuildkiteCI Reviewed-by: grfn <grfn@gws.fyi> Reviewed-by: tazjin <mail@tazj.in>
This commit is contained in:
parent
eb6c7fd3bf
commit
32de4cbd93
2 changed files with 67 additions and 10 deletions
|
|
@ -58,9 +58,74 @@ let
|
|||
else builtins.throw "Don't know how to get (base)name of "
|
||||
+ lib.generators.toPretty {} p;
|
||||
|
||||
/* Get the type of a path itself as it would be returned for a
|
||||
directory child by builtins.readDir.
|
||||
|
||||
Type: path(-like) -> option<string>
|
||||
|
||||
Example:
|
||||
pathType ./foo.c
|
||||
=> "regular"
|
||||
|
||||
pathType /home/lukas
|
||||
=> "directory"
|
||||
|
||||
pathType ./result
|
||||
=> "symlink"
|
||||
|
||||
pathType /does/not/exist
|
||||
=> null
|
||||
*/
|
||||
pathType = path:
|
||||
let
|
||||
# baseNameOf is very annoyed if we proceed with string context.
|
||||
# We need to call toString to prevent unsafeDiscardStringContext
|
||||
# from importing a path into store which messes with base- and
|
||||
# dirname of course.
|
||||
path'= builtins.unsafeDiscardStringContext (toString path);
|
||||
# To read the containing directory we absolutely need
|
||||
# to keep the string context, otherwise a derivation
|
||||
# would not be realized before our check (at eval time)
|
||||
containingDir = builtins.readDir (builtins.dirOf path);
|
||||
in
|
||||
containingDir.${builtins.baseNameOf path'} or null;
|
||||
|
||||
pathType' = path:
|
||||
let
|
||||
p = pathType path;
|
||||
in
|
||||
if p == null
|
||||
then builtins.throw "${lib.generators.toPretty {} path} does not exist"
|
||||
else p;
|
||||
|
||||
/* Check whether the given path is a directory.
|
||||
Throws if the path in question doesn't exist.
|
||||
|
||||
Type: path(-like) -> bool
|
||||
*/
|
||||
isDirectory = path: pathType' path == "directory";
|
||||
|
||||
/* Check whether the given path is a regular file.
|
||||
Throws if the path in question doesn't exist.
|
||||
|
||||
Type: path(-like) -> bool
|
||||
*/
|
||||
isRegularFile = path: pathType' path == "regular";
|
||||
|
||||
/* Check whether the given path is a symbolic link.
|
||||
Throws if the path in question doesn't exist.
|
||||
|
||||
Type: path(-like) -> bool
|
||||
*/
|
||||
isSymlink = path: pathType' path == "symlink";
|
||||
|
||||
in {
|
||||
inherit
|
||||
drvTargets
|
||||
storePathName
|
||||
pathType
|
||||
isDirectory
|
||||
isRegularFile
|
||||
isSymlink
|
||||
;
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue