| // Copyright 2015 The Chromium Authors. All rights reserved. | 
 | // Use of this source code is governed by a BSD-style license that can be | 
 | // found in the LICENSE file. | 
 |  | 
 | #include "ipc/ipc_mojo_param_traits.h" | 
 |  | 
 | #include "ipc/ipc_message_utils.h" | 
 | #include "ipc/ipc_mojo_handle_attachment.h" | 
 | #include "ipc/ipc_mojo_message_helper.h" | 
 |  | 
 | namespace IPC { | 
 |  | 
 | void ParamTraits<mojo::MessagePipeHandle>::GetSize(base::PickleSizer* sizer, | 
 |                                                    const param_type& p) { | 
 |   GetParamSize(sizer, p.is_valid()); | 
 |   if (p.is_valid()) | 
 |     sizer->AddAttachment(); | 
 | } | 
 |  | 
 | void ParamTraits<mojo::MessagePipeHandle>::Write(base::Pickle* m, | 
 |                                                  const param_type& p) { | 
 |   WriteParam(m, p.is_valid()); | 
 |   if (p.is_valid()) | 
 |     MojoMessageHelper::WriteMessagePipeTo(m, mojo::ScopedMessagePipeHandle(p)); | 
 | } | 
 |  | 
 | bool ParamTraits<mojo::MessagePipeHandle>::Read(const base::Pickle* m, | 
 |                                                 base::PickleIterator* iter, | 
 |                                                 param_type* r) { | 
 |   bool is_valid; | 
 |   if (!ReadParam(m, iter, &is_valid)) | 
 |     return false; | 
 |   if (!is_valid) | 
 |     return true; | 
 |  | 
 |   mojo::ScopedMessagePipeHandle handle; | 
 |   if (!MojoMessageHelper::ReadMessagePipeFrom(m, iter, &handle)) | 
 |     return false; | 
 |   DCHECK(handle.is_valid()); | 
 |   *r = handle.release(); | 
 |   return true; | 
 | } | 
 |  | 
 | void ParamTraits<mojo::MessagePipeHandle>::Log(const param_type& p, | 
 |                                                std::string* l) { | 
 |   l->append("mojo::MessagePipeHandle("); | 
 |   LogParam(p.value(), l); | 
 |   l->append(")"); | 
 | } | 
 |  | 
 | void ParamTraits<mojo::DataPipeConsumerHandle>::GetSize( | 
 |     base::PickleSizer* sizer, | 
 |     const param_type& p) { | 
 |   GetParamSize(sizer, p.is_valid()); | 
 |   if (p.is_valid()) | 
 |     sizer->AddAttachment(); | 
 | } | 
 |  | 
 | void ParamTraits<mojo::DataPipeConsumerHandle>::Write(base::Pickle* m, | 
 |                                                       const param_type& p) { | 
 |   WriteParam(m, p.is_valid()); | 
 |   if (!p.is_valid()) | 
 |     return; | 
 |  | 
 |   m->WriteAttachment(new internal::MojoHandleAttachment( | 
 |       mojo::ScopedHandle::From(mojo::ScopedDataPipeConsumerHandle(p)))); | 
 | } | 
 |  | 
 | bool ParamTraits<mojo::DataPipeConsumerHandle>::Read(const base::Pickle* m, | 
 |                                                      base::PickleIterator* iter, | 
 |                                                      param_type* r) { | 
 |   bool is_valid; | 
 |   if (!ReadParam(m, iter, &is_valid)) | 
 |     return false; | 
 |   if (!is_valid) | 
 |     return true; | 
 |  | 
 |   scoped_refptr<base::Pickle::Attachment> attachment; | 
 |   if (!m->ReadAttachment(iter, &attachment)) { | 
 |     DLOG(ERROR) << "Failed to read attachment for message pipe."; | 
 |     return false; | 
 |   } | 
 |  | 
 |   MessageAttachment::Type type = | 
 |       static_cast<MessageAttachment*>(attachment.get())->GetType(); | 
 |   if (type != MessageAttachment::Type::MOJO_HANDLE) { | 
 |     DLOG(ERROR) << "Unexpected attachment type:" << type; | 
 |     return false; | 
 |   } | 
 |  | 
 |   mojo::ScopedDataPipeConsumerHandle handle; | 
 |   handle.reset(mojo::DataPipeConsumerHandle( | 
 |       static_cast<internal::MojoHandleAttachment*>(attachment.get()) | 
 |           ->TakeHandle() | 
 |           .release() | 
 |           .value())); | 
 |   DCHECK(handle.is_valid()); | 
 |   *r = handle.release(); | 
 |   return true; | 
 | } | 
 |  | 
 | void ParamTraits<mojo::DataPipeConsumerHandle>::Log(const param_type& p, | 
 |                                                     std::string* l) { | 
 |   l->append("mojo::DataPipeConsumerHandle("); | 
 |   LogParam(p.value(), l); | 
 |   l->append(")"); | 
 | } | 
 |  | 
 | }  // namespace IPC |