forked from lix-project/lix
Merge pull request #6590 from edolstra/fix-noexcept
Fix noexcept violations
This commit is contained in:
commit
af23d38019
|
@ -348,7 +348,7 @@
|
||||||
|
|
||||||
strictDeps = true;
|
strictDeps = true;
|
||||||
|
|
||||||
passthru.perl-bindings = with final; currentStdenv.mkDerivation {
|
passthru.perl-bindings = with final; perl.pkgs.toPerlModule (currentStdenv.mkDerivation {
|
||||||
name = "nix-perl-${version}";
|
name = "nix-perl-${version}";
|
||||||
|
|
||||||
src = self;
|
src = self;
|
||||||
|
@ -378,8 +378,9 @@
|
||||||
enableParallelBuilding = true;
|
enableParallelBuilding = true;
|
||||||
|
|
||||||
postUnpack = "sourceRoot=$sourceRoot/perl";
|
postUnpack = "sourceRoot=$sourceRoot/perl";
|
||||||
};
|
});
|
||||||
|
|
||||||
|
meta.platforms = systems;
|
||||||
};
|
};
|
||||||
|
|
||||||
lowdown-nix = with final; currentStdenv.mkDerivation rec {
|
lowdown-nix = with final; currentStdenv.mkDerivation rec {
|
||||||
|
|
|
@ -161,7 +161,12 @@ protected:
|
||||||
void getFile(const std::string & path,
|
void getFile(const std::string & path,
|
||||||
Callback<std::optional<std::string>> callback) noexcept override
|
Callback<std::optional<std::string>> callback) noexcept override
|
||||||
{
|
{
|
||||||
checkEnabled();
|
try {
|
||||||
|
checkEnabled();
|
||||||
|
} catch (...) {
|
||||||
|
callback.rethrow();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
auto request(makeRequest(path));
|
auto request(makeRequest(path));
|
||||||
|
|
||||||
|
|
|
@ -718,36 +718,34 @@ void RemoteStore::registerDrvOutput(const Realisation & info)
|
||||||
void RemoteStore::queryRealisationUncached(const DrvOutput & id,
|
void RemoteStore::queryRealisationUncached(const DrvOutput & id,
|
||||||
Callback<std::shared_ptr<const Realisation>> callback) noexcept
|
Callback<std::shared_ptr<const Realisation>> callback) noexcept
|
||||||
{
|
{
|
||||||
auto conn(getConnection());
|
|
||||||
|
|
||||||
if (GET_PROTOCOL_MINOR(conn->daemonVersion) < 27) {
|
|
||||||
warn("the daemon is too old to support content-addressed derivations, please upgrade it to 2.4");
|
|
||||||
try {
|
|
||||||
callback(nullptr);
|
|
||||||
} catch (...) { return callback.rethrow(); }
|
|
||||||
}
|
|
||||||
|
|
||||||
conn->to << wopQueryRealisation;
|
|
||||||
conn->to << id.to_string();
|
|
||||||
conn.processStderr();
|
|
||||||
|
|
||||||
auto real = [&]() -> std::shared_ptr<const Realisation> {
|
|
||||||
if (GET_PROTOCOL_MINOR(conn->daemonVersion) < 31) {
|
|
||||||
auto outPaths = worker_proto::read(
|
|
||||||
*this, conn->from, Phantom<std::set<StorePath>> {});
|
|
||||||
if (outPaths.empty())
|
|
||||||
return nullptr;
|
|
||||||
return std::make_shared<const Realisation>(Realisation { .id = id, .outPath = *outPaths.begin() });
|
|
||||||
} else {
|
|
||||||
auto realisations = worker_proto::read(
|
|
||||||
*this, conn->from, Phantom<std::set<Realisation>> {});
|
|
||||||
if (realisations.empty())
|
|
||||||
return nullptr;
|
|
||||||
return std::make_shared<const Realisation>(*realisations.begin());
|
|
||||||
}
|
|
||||||
}();
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
auto conn(getConnection());
|
||||||
|
|
||||||
|
if (GET_PROTOCOL_MINOR(conn->daemonVersion) < 27) {
|
||||||
|
warn("the daemon is too old to support content-addressed derivations, please upgrade it to 2.4");
|
||||||
|
return callback(nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
conn->to << wopQueryRealisation;
|
||||||
|
conn->to << id.to_string();
|
||||||
|
conn.processStderr();
|
||||||
|
|
||||||
|
auto real = [&]() -> std::shared_ptr<const Realisation> {
|
||||||
|
if (GET_PROTOCOL_MINOR(conn->daemonVersion) < 31) {
|
||||||
|
auto outPaths = worker_proto::read(
|
||||||
|
*this, conn->from, Phantom<std::set<StorePath>> {});
|
||||||
|
if (outPaths.empty())
|
||||||
|
return nullptr;
|
||||||
|
return std::make_shared<const Realisation>(Realisation { .id = id, .outPath = *outPaths.begin() });
|
||||||
|
} else {
|
||||||
|
auto realisations = worker_proto::read(
|
||||||
|
*this, conn->from, Phantom<std::set<Realisation>> {});
|
||||||
|
if (realisations.empty())
|
||||||
|
return nullptr;
|
||||||
|
return std::make_shared<const Realisation>(*realisations.begin());
|
||||||
|
}
|
||||||
|
}();
|
||||||
|
|
||||||
callback(std::shared_ptr<const Realisation>(real));
|
callback(std::shared_ptr<const Realisation>(real));
|
||||||
} catch (...) { return callback.rethrow(); }
|
} catch (...) { return callback.rethrow(); }
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue