| OLD | NEW |
| 1 // Copyright 2017 The Chromium Authors. All rights reserved. | 1 // Copyright 2017 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 "cc/ipc/copy_output_result_struct_traits.h" | 5 #include "cc/ipc/copy_output_result_struct_traits.h" |
| 6 | 6 |
| 7 namespace mojo { | 7 namespace mojo { |
| 8 | 8 |
| 9 // static | 9 // static |
| 10 bool StructTraits<cc::mojom::CopyOutputResultDataView, cc::CopyOutputResult>:: | 10 bool StructTraits<cc::mojom::CopyOutputResultDataView, |
| 11 Read(cc::mojom::CopyOutputResultDataView data, cc::CopyOutputResult* out) { | 11 std::unique_ptr<cc::CopyOutputResult>>:: |
| 12 out->bitmap_ = base::MakeUnique<SkBitmap>(); | 12 Read(cc::mojom::CopyOutputResultDataView data, |
| 13 return data.ReadSize(&out->size_) && data.ReadBitmap(out->bitmap_.get()) && | 13 std::unique_ptr<cc::CopyOutputResult>* out_p) { |
| 14 data.ReadTextureMailbox(&out->texture_mailbox_); | 14 auto result = cc::CopyOutputResult::CreateEmptyResult(); |
| 15 |
| 16 if (!data.ReadSize(&result->size_)) |
| 17 return false; |
| 18 |
| 19 result->bitmap_ = base::MakeUnique<SkBitmap>(); |
| 20 if (!data.ReadBitmap(result->bitmap_.get())) |
| 21 return false; |
| 22 |
| 23 if (!data.ReadTextureMailbox(&result->texture_mailbox_)) |
| 24 return false; |
| 25 |
| 26 *out_p = std::move(result); |
| 27 |
| 28 return true; |
| 15 } | 29 } |
| 16 | 30 |
| 17 // static | 31 // static |
| 18 const SkBitmap& | 32 const SkBitmap& StructTraits<cc::mojom::CopyOutputResultDataView, |
| 19 StructTraits<cc::mojom::CopyOutputResultDataView, cc::CopyOutputResult>::bitmap( | 33 std::unique_ptr<cc::CopyOutputResult>>:: |
| 20 const cc::CopyOutputResult& result) { | 34 bitmap(const std::unique_ptr<cc::CopyOutputResult>& result) { |
| 21 static SkBitmap* null_bitmap = new SkBitmap(); | 35 static SkBitmap* null_bitmap = new SkBitmap(); |
| 22 if (!result.bitmap_) | 36 if (!result->bitmap_) |
| 23 return *null_bitmap; | 37 return *null_bitmap; |
| 24 return *result.bitmap_; | 38 return *result->bitmap_; |
| 25 } | 39 } |
| 26 | 40 |
| 27 } // namespace mojo | 41 } // namespace mojo |
| OLD | NEW |