Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(143)

Side by Side Diff: services/flog/flog_logger_impl.cc

Issue 2046703002: Add 'flog' service implementation. (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: Fixes per feedback. Created 4 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « services/flog/flog_logger_impl.h ('k') | services/flog/flog_reader_impl.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 // Copyright 2016 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "base/logging.h"
6 #include "services/flog/flog_logger_impl.h"
7
8 namespace mojo {
9 namespace flog {
10
11 // static
12 std::shared_ptr<FlogLoggerImpl> FlogLoggerImpl::Create(
13 InterfaceRequest<FlogLogger> request,
14 uint32_t log_id,
15 const std::string& label,
16 std::shared_ptr<FlogDirectory> directory,
17 FlogServiceImpl* owner) {
18 return std::shared_ptr<FlogLoggerImpl>(
19 new FlogLoggerImpl(request.Pass(), log_id, label, directory, owner));
20 }
21
22 FlogLoggerImpl::FlogLoggerImpl(InterfaceRequest<FlogLogger> request,
23 uint32_t log_id,
24 const std::string& label,
25 std::shared_ptr<FlogDirectory> directory,
26 FlogServiceImpl* owner)
27 : FlogServiceImpl::ProductBase(owner),
28 file_(directory->GetFile(log_id, label, true)) {
29 mojo::internal::MessageValidatorList validators;
30 router_.reset(new mojo::internal::Router(
31 request.PassMessagePipe(), std::move(validators),
32 Environment::GetDefaultAsyncWaiter()));
33 router_->set_incoming_receiver(this);
34 router_->set_connection_error_handler([this]() { ReleaseFromOwner(); });
35 }
36
37 FlogLoggerImpl::~FlogLoggerImpl() {}
38
39 bool FlogLoggerImpl::Accept(Message* message) {
40 DCHECK(message != nullptr);
41 DCHECK(message->data_num_bytes() > 0);
42 DCHECK(message->data() != nullptr);
43
44 uint32_t message_size = message->data_num_bytes();
45
46 WriteData(sizeof(message_size), &message_size);
47 WriteData(message_size, message->data());
48
49 return true;
50 }
51
52 bool FlogLoggerImpl::AcceptWithResponder(Message* message,
53 MessageReceiverWithStatus* responder) {
54 DCHECK(false) << "FlogLogger has no methods with responses";
55 abort();
56 }
57
58 void FlogLoggerImpl::WriteData(uint32_t data_size, const void* data) {
59 DCHECK(data_size > 0);
60 DCHECK(data != nullptr);
61 DCHECK(file_);
62
63 Array<uint8_t> bytes_to_write = Array<uint8_t>::New(data_size);
64 memcpy(bytes_to_write.data(), data, data_size);
65 file_->Write(bytes_to_write.Pass(), 0, files::Whence::FROM_CURRENT,
66 [data_size](files::Error error, uint32 bytes_written) {
67 DCHECK(error == files::Error::OK);
68 DCHECK(bytes_written == data_size);
69 // TODO(dalesat): Handle error.
70 });
71 }
72
73 } // namespace flog
74 } // namespace mojo
OLDNEW
« no previous file with comments | « services/flog/flog_logger_impl.h ('k') | services/flog/flog_reader_impl.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698