add helper to lib/attrsets: hasAttrByPath
This commit is contained in:
parent
ff66ac9dd0
commit
ce96057588
|
@ -23,6 +23,17 @@ rec {
|
||||||
then attrByPath (tail attrPath) default e.${attr}
|
then attrByPath (tail attrPath) default e.${attr}
|
||||||
else default;
|
else default;
|
||||||
|
|
||||||
|
/* Return if an attribute from nested attribute set exists.
|
||||||
|
For instance ["x" "y"] applied to some set e returns true, if e.x.y exists. False
|
||||||
|
is returned otherwise. */
|
||||||
|
hasAttrByPath = attrPath: e:
|
||||||
|
let attr = head attrPath;
|
||||||
|
in
|
||||||
|
if attrPath == [] then true
|
||||||
|
else if e ? ${attr}
|
||||||
|
then hasAttrByPath (tail attrPath) e.${attr}
|
||||||
|
else false;
|
||||||
|
|
||||||
|
|
||||||
/* Return nested attribute set in which an attribute is set. For instance
|
/* Return nested attribute set in which an attribute is set. For instance
|
||||||
["x" "y"] applied with some value v returns `x.y = v;' */
|
["x" "y"] applied with some value v returns `x.y = v;' */
|
||||||
|
|
|
@ -120,4 +120,14 @@ runTests {
|
||||||
expected = { success = false; value = false; };
|
expected = { success = false; value = false; };
|
||||||
};
|
};
|
||||||
|
|
||||||
|
testHasAttrByPathTrue = {
|
||||||
|
expr = hasAttrByPath ["a" "b"] { a = { b = "yey"; }; };
|
||||||
|
expected = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
testHasAttrByPathFalse = {
|
||||||
|
expr = hasAttrByPath ["a" "b"] { a = { c = "yey"; }; };
|
||||||
|
expected = false;
|
||||||
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue