From 4a9c6ab6a22432a8df3ad0611dd4821e005dc0a7 Mon Sep 17 00:00:00 2001 From: Vincent Ambo Date: Sat, 21 Dec 2019 05:42:32 +0000 Subject: refactor(nix/readTree): Move readTree to its own subfolder --- default.nix | 2 +- nix/readTree/default.nix | 63 ++++++++++++++++++++++++++++++++++++++++++++++++ read-tree.nix | 61 ---------------------------------------------- 3 files changed, 64 insertions(+), 62 deletions(-) create mode 100644 nix/readTree/default.nix delete mode 100644 read-tree.nix diff --git a/default.nix b/default.nix index b38a12aaa7..69be71e211 100644 --- a/default.nix +++ b/default.nix @@ -26,7 +26,7 @@ let }; }; - readTree' = import ./read-tree.nix; + readTree' = import ./nix/readTree {}; localPkgs = readTree: { fun = readTree ./fun; diff --git a/nix/readTree/default.nix b/nix/readTree/default.nix new file mode 100644 index 0000000000..c48928ee19 --- /dev/null +++ b/nix/readTree/default.nix @@ -0,0 +1,63 @@ +{ ... }: + +args: initPath: + +let + inherit (builtins) + attrNames + baseNameOf + filter + hasAttr + head + length + listToAttrs + map + match + isAttrs + readDir; + + argsWithPath = parts: args // { + locatedAt = parts; + }; + + # The marker is added to every set that was imported directly by + # readTree. + importWithMark = path: parts: + let imported = import path (argsWithPath parts); + in if (isAttrs imported) + then imported // { __readTree = true; } + else imported; + + nixFileName = file: + let res = match "(.*)\.nix" file; + in if res == null then null else head res; + + readTree = path: parts: + let + dir = readDir path; + self = importWithMark path parts; + joinChild = c: path + ("/" + c); + + # Import subdirectories of the current one, unless the special + # `.skip-subtree` file exists which makes readTree ignore the + # children. + # + # This file can optionally contain information on why the tree + # should be ignored, but its content is not inspected by + # readTree + filterDir = f: dir."${f}" == "directory"; + children = if hasAttr ".skip-subtree" dir then [] else map (c: { + name = c; + value = readTree (joinChild c) (parts ++ [ c ]); + }) (filter filterDir (attrNames dir)); + + # Import Nix files + nixFiles = filter (f: f != null) (map nixFileName (attrNames dir)); + nixChildren = map (c: let p = joinChild (c + ".nix"); in { + name = c; + value = importWithMark p (parts ++ [ c ]); + }) nixFiles; + in if dir ? "default.nix" + then (if isAttrs self then self // (listToAttrs children) else self) + else listToAttrs (nixChildren ++ children); +in readTree initPath [ (baseNameOf initPath) ] diff --git a/read-tree.nix b/read-tree.nix deleted file mode 100644 index 052865914e..0000000000 --- a/read-tree.nix +++ /dev/null @@ -1,61 +0,0 @@ -args: initPath: - -let - inherit (builtins) - attrNames - baseNameOf - filter - hasAttr - head - length - listToAttrs - map - match - isAttrs - readDir; - - argsWithPath = parts: args // { - locatedAt = parts; - }; - - # The marker is added to every set that was imported directly by - # readTree. - importWithMark = path: parts: - let imported = import path (argsWithPath parts); - in if (isAttrs imported) - then imported // { __readTree = true; } - else imported; - - nixFileName = file: - let res = match "(.*)\.nix" file; - in if res == null then null else head res; - - readTree = path: parts: - let - dir = readDir path; - self = importWithMark path parts; - joinChild = c: path + ("/" + c); - - # Import subdirectories of the current one, unless the special - # `.skip-subtree` file exists which makes readTree ignore the - # children. - # - # This file can optionally contain information on why the tree - # should be ignored, but its content is not inspected by - # readTree - filterDir = f: dir."${f}" == "directory"; - children = if hasAttr ".skip-subtree" dir then [] else map (c: { - name = c; - value = readTree (joinChild c) (parts ++ [ c ]); - }) (filter filterDir (attrNames dir)); - - # Import Nix files - nixFiles = filter (f: f != null) (map nixFileName (attrNames dir)); - nixChildren = map (c: let p = joinChild (c + ".nix"); in { - name = c; - value = importWithMark p (parts ++ [ c ]); - }) nixFiles; - in if dir ? "default.nix" - then (if isAttrs self then self // (listToAttrs children) else self) - else listToAttrs (nixChildren ++ children); -in readTree initPath [ (baseNameOf initPath) ] -- cgit 1.4.1