// Copyright 2013 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CC_RESOURCES_TEXTURE_MAILBOX_DELETER_H_
#define CC_RESOURCES_TEXTURE_MAILBOX_DELETER_H_
#include "base/memory/weak_ptr.h"
#include "cc/base/cc_export.h"
#include "cc/base/scoped_ptr_vector.h"
namespace cc {
class ContextProvider;
class SingleReleaseCallback;
class CC_EXPORT TextureMailboxDeleter {
public:
TextureMailboxDeleter();
~TextureMailboxDeleter();
// Returns a Callback that can be used as the ReleaseCallback for a
// TextureMailbox attached to the |texture_id|. The ReleaseCallback can
// be passed to other threads and will destroy the texture, once it is
// run, on the impl thread. If the TextureMailboxDeleter is destroyed
// due to the compositor shutting down, then the ReleaseCallback will
// become a no-op and the texture will be deleted immediately on the
// impl thread, along with dropping the reference to the ContextProvider.
scoped_ptr<SingleReleaseCallback> GetReleaseCallback(
const scoped_refptr<ContextProvider>& context_provider,
unsigned texture_id);
private:
// Runs the |impl_callback| to delete the texture and removes the callback
// from the |impl_callbacks_| list.
void RunDeleteTextureOnImplThread(
SingleReleaseCallback* impl_callback,
unsigned sync_point,
bool is_lost);
ScopedPtrVector<SingleReleaseCallback> impl_callbacks_;
base::WeakPtrFactory<TextureMailboxDeleter> weak_ptr_factory_;
};
} // namespace cc
#endif // CC_RESOURCES_TEXTURE_MAILBOX_DELETER_H_