| OLD | NEW |
| (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 |
| OLD | NEW |