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

Side by Side Diff: ipc/handle_attachment_win.cc

Issue 1206093002: Update ChannelReader to use AttachmentBroker. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@attachment_broker3_listener
Patch Set: Created 5 years, 5 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
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "ipc/handle_attachment_win.h" 5 #include "ipc/handle_attachment_win.h"
6 6
7 #include <windows.h> 7 #include <windows.h>
8 8
9 namespace IPC { 9 namespace IPC {
10 namespace internal { 10 namespace internal {
11 11
12 HandleAttachmentWin::HandleAttachmentWin(const HANDLE& handle) 12 HandleAttachmentWin::HandleAttachmentWin(const HANDLE& handle)
13 : handle_(handle) { 13 : handle_(handle) {
14 } 14 }
15 15
16 HandleAttachmentWin::HandleAttachmentWin(const WireFormat& wire_format) 16 HandleAttachmentWin::HandleAttachmentWin(const WireFormat& wire_format)
17 : BrokerableAttachment(wire_format.attachment_id), 17 : BrokerableAttachment(wire_format.attachment_id, false),
18 handle_(LongToHandle(wire_format.handle)) { 18 handle_(LongToHandle(wire_format.handle)) {
19 } 19 }
20 20
21 HandleAttachmentWin::HandleAttachmentWin(
22 const BrokerableAttachment::AttachmentId& id)
23 : BrokerableAttachment(id, true), handle_(INVALID_HANDLE_VALUE) {
24 }
25
21 HandleAttachmentWin::~HandleAttachmentWin() { 26 HandleAttachmentWin::~HandleAttachmentWin() {
22 } 27 }
23 28
24 HandleAttachmentWin::BrokerableType HandleAttachmentWin::GetBrokerableType() 29 HandleAttachmentWin::BrokerableType HandleAttachmentWin::GetBrokerableType()
25 const { 30 const {
26 return WIN_HANDLE; 31 return WIN_HANDLE;
27 } 32 }
28 33
34 void HandleAttachmentWin::PopulateWithAttachment(
35 const BrokerableAttachment* attachment) {
36 DCHECK(NeedsBrokering());
37 DCHECK(!attachment->NeedsBrokering());
38 DCHECK(GetIdentifier() == attachment->GetIdentifier());
39 DCHECK_EQ(GetBrokerableType(), attachment->GetBrokerableType());
40
41 const HandleAttachmentWin* handle_attachment =
42 static_cast<const HandleAttachmentWin*>(attachment);
43 handle_ = handle_attachment->handle_;
44 SetNeedsBrokering(false);
45 }
46
29 HandleAttachmentWin::WireFormat HandleAttachmentWin::GetWireFormat( 47 HandleAttachmentWin::WireFormat HandleAttachmentWin::GetWireFormat(
30 const base::ProcessId& destination) const { 48 const base::ProcessId& destination) const {
31 WireFormat format; 49 WireFormat format;
32 format.handle = HandleToLong(handle_); 50 format.handle = HandleToLong(handle_);
33 format.attachment_id = GetIdentifier(); 51 format.attachment_id = GetIdentifier();
34 format.destination_process = destination; 52 format.destination_process = destination;
35 return format; 53 return format;
36 } 54 }
37 55
38 } // namespace internal 56 } // namespace internal
39 } // namespace IPC 57 } // namespace IPC
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698