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

Side by Side Diff: services/surfaces/surfaces_impl.cc

Issue 807733002: Split surface id and simplify connecting to surfaces service (Closed) Base URL: git@github.com:domokit/mojo.git@master
Patch Set: Created 6 years 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 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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 "services/surfaces/surfaces_impl.h" 5 #include "services/surfaces/surfaces_impl.h"
6 6
7 #include "base/debug/trace_event.h" 7 #include "base/debug/trace_event.h"
8 #include "cc/output/compositor_frame.h" 8 #include "cc/output/compositor_frame.h"
9 #include "cc/resources/returned_resource.h" 9 #include "cc/resources/returned_resource.h"
10 #include "cc/surfaces/display.h" 10 #include "cc/surfaces/display.h"
11 #include "cc/surfaces/surface_id_allocator.h" 11 #include "cc/surfaces/surface_id_allocator.h"
12 #include "mojo/cc/context_provider_mojo.h" 12 #include "mojo/cc/context_provider_mojo.h"
13 #include "mojo/cc/direct_output_surface.h" 13 #include "mojo/cc/direct_output_surface.h"
14 #include "mojo/converters/geometry/geometry_type_converters.h" 14 #include "mojo/converters/geometry/geometry_type_converters.h"
15 #include "mojo/converters/surfaces/surfaces_type_converters.h" 15 #include "mojo/converters/surfaces/surfaces_type_converters.h"
16 16
17 using mojo::SurfaceIdPtr; 17 using mojo::SurfaceIdPtr;
18 18
19 namespace surfaces { 19 namespace surfaces {
20 20
21 namespace { 21 namespace {
22 void CallCallback(const mojo::Closure& callback) { 22 void CallCallback(const mojo::Closure& callback) {
23 callback.Run(); 23 callback.Run();
24 } 24 }
25 } 25 }
26 26
27 SurfacesImpl::SurfacesImpl(cc::SurfaceManager* manager, 27 SurfacesImpl::SurfacesImpl(cc::SurfaceManager* manager,
sky 2014/12/16 03:34:04 nit: move to match position in header.
28 uint32_t id_namespace, 28 uint32_t id_namespace,
29 Client* client)
30 : manager_(manager),
31 factory_(manager, this),
32 id_namespace_(id_namespace),
33 client_(client),
34 binding_(this) {
35 }
36
37 SurfacesImpl::SurfacesImpl(cc::SurfaceManager* manager,
38 uint32_t id_namespace,
39 Client* client,
40 mojo::InterfaceRequest<mojo::Surface> request)
41 : SurfacesImpl(manager, id_namespace, client) {
42 binding_.Bind(request.Pass());
43 binding_.client()->SetIdNamespace(id_namespace);
44 }
45
46 SurfacesImpl::SurfacesImpl(cc::SurfaceManager* manager,
47 uint32_t id_namespace,
29 Client* client, 48 Client* client,
30 mojo::SurfacePtr* surface) 49 mojo::SurfacePtr* surface)
31 : manager_(manager), 50 : SurfacesImpl(manager, id_namespace, client) {
32 factory_(manager, this), 51 binding_.Bind(surface);
33 id_namespace_(id_namespace), 52 binding_.client()->SetIdNamespace(id_namespace);
34 client_(client),
35 binding_(this, surface) {
36 } 53 }
37 54
38 SurfacesImpl::~SurfacesImpl() { 55 SurfacesImpl::~SurfacesImpl() {
39 client_->OnDisplayBeingDestroyed(display_.get()); 56 client_->OnDisplayBeingDestroyed(display_.get());
40 factory_.DestroyAll(); 57 factory_.DestroyAll();
41 } 58 }
42 59
43 void SurfacesImpl::CreateSurface(SurfaceIdPtr id, mojo::SizePtr size) { 60 void SurfacesImpl::CreateSurface(SurfaceIdPtr id) {
44 cc::SurfaceId cc_id = id.To<cc::SurfaceId>(); 61 cc::SurfaceId cc_id = id.To<cc::SurfaceId>();
45 if (cc::SurfaceIdAllocator::NamespaceForId(cc_id) != id_namespace_) { 62 if (cc::SurfaceIdAllocator::NamespaceForId(cc_id) != id_namespace_) {
46 // Bad message, do something bad to the caller? 63 // Bad message, do something bad to the caller?
47 NOTREACHED(); 64 NOTREACHED();
48 return; 65 return;
49 } 66 }
50 factory_.Create(id.To<cc::SurfaceId>()); 67 factory_.Create(id.To<cc::SurfaceId>());
51 } 68 }
52 69
53 void SurfacesImpl::SubmitFrame(SurfaceIdPtr id, 70 void SurfacesImpl::SubmitFrame(SurfaceIdPtr id,
(...skipping 80 matching lines...) Expand 10 before | Expand all | Expand 10 after
134 } 151 }
135 152
136 void SurfacesImpl::OnVSyncParametersUpdated(int64_t timebase, 153 void SurfacesImpl::OnVSyncParametersUpdated(int64_t timebase,
137 int64_t interval) { 154 int64_t interval) {
138 client_->OnVSyncParametersUpdated( 155 client_->OnVSyncParametersUpdated(
139 base::TimeTicks::FromInternalValue(timebase), 156 base::TimeTicks::FromInternalValue(timebase),
140 base::TimeDelta::FromInternalValue(interval)); 157 base::TimeDelta::FromInternalValue(interval));
141 } 158 }
142 159
143 } // namespace mojo 160 } // namespace mojo
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698