aboutsummaryrefslogtreecommitdiff
path: root/src/libexpr/flake/flakeref.cc
diff options
context:
space:
mode:
authorAlexander Bantyev <balsoft@balsoft.ru>2022-01-14 17:15:45 +0300
committerAlexander Bantyev <balsoft@balsoft.ru>2022-01-14 17:21:18 +0300
commite3690ab39382498eaabbd07e696335e17c9f209c (patch)
tree069fbb6383db42598229aa393fa2489efb63504a /src/libexpr/flake/flakeref.cc
parent2dead2092470f7b0440d34035e19b9d8c80db91e (diff)
Add more tests for flake upward searching
Diffstat (limited to 'src/libexpr/flake/flakeref.cc')
-rw-r--r--src/libexpr/flake/flakeref.cc39
1 files changed, 20 insertions, 19 deletions
diff --git a/src/libexpr/flake/flakeref.cc b/src/libexpr/flake/flakeref.cc
index 06f8511b6..930ed9ccd 100644
--- a/src/libexpr/flake/flakeref.cc
+++ b/src/libexpr/flake/flakeref.cc
@@ -122,27 +122,28 @@ std::pair<FlakeRef, std::string> parseFlakeRefWithFragment(
if (isFlake) {
- if (!allowMissing && !pathExists(path + "/flake.nix")){
- notice("path '%s' does not contain a 'flake.nix', searching up",path);
-
- // Save device to detect filesystem boundary
- dev_t device = lstat(path).st_dev;
- bool found = false;
- while (path != "/") {
- if (pathExists(path + "/flake.nix")) {
- found = true;
- break;
- } else if (pathExists(path + "/.git"))
- throw Error("unable to find a flake before encountering git boundary at '%s'", path);
- else {
- if (lstat(path).st_dev != device)
- throw Error("path '%s' is not part of a flake (neither it nor its parent directories contain a 'flake.nix' file)", origPath);
+ if (!allowMissing && !pathExists(path + "/flake.nix")){
+ notice("path '%s' does not contain a 'flake.nix', searching up",path);
+
+ // Save device to detect filesystem boundary
+ dev_t device = lstat(path).st_dev;
+ bool found = false;
+ while (path != "/") {
+ if (pathExists(path + "/flake.nix")) {
+ found = true;
+ break;
+ } else if (pathExists(path + "/.git"))
+ throw Error("path '%s' is not part of a flake (neither it nor its parent directories contain a 'flake.nix' file)", path);
+ else {
+ if (lstat(path).st_dev != device)
+ throw Error("unable to find a flake before encountering filesystem boundary at '%s'", path);
+ }
+ path = dirOf(path);
}
- path = dirOf(path);
+ if (!found)
+ throw BadURL("could not find a flake.nix file");
}
- if (!found)
- throw BadURL("could not find a flake.nix file");
- }
+
if (!S_ISDIR(lstat(path).st_mode))
throw BadURL("path '%s' is not a flake (because it's not a directory)", path);