mirror of
https://github.com/privatevoid-net/nix-super.git
synced 2025-01-19 01:26:47 +02:00
Simplify
This commit is contained in:
parent
5a0e98d1e5
commit
14d3f45009
1 changed files with 4 additions and 18 deletions
|
@ -425,29 +425,15 @@ std::vector<std::shared_ptr<Installable>> SourceExprCommand::parseInstallables(
|
|||
getDefaultFlakeAttrPathPrefixes()));
|
||||
|
||||
else {
|
||||
std::exception_ptr flakeEx;
|
||||
|
||||
try {
|
||||
auto flakeRef = FlakeRef(s, true);
|
||||
result.push_back(std::make_shared<InstallableFlake>(
|
||||
*this, std::move(flakeRef), getDefaultFlakeAttrPaths()));
|
||||
continue;
|
||||
} catch (MissingFlake &) {
|
||||
/* 's' could be parsed as a flakeref, but it
|
||||
references a local path that is not a flake. So
|
||||
take note of that. */
|
||||
flakeEx = std::current_exception();
|
||||
} catch (BadFlakeRef &) {
|
||||
}
|
||||
|
||||
if (s.find('/') != std::string::npos && (storePath = follow(s)))
|
||||
result.push_back(std::make_shared<InstallableStorePath>(*storePath));
|
||||
|
||||
else {
|
||||
if (flakeEx)
|
||||
std::rethrow_exception(flakeEx);
|
||||
} catch (...) {
|
||||
if (s.find('/') != std::string::npos && (storePath = follow(s)))
|
||||
result.push_back(std::make_shared<InstallableStorePath>(*storePath));
|
||||
else
|
||||
throw Error("unsupported argument '%s'", s);
|
||||
throw;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue