diff options
author | jamesr@chromium.org <jamesr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-08-25 00:09:14 +0000 |
---|---|---|
committer | jamesr@chromium.org <jamesr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-08-25 00:09:14 +0000 |
commit | 94f206c1c75eb8cc4df2225a1c5c9c7b6fc96679 (patch) | |
tree | 530f51d5c75459999e4adf2a6895884ce1c15ce0 /cc/CCScopedTexture.cpp | |
parent | 56235947f2b023fc63cfad692c56df4e92199848 (diff) | |
download | chromium_src-94f206c1c75eb8cc4df2225a1c5c9c7b6fc96679.zip chromium_src-94f206c1c75eb8cc4df2225a1c5c9c7b6fc96679.tar.gz chromium_src-94f206c1c75eb8cc4df2225a1c5c9c7b6fc96679.tar.bz2 |
Here are gyp targets and stubs for compiling libcc and the webkit_compositor bindings in chromium. Everything is guarded behind the off-by-default use_libcc_for_compositor gyp variable. I haven't included the actual code here, but there are scripts to sync. I plan to land + manually sync the code into place until we're ready to flip the gyp switch.
Snapshot from r126652
BUG=
Review URL: https://chromiumcodereview.appspot.com/10828381
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@153354 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'cc/CCScopedTexture.cpp')
-rw-r--r-- | cc/CCScopedTexture.cpp | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/cc/CCScopedTexture.cpp b/cc/CCScopedTexture.cpp new file mode 100644 index 0000000..b032680 --- /dev/null +++ b/cc/CCScopedTexture.cpp @@ -0,0 +1,51 @@ +// Copyright 2012 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. + +#include "config.h" + +#include "CCScopedTexture.h" + +namespace WebCore { + +CCScopedTexture::CCScopedTexture(CCResourceProvider* resourceProvider) + : m_resourceProvider(resourceProvider) +{ + ASSERT(m_resourceProvider); +} + +CCScopedTexture::~CCScopedTexture() +{ + free(); +} + +bool CCScopedTexture::allocate(int pool, const IntSize& size, GC3Denum format, CCResourceProvider::TextureUsageHint hint) +{ + ASSERT(!id()); + ASSERT(!size.isEmpty()); + + setDimensions(size, format); + setId(m_resourceProvider->createResource(pool, size, format, hint)); + +#if !ASSERT_DISABLED + m_allocateThreadIdentifier = WTF::currentThread(); +#endif + + return id(); +} + +void CCScopedTexture::free() +{ + if (id()) { + ASSERT(m_allocateThreadIdentifier == WTF::currentThread()); + m_resourceProvider->deleteResource(id()); + } + setId(0); +} + +void CCScopedTexture::leak() +{ + setId(0); +} + +} |