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

Side by Side Diff: gpu/command_buffer/service/renderbuffer_manager.cc

Issue 2880013: Free the resources used by a context group. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: '' Created 10 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 | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2010 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 "gpu/command_buffer/service/renderbuffer_manager.h" 5 #include "gpu/command_buffer/service/renderbuffer_manager.h"
6 #include "base/logging.h" 6 #include "base/logging.h"
7 #include "gpu/command_buffer/common/gles2_cmd_utils.h" 7 #include "gpu/command_buffer/common/gles2_cmd_utils.h"
8 #include "gpu/command_buffer/service/gles2_cmd_decoder.h" 8 #include "gpu/command_buffer/service/gles2_cmd_decoder.h"
9 9
10 namespace gpu { 10 namespace gpu {
11 namespace gles2 { 11 namespace gles2 {
12 12
13 RenderbufferManager::~RenderbufferManager() {
14 DCHECK(renderbuffer_infos_.empty());
15 }
16
17 void RenderbufferManager::Destroy(bool have_context) {
18 while (!renderbuffer_infos_.empty()) {
19 if (have_context) {
20 RenderbufferInfo* info = renderbuffer_infos_.begin()->second;
21 if (!info->IsDeleted()) {
22 GLuint service_id = info->service_id();
23 glDeleteRenderbuffersEXT(1, &service_id);
24 info->MarkAsDeleted();
25 }
26 }
27 renderbuffer_infos_.erase(renderbuffer_infos_.begin());
28 }
29 }
30
13 void RenderbufferManager::CreateRenderbufferInfo( 31 void RenderbufferManager::CreateRenderbufferInfo(
14 GLuint client_id, GLuint service_id) { 32 GLuint client_id, GLuint service_id) {
15 std::pair<RenderbufferInfoMap::iterator, bool> result = 33 std::pair<RenderbufferInfoMap::iterator, bool> result =
16 renderbuffer_infos_.insert( 34 renderbuffer_infos_.insert(
17 std::make_pair( 35 std::make_pair(
18 client_id, 36 client_id,
19 RenderbufferInfo::Ref(new RenderbufferInfo(service_id)))); 37 RenderbufferInfo::Ref(new RenderbufferInfo(service_id))));
20 DCHECK(result.second); 38 DCHECK(result.second);
21 } 39 }
22 40
(...skipping 21 matching lines...) Expand all
44 return true; 62 return true;
45 } 63 }
46 } 64 }
47 return false; 65 return false;
48 } 66 }
49 67
50 } // namespace gles2 68 } // namespace gles2
51 } // namespace gpu 69 } // namespace gpu
52 70
53 71
OLDNEW
« no previous file with comments | « gpu/command_buffer/service/renderbuffer_manager.h ('k') | gpu/command_buffer/service/renderbuffer_manager_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698