From c40c887e503bda855a12484902a62984f4b30f01 Mon Sep 17 00:00:00 2001 From: Hamish Mackenzie Date: Tue, 7 Jan 2020 12:38:06 +1300 Subject: [PATCH 1/2] Fixes for macOS Building on macOS with the latest nixpkgs master and NixOS/nixpkgs#77147 fails. It seems some `std::experimental` (optional) for instance are not available as `experimental`, but are in `std`. Also `toJSON` is missing for `atomic< unsigned long long >`. --- src/hydra-evaluator/hydra-evaluator.cc | 4 ++-- src/hydra-queue-runner/hydra-queue-runner.cc | 1 + src/libhydra/db.hh | 6 +++--- 3 files changed, 6 insertions(+), 5 deletions(-) diff --git a/src/hydra-evaluator/hydra-evaluator.cc b/src/hydra-evaluator/hydra-evaluator.cc index 86ac5c39..091a4e9c 100644 --- a/src/hydra-evaluator/hydra-evaluator.cc +++ b/src/hydra-evaluator/hydra-evaluator.cc @@ -6,7 +6,7 @@ #include #include #include -#include +#include #include #include @@ -31,7 +31,7 @@ struct Evaluator typedef std::map Jobsets; - std::experimental::optional evalOne; + std::optional evalOne; const size_t maxEvals; diff --git a/src/hydra-queue-runner/hydra-queue-runner.cc b/src/hydra-queue-runner/hydra-queue-runner.cc index fa7515d3..f97a1c95 100644 --- a/src/hydra-queue-runner/hydra-queue-runner.cc +++ b/src/hydra-queue-runner/hydra-queue-runner.cc @@ -23,6 +23,7 @@ namespace nix { template<> void toJSON>(std::ostream & str, const std::atomic & n) { str << n; } template<> void toJSON>(std::ostream & str, const std::atomic & n) { str << n; } +template<> void toJSON>(std::ostream & str, const std::atomic & n) { str << n; } template<> void toJSON(std::ostream & str, const double & n) { str << n; } } diff --git a/src/libhydra/db.hh b/src/libhydra/db.hh index 5bb5aac5..29af7cc2 100644 --- a/src/libhydra/db.hh +++ b/src/libhydra/db.hh @@ -23,7 +23,7 @@ struct Connection : pqxx::connection class receiver : public pqxx::notification_receiver { - std::experimental::optional status; + std::optional status; public: @@ -35,9 +35,9 @@ public: status = payload; }; - std::experimental::optional get() { + std::optional get() { auto s = status; - status = std::experimental::nullopt; + status = std::nullopt; return s; } }; From 5fab5e935bdb3b6032a62577de66cc2fd07e8741 Mon Sep 17 00:00:00 2001 From: Bas van Dijk Date: Sun, 26 Jan 2020 21:45:38 +0100 Subject: [PATCH 2/2] Remove the "log diff" buttons because they're referencing the removed `logdiff` API. This API was removed in 4d1816b1529e4877f9527f039facbe9953c187bd. Fixes #409 --- src/root/build.tt | 2 -- 1 file changed, 2 deletions(-) diff --git a/src/root/build.tt b/src/root/build.tt index 750ae474..8f026576 100644 --- a/src/root/build.tt +++ b/src/root/build.tt @@ -292,11 +292,9 @@ END; Last successful build [% INCLUDE renderDateTime timestamp = prevSuccessfulBuild.timestamp %] [% IF prevSuccessfulBuild && firstBrokenBuild && firstBrokenBuild.id != build.id %] First broken build [% INCLUDE renderDateTime timestamp = firstBrokenBuild.timestamp %] - log diff [% END %] This build [% INCLUDE renderDateTime timestamp = build.timestamp %] - log diff