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

Side by Side Diff: content/browser/renderer_host/offscreen_canvas_surface_manager.cc

Issue 2479563005: Create manager to track OffscreenCanvasSurfaceImpl instances (Closed)
Patch Set: Created 4 years, 1 month 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
(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 "content/browser/renderer_host/offscreen_canvas_surface_manager.h"
6
7 namespace content {
8
9 namespace {
10 OffscreenCanvasSurfaceManager* g_manager = NULL;
11 }
12
13 OffscreenCanvasSurfaceManager::OffscreenCanvasSurfaceManager() {}
14
15 OffscreenCanvasSurfaceManager::~OffscreenCanvasSurfaceManager() {
16 registered_surface_instances_.clear();
17 registered_compositor_frame_sink_instances_.clear();
18 }
19
20 OffscreenCanvasSurfaceManager* OffscreenCanvasSurfaceManager::GetInstance() {
21 if (!g_manager) {
22 g_manager = new OffscreenCanvasSurfaceManager();
dcheng 2016/11/08 18:30:23 Let's just use a leaky LazyInstance, unless there'
xlai (Olivia) 2016/11/10 15:45:11 I'm following the example of ImageTransportFactory
dcheng 2016/11/11 08:36:40 I guess I'm missing something still. Don't the obj
23 }
24 return g_manager;
25 }
26
27 void OffscreenCanvasSurfaceManager::Terminate() {
28 if (g_manager) {
29 delete g_manager;
30 g_manager = NULL;
31 }
32 }
33
34 void OffscreenCanvasSurfaceManager::RegisterOffscreenCanvasSurfaceInstance(
35 int canvas_id,
36 OffscreenCanvasSurfaceImpl* surface_instance) {
37 DCHECK(surface_instance);
38 DCHECK_EQ(registered_surface_instances_.count(canvas_id), 0u);
39 registered_surface_instances_[canvas_id] = surface_instance->GetWeakPtr();
40 }
41
42 void OffscreenCanvasSurfaceManager::UnregisterOffscreenCanvasSurfaceInstance(
43 int canvas_id) {
44 DCHECK_EQ(registered_surface_instances_.count(canvas_id), 1u);
45 registered_surface_instances_.erase(canvas_id);
46 }
47
48 void OffscreenCanvasSurfaceManager::RegisterCompositorFrameSinkInstance(
49 int canvas_id,
50 OffscreenCanvasCompositorFrameSink* surface_instance) {
51 DCHECK(surface_instance);
52 DCHECK_EQ(registered_compositor_frame_sink_instances_.count(canvas_id), 0u);
53 registered_compositor_frame_sink_instances_[canvas_id] =
54 surface_instance->GetWeakPtr();
55 }
56
57 void OffscreenCanvasSurfaceManager::UnregisterCompositorFrameSinkInstance(
58 int canvas_id) {
59 DCHECK_EQ(registered_compositor_frame_sink_instances_.count(canvas_id), 1u);
60 registered_compositor_frame_sink_instances_.erase(canvas_id);
61 }
62
63 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698