forked from chromium/chromium
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Only use skia::RefPtr for refcounting
For consistency and sanity in Chromium, only use skia::RefPtr in Chromium to ref count skia classes. SkRefPtr is unsafe to use for newly created objects because it refs the object that is passed to its constructor. skia::RefPtr makes this adoption explicit it via skia::AdoptRef and so is much clearer. This patch also adds a skia::ShareRef function which makes it explicit that the callsite is adopting a ref which is already owned somewhere else. Using AdoptRef vs. ShareRef seems much clearer than using SkRefPtr vs. skia::RefPtr. These are the remaining code sites that use internal Skia reference counted classes. Once these have been removed, then we can use a PRESUBMIT rule to prevent new uses from being added. BUG=none Review URL: https://chromiumcodereview.appspot.com/15004024 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@200989 0039d316-1c4b-4281-b951-d872f2087c98
- Loading branch information
enne@chromium.org
committed
May 18, 2013
1 parent
5a26074
commit 584abe7
Showing
12 changed files
with
187 additions
and
121 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,82 @@ | ||
// 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 "cc/test/skia_common.h" | ||
|
||
#include "cc/resources/picture.h" | ||
#include "skia/ext/refptr.h" | ||
#include "third_party/skia/include/core/SkDevice.h" | ||
#include "ui/gfx/rect.h" | ||
#include "ui/gfx/skia_util.h" | ||
|
||
namespace cc { | ||
|
||
TestPixelRef::TestPixelRef(int width, int height) | ||
: pixels_(new char[4 * width * height]) {} | ||
|
||
TestPixelRef::~TestPixelRef() {} | ||
|
||
SkFlattenable::Factory TestPixelRef::getFactory() { return NULL; } | ||
|
||
void* TestPixelRef::onLockPixels(SkColorTable** color_table) { | ||
return pixels_.get(); | ||
} | ||
|
||
SkPixelRef* TestPixelRef::deepCopy( | ||
SkBitmap::Config config, | ||
const SkIRect* subset) { | ||
this->ref(); | ||
return this; | ||
} | ||
|
||
|
||
TestLazyPixelRef::TestLazyPixelRef(int width, int height) | ||
: pixels_(new char[4 * width * height]) {} | ||
|
||
TestLazyPixelRef::~TestLazyPixelRef() {} | ||
|
||
SkFlattenable::Factory TestLazyPixelRef::getFactory() { return NULL; } | ||
|
||
void* TestLazyPixelRef::onLockPixels(SkColorTable** color_table) { | ||
return pixels_.get(); | ||
} | ||
|
||
bool TestLazyPixelRef::PrepareToDecode(const PrepareParams& params) { | ||
return true; | ||
} | ||
|
||
SkPixelRef* TestLazyPixelRef::deepCopy( | ||
SkBitmap::Config config, | ||
const SkIRect* subset) { | ||
this->ref(); | ||
return this; | ||
} | ||
|
||
void DrawPicture(unsigned char* buffer, | ||
gfx::Rect layer_rect, | ||
scoped_refptr<Picture> picture) { | ||
SkBitmap bitmap; | ||
bitmap.setConfig(SkBitmap::kARGB_8888_Config, | ||
layer_rect.width(), | ||
layer_rect.height()); | ||
bitmap.setPixels(buffer); | ||
SkDevice device(bitmap); | ||
SkCanvas canvas(&device); | ||
canvas.clipRect(gfx::RectToSkRect(layer_rect)); | ||
picture->Raster(&canvas, layer_rect, 1.0f, false); | ||
} | ||
|
||
void CreateBitmap(gfx::Size size, const char* uri, SkBitmap* bitmap) { | ||
skia::RefPtr<TestLazyPixelRef> lazy_pixel_ref = | ||
skia::AdoptRef(new TestLazyPixelRef(size.width(), size.height())); | ||
lazy_pixel_ref->setURI(uri); | ||
|
||
bitmap->setConfig(SkBitmap::kARGB_8888_Config, | ||
size.width(), | ||
size.height()); | ||
bitmap->setPixelRef(lazy_pixel_ref.get()); | ||
} | ||
|
||
|
||
} // namespace cc |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,62 @@ | ||
// 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. | ||
|
||
#ifndef CC_TEST_SKIA_COMMON_H_ | ||
#define CC_TEST_SKIA_COMMON_H_ | ||
|
||
#include "base/memory/ref_counted.h" | ||
#include "base/memory/scoped_ptr.h" | ||
#include "skia/ext/lazy_pixel_ref.h" | ||
#include "third_party/skia/include/core/SkBitmap.h" | ||
#include "third_party/skia/include/core/SkFlattenable.h" | ||
|
||
namespace gfx { | ||
class Rect; | ||
class Size; | ||
} | ||
|
||
namespace cc { | ||
class Picture; | ||
|
||
class TestPixelRef : public SkPixelRef { | ||
public: | ||
TestPixelRef(int width, int height); | ||
virtual ~TestPixelRef(); | ||
|
||
virtual SkFlattenable::Factory getFactory() OVERRIDE; | ||
virtual void* onLockPixels(SkColorTable** color_table) OVERRIDE; | ||
virtual void onUnlockPixels() OVERRIDE {} | ||
virtual SkPixelRef* deepCopy( | ||
SkBitmap::Config config, | ||
const SkIRect* subset) OVERRIDE; | ||
private: | ||
scoped_ptr<char[]> pixels_; | ||
}; | ||
|
||
class TestLazyPixelRef : public skia::LazyPixelRef { | ||
public: | ||
TestLazyPixelRef(int width, int height); | ||
virtual ~TestLazyPixelRef(); | ||
|
||
virtual SkFlattenable::Factory getFactory() OVERRIDE; | ||
virtual void* onLockPixels(SkColorTable** color_table) OVERRIDE; | ||
virtual void onUnlockPixels() OVERRIDE {} | ||
virtual bool PrepareToDecode(const PrepareParams& params) OVERRIDE; | ||
virtual SkPixelRef* deepCopy( | ||
SkBitmap::Config config, | ||
const SkIRect* subset) OVERRIDE; | ||
virtual void Decode() OVERRIDE {} | ||
private: | ||
scoped_ptr<char[]> pixels_; | ||
}; | ||
|
||
void DrawPicture(unsigned char* buffer, | ||
gfx::Rect layer_rect, | ||
scoped_refptr<Picture> picture); | ||
|
||
void CreateBitmap(gfx::Size size, const char* uri, SkBitmap* bitmap); | ||
|
||
} // namespace cc | ||
|
||
#endif // CC_TEST_SKIA_COMMON_H_ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.