| Index: gpu/command_buffer/service/texture_manager.cc
|
| diff --git a/gpu/command_buffer/service/texture_manager.cc b/gpu/command_buffer/service/texture_manager.cc
|
| index 54b2eafdcde9d4cdf75ca64988c4df0ee714b332..810867a07bf0d3f2d9e097dae5b8a5be8ab42ad3 100644
|
| --- a/gpu/command_buffer/service/texture_manager.cc
|
| +++ b/gpu/command_buffer/service/texture_manager.cc
|
| @@ -27,6 +27,7 @@
|
| #include "gpu/command_buffer/service/gles2_cmd_decoder.h"
|
| #include "gpu/command_buffer/service/mailbox_manager.h"
|
| #include "gpu/command_buffer/service/memory_tracking.h"
|
| +#include "gpu/command_buffer/service/progress_reporter.h"
|
| #include "ui/gl/gl_context.h"
|
| #include "ui/gl/gl_implementation.h"
|
| #include "ui/gl/gl_state_restorer.h"
|
| @@ -361,9 +362,14 @@ TextureManager::~TextureManager() {
|
|
|
| void TextureManager::Destroy(bool have_context) {
|
| have_context_ = have_context;
|
| - textures_.clear();
|
| +
|
| + while (!textures_.empty()) {
|
| + textures_.erase(textures_.begin());
|
| + progress_reporter_->ReportProgress();
|
| + }
|
| for (int ii = 0; ii < kNumDefaultTextures; ++ii) {
|
| default_textures_[ii] = NULL;
|
| + progress_reporter_->ReportProgress();
|
| }
|
|
|
| if (have_context) {
|
| @@ -1786,7 +1792,8 @@ TextureManager::TextureManager(MemoryTracker* memory_tracker,
|
| GLint max_rectangle_texture_size,
|
| GLint max_3d_texture_size,
|
| GLint max_array_texture_layers,
|
| - bool use_default_textures)
|
| + bool use_default_textures,
|
| + ProgressReporter* progress_reporter)
|
| : memory_type_tracker_(new MemoryTypeTracker(memory_tracker)),
|
| memory_tracker_(memory_tracker),
|
| feature_info_(feature_info),
|
| @@ -1814,7 +1821,9 @@ TextureManager::TextureManager(MemoryTracker* memory_tracker,
|
| num_images_(0),
|
| texture_count_(0),
|
| have_context_(true),
|
| - current_service_id_generation_(0) {
|
| + current_service_id_generation_(0),
|
| + progress_reporter_(progress_reporter) {
|
| + DCHECK(progress_reporter_);
|
| for (int ii = 0; ii < kNumDefaultTextures; ++ii) {
|
| black_texture_ids_[ii] = 0;
|
| }
|
|
|