2020-09-01 13:16:34 +02:00
|
|
|
{ pkgs, ... }:
|
|
|
|
|
|
|
|
# `fs` contains utility functions for working with the filesystem.
|
|
|
|
|
|
|
|
let
|
|
|
|
inherit (builtins) attrNames hasAttr map readDir;
|
|
|
|
inherit (pkgs.lib) filterAttrs;
|
2022-01-30 17:06:58 +01:00
|
|
|
in
|
|
|
|
{
|
2020-09-01 13:16:34 +02:00
|
|
|
# Returns a list of all of the regular files in `dir`.
|
|
|
|
files = dir:
|
|
|
|
map (name: dir + "/${name}")
|
|
|
|
(attrNames
|
|
|
|
(filterAttrs (_: type: type == "regular") (readDir dir)));
|
|
|
|
|
|
|
|
# Returns a list of all of the directories in `dir`.
|
|
|
|
dirs = dir:
|
|
|
|
map (name: dir + "/${name}")
|
|
|
|
(attrNames
|
|
|
|
(filterAttrs (_: type: type == "directory") (readDir dir)));
|
|
|
|
|
|
|
|
# Returns a list of paths to all of the `name` files starting at `dir`.
|
|
|
|
find = name: dir:
|
|
|
|
if hasAttr name (readDir dir) then
|
|
|
|
[ (dir + name) ] ++ concatMap findAllDefaultNix (dirs dir)
|
|
|
|
else
|
|
|
|
concatMap findAllDefaultNix (dirs dir);
|
|
|
|
|
|
|
|
# Looks for `name` in `dir`; if it cannot find it, it checks the parent
|
|
|
|
# directory.
|
|
|
|
resolve = name: dir:
|
|
|
|
if hasAttr name (readDir dir) then
|
|
|
|
dir + "/${name}"
|
|
|
|
else
|
2022-01-30 17:06:58 +01:00
|
|
|
# This prevents the function from infinitely recursing and eventually
|
|
|
|
# stack overflowing.
|
2020-09-01 13:16:34 +02:00
|
|
|
if (dirOf dir) == dir then
|
|
|
|
null
|
|
|
|
else
|
|
|
|
resolve name (dirOf dir);
|
2022-01-30 17:06:58 +01:00
|
|
|
};
|
2020-09-01 13:16:34 +02:00
|
|
|
}
|