diff options
author | Griffin Smith <grfn@gws.fyi> | 2020-07-23T16·35-0400 |
---|---|---|
committer | glittershark <grfn@gws.fyi> | 2020-07-25T20·11+0000 |
commit | dcaba9de64354fa699ee6b292efbedfb984582db (patch) | |
tree | 00d82d265d06eec49d6b729941d803801f34707b /third_party/nix/src/nix-daemon/nix-daemon-proto.cc | |
parent | 7c56fccdad85c5d99c1a79e0768ce3d20aac82e9 (diff) |
feat(3p/nix): Add main function for grpc daemon r/1472
Implement the main function for the new, proto-based nix daemon. This mostly replicates the behavior of the previous nix daemon - it starts a grpc server listening on the same nix socket path and supports the same set of options - with the exception of --stdio, which has been renamed to --pipe and documented in the man page. Change-Id: Ib729283c1d5d35c0e1b0a968bc1f052f5527f2d7 Reviewed-on: https://cl.tvl.fyi/c/depot/+/1356 Tested-by: BuildkiteCI Reviewed-by: tazjin <mail@tazj.in> Reviewed-by: kanepyork <rikingcoding@gmail.com>
Diffstat (limited to 'third_party/nix/src/nix-daemon/nix-daemon-proto.cc')
-rw-r--r-- | third_party/nix/src/nix-daemon/nix-daemon-proto.cc | 11 |
1 files changed, 5 insertions, 6 deletions
diff --git a/third_party/nix/src/nix-daemon/nix-daemon-proto.cc b/third_party/nix/src/nix-daemon/nix-daemon-proto.cc index ffd34cc60a61..d382964a71d8 100644 --- a/third_party/nix/src/nix-daemon/nix-daemon-proto.cc +++ b/third_party/nix/src/nix-daemon/nix-daemon-proto.cc @@ -26,7 +26,7 @@ static Status INVALID_STORE_PATH = class WorkerServiceImpl final : public WorkerService::Service { public: - WorkerServiceImpl(nix::Store* store) : store_(store) {} + WorkerServiceImpl(nix::Store& store) : store_(&store) {} Status IsValidPath(grpc::ServerContext* context, const StorePath* request, nix::proto::IsValidPathResponse* response) override { @@ -221,7 +221,7 @@ class WorkerServiceImpl final : public WorkerService::Service { nix::proto::BuildDerivationResponse* response) override { auto drv_path = request->drv_path().path(); store_->assertStorePath(drv_path); - auto drv = BasicDerivation::from_proto(&request->derivation(), store_); + auto drv = BasicDerivation::from_proto(&request->derivation(), *store_); auto build_mode = nix::build_mode_from(request->build_mode()); if (!build_mode) { @@ -282,12 +282,11 @@ class WorkerServiceImpl final : public WorkerService::Service { }; private: - // TODO(tazjin): Who owns the store? - nix::Store* store_; + ref<nix::Store> store_; }; -std::unique_ptr<WorkerService::Service> NewWorkerService(nix::Store* store) { - return std::make_unique<WorkerServiceImpl>(store); +WorkerService::Service* NewWorkerService(nix::Store& store) { + return new WorkerServiceImpl(store); } } // namespace nix::daemon |