41 lines
		
	
	
	
		
			1.2 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
			
		
		
	
	
			41 lines
		
	
	
	
		
			1.2 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
| { 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);
 | |
|   };
 | |
| }
 |