subtree(users/wpcarro): docking briefcase at '24f5a642'

git-subtree-dir: users/wpcarro
git-subtree-mainline: 464bbcb15c
git-subtree-split: 24f5a642af
Change-Id: I6105b3762b79126b3488359c95978cadb3efa789
This commit is contained in:
Vincent Ambo 2021-12-14 01:51:19 +03:00
commit 019f8fd211
766 changed files with 175420 additions and 0 deletions

View file

@ -0,0 +1,8 @@
# Nix Utils
Nix is useful and well-designed in many cases. Nix's standard library of is not
a representative example of the value of Nix. I'm hoping to replace some of the
standard library functions with versions that I find more intuitive and
ergonomic to consume.
This directcory is where I will host that work.

View file

@ -0,0 +1,11 @@
{ pkgs, ... }:
let
inherit (pkgs) writeShellScriptBin;
in {
# Create a derivation that creates an executable shell script named `as` that
# calls the program located at `path`, forwarding all of the arguments.
wrapNonNixProgram = { path, as }: writeShellScriptBin as ''
exec ${path} "$@"
'';
}

View file

@ -0,0 +1,14 @@
args@{ pkgs, ... }:
# This top-level module exposes all of my utility functions for Nix. It should
# be used like:
# ```nix
# inherit (briefcase.utils) fs;
# ```
let
builder = import ./builder.nix args;
fs = import ./fs.nix args;
in {
inherit builder fs;
}

View file

@ -0,0 +1,41 @@
{ pkgs, ... }:
# `fs` contains utility functions for working with the filesystem.
let
inherit (builtins) attrNames hasAttr map readDir;
inherit (pkgs.lib) filterAttrs;
in {
# 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
# This prevents the function from infinitely recursing and eventually
# stack overflowing.
if (dirOf dir) == dir then
null
else
resolve name (dirOf dir);
};
}