aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--src/core/SkBitmapHeap.cpp13
-rw-r--r--src/core/SkBitmapHeap.h9
-rw-r--r--src/core/SkPictureData.cpp43
-rw-r--r--src/core/SkPictureData.h12
-rw-r--r--src/core/SkPictureFlat.h17
-rw-r--r--src/core/SkTRefArray.h112
-rw-r--r--tests/RefCntTest.cpp43
7 files changed, 24 insertions, 225 deletions
diff --git a/src/core/SkBitmapHeap.cpp b/src/core/SkBitmapHeap.cpp
index efaa23fc64..07e65fb3e2 100644
--- a/src/core/SkBitmapHeap.cpp
+++ b/src/core/SkBitmapHeap.cpp
@@ -111,19 +111,6 @@ SkBitmapHeap::~SkBitmapHeap() {
fLookupTable.deleteAll();
}
-SkTRefArray<SkBitmap>* SkBitmapHeap::extractBitmaps() const {
- const int size = fStorage.count();
- SkTRefArray<SkBitmap>* array = NULL;
- if (size > 0) {
- array = SkTRefArray<SkBitmap>::Create(size);
- for (int i = 0; i < size; i++) {
- // make a shallow copy of the bitmap
- array->writableAt(i) = fStorage[i]->fBitmap;
- }
- }
- return array;
-}
-
void SkBitmapHeap::removeFromLRU(SkBitmapHeap::LookupEntry* entry) {
if (fMostRecentlyUsed == entry) {
fMostRecentlyUsed = entry->fLessRecentlyUsed;
diff --git a/src/core/SkBitmapHeap.h b/src/core/SkBitmapHeap.h
index 56ed3584e8..148ae132a4 100644
--- a/src/core/SkBitmapHeap.h
+++ b/src/core/SkBitmapHeap.h
@@ -13,7 +13,6 @@
#include "SkRefCnt.h"
#include "SkTDArray.h"
#include "SkThread.h"
-#include "SkTRefArray.h"
/**
* SkBitmapHeapEntry provides users of SkBitmapHeap (using internal storage) with a means to...
@@ -114,14 +113,6 @@ public:
virtual ~SkBitmapHeap();
/**
- * Makes a shallow copy of all bitmaps currently in the heap and returns them as an array. The
- * array indices match their position in the heap.
- *
- * @return a ptr to an array of bitmaps or NULL if external storage is being used.
- */
- SkTRefArray<SkBitmap>* extractBitmaps() const;
-
- /**
* Retrieves the bitmap from the specified slot in the heap
*
* @return The bitmap located at that slot or NULL if external storage is being used.
diff --git a/src/core/SkPictureData.cpp b/src/core/SkPictureData.cpp
index 29e4415cfa..2dff8eb1d7 100644
--- a/src/core/SkPictureData.cpp
+++ b/src/core/SkPictureData.cpp
@@ -30,8 +30,8 @@ SkPictureData::SkPictureData(const SkPictInfo& info)
void SkPictureData::initForPlayback() const {
// ensure that the paths bounds are pre-computed
- for (int i = 0; i < fPaths->count(); i++) {
- (*fPaths)[i].updateBoundsCache();
+ for (int i = 0; i < fPaths.count(); i++) {
+ fPaths[i].updateBoundsCache();
}
}
@@ -46,9 +46,9 @@ SkPictureData::SkPictureData(const SkPictureRecord& record,
fContentInfo.set(record.fContentInfo);
- fBitmaps = SkTRefArray<SkBitmap>::Create(record.fBitmaps.begin(), record.fBitmaps.count());
- fPaints = SkTRefArray<SkPaint> ::Create(record.fPaints .begin(), record.fPaints .count());
- fPaths = SkTRefArray<SkPath> ::Create(record.fPaths .begin(), record.fPaths .count());
+ fBitmaps = record.fBitmaps;
+ fPaints = record.fPaints;
+ fPaths = record.fPaths;
this->initForPlayback();
@@ -74,9 +74,6 @@ SkPictureData::SkPictureData(const SkPictureRecord& record,
}
void SkPictureData::init() {
- fBitmaps = NULL;
- fPaints = NULL;
- fPaths = NULL;
fPictureRefs = NULL;
fPictureCount = 0;
fTextBlobRefs = NULL;
@@ -88,10 +85,6 @@ void SkPictureData::init() {
SkPictureData::~SkPictureData() {
SkSafeUnref(fOpData);
- SkSafeUnref(fBitmaps);
- SkSafeUnref(fPaints);
- SkSafeUnref(fPaths);
-
for (int i = 0; i < fPictureCount; i++) {
fPictureRefs[i]->unref();
}
@@ -106,7 +99,7 @@ SkPictureData::~SkPictureData() {
}
bool SkPictureData::containsBitmaps() const {
- if (fBitmaps && fBitmaps->count() > 0) {
+ if (fBitmaps.count() > 0) {
return true;
}
for (int i = 0; i < fPictureCount; ++i) {
@@ -194,25 +187,25 @@ void SkPictureData::WriteTypefaces(SkWStream* stream, const SkRefCntSet& rec) {
void SkPictureData::flattenToBuffer(SkWriteBuffer& buffer) const {
int i, n;
- if ((n = SafeCount(fBitmaps)) > 0) {
+ if ((n = fBitmaps.count()) > 0) {
write_tag_size(buffer, SK_PICT_BITMAP_BUFFER_TAG, n);
for (i = 0; i < n; i++) {
- buffer.writeBitmap((*fBitmaps)[i]);
+ buffer.writeBitmap(fBitmaps[i]);
}
}
- if ((n = SafeCount(fPaints)) > 0) {
+ if ((n = fPaints.count()) > 0) {
write_tag_size(buffer, SK_PICT_PAINT_BUFFER_TAG, n);
for (i = 0; i < n; i++) {
- buffer.writePaint((*fPaints)[i]);
+ buffer.writePaint(fPaints[i]);
}
}
- if ((n = SafeCount(fPaths)) > 0) {
+ if ((n = fPaths.count()) > 0) {
write_tag_size(buffer, SK_PICT_PATH_BUFFER_TAG, n);
buffer.writeInt(n);
for (int i = 0; i < n; i++) {
- buffer.writePath((*fPaths)[i]);
+ buffer.writePath(fPaths[i]);
}
}
@@ -423,9 +416,9 @@ bool SkPictureData::parseBufferTag(SkReadBuffer& buffer,
switch (tag) {
case SK_PICT_BITMAP_BUFFER_TAG: {
const int count = SkToInt(size);
- fBitmaps = SkTRefArray<SkBitmap>::Create(size);
+ fBitmaps.reset(count);
for (int i = 0; i < count; ++i) {
- SkBitmap* bm = &fBitmaps->writableAt(i);
+ SkBitmap* bm = &fBitmaps[i];
if (buffer.readBitmap(bm)) {
bm->setImmutable();
} else {
@@ -435,17 +428,17 @@ bool SkPictureData::parseBufferTag(SkReadBuffer& buffer,
} break;
case SK_PICT_PAINT_BUFFER_TAG: {
const int count = SkToInt(size);
- fPaints = SkTRefArray<SkPaint>::Create(size);
+ fPaints.reset(count);
for (int i = 0; i < count; ++i) {
- buffer.readPaint(&fPaints->writableAt(i));
+ buffer.readPaint(&fPaints[i]);
}
} break;
case SK_PICT_PATH_BUFFER_TAG:
if (size > 0) {
const int count = buffer.readInt();
- fPaths = SkTRefArray<SkPath>::Create(count);
+ fPaths.reset(count);
for (int i = 0; i < count; i++) {
- buffer.readPath(&fPaths->writableAt(i));
+ buffer.readPath(&fPaths[i]);
}
} break;
case SK_PICT_TEXTBLOB_BUFFER_TAG: {
diff --git a/src/core/SkPictureData.h b/src/core/SkPictureData.h
index 9a5a4ca0c1..667880675b 100644
--- a/src/core/SkPictureData.h
+++ b/src/core/SkPictureData.h
@@ -84,12 +84,12 @@ protected:
public:
const SkBitmap& getBitmap(SkReader32* reader) const {
const int index = reader->readInt();
- return (*fBitmaps)[index];
+ return fBitmaps[index];
}
const SkPath& getPath(SkReader32* reader) const {
int index = reader->readInt() - 1;
- return (*fPaths)[index];
+ return fPaths[index];
}
const SkPicture* getPicture(SkReader32* reader) const {
@@ -103,7 +103,7 @@ public:
if (index == 0) {
return NULL;
}
- return &(*fPaints)[index - 1];
+ return &fPaints[index - 1];
}
const SkTextBlob* getTextBlob(SkReader32* reader) const {
@@ -142,9 +142,9 @@ private:
// bitmap allows playback to draw nothing and move on.
SkBitmap fBadBitmap;
- SkTRefArray<SkBitmap>* fBitmaps;
- SkTRefArray<SkPaint>* fPaints;
- SkTRefArray<SkPath>* fPaths;
+ SkTArray<SkBitmap> fBitmaps;
+ SkTArray<SkPaint> fPaints;
+ SkTArray<SkPath> fPaths;
SkData* fOpData; // opcodes and parameters
diff --git a/src/core/SkPictureFlat.h b/src/core/SkPictureFlat.h
index 40f6a0a803..61c4813597 100644
--- a/src/core/SkPictureFlat.h
+++ b/src/core/SkPictureFlat.h
@@ -18,7 +18,6 @@
#include "SkPicture.h"
#include "SkPtrRecorder.h"
#include "SkTDynamicHash.h"
-#include "SkTRefArray.h"
enum DrawType {
UNUSED,
@@ -449,22 +448,6 @@ public:
}
/**
- * Unflatten the objects and return them in SkTRefArray, or return NULL
- * if there no objects. Caller takes ownership of result.
- */
- SkTRefArray<T>* unflattenToArray() const {
- const int count = this->count();
- if (count == 0) {
- return NULL;
- }
- SkTRefArray<T>* array = SkTRefArray<T>::Create(count);
- for (int i = 0; i < count; i++) {
- this->unflatten(&array->writableAt(i), fIndexedData[i]);
- }
- return array;
- }
-
- /**
* Unflatten the specific object at the given index.
* Caller takes ownership of the result.
*/
diff --git a/src/core/SkTRefArray.h b/src/core/SkTRefArray.h
deleted file mode 100644
index c4bca241d7..0000000000
--- a/src/core/SkTRefArray.h
+++ /dev/null
@@ -1,112 +0,0 @@
-//
-// SkTRefArray.h
-// core
-//
-// Created by Mike Reed on 7/17/12.
-// Copyright (c) 2012 __MyCompanyName__. All rights reserved.
-//
-
-#ifndef SkTRefArray_DEFINED
-#define SkTRefArray_DEFINED
-
-#include "SkRefCnt.h"
-#include <new>
-
-/**
- * Wrapper to manage thread-safe sharing of an array of T objects. The array
- * cannot be grown or shrunk.
- */
-template <typename T> class SkTRefArray : public SkRefCnt {
- /*
- * Shared factory to allocate the space needed for our instance plus N
- * T entries at the end. We call our constructor, but not the constructors
- * for the elements. Those are called by the proper Create method.
- */
- static SkTRefArray<T>* Alloc(int count) {
- // space for us, and our [count] elements
- size_t size = sizeof(SkTRefArray<T>) + count * sizeof(T);
- SkTRefArray<T>* obj = (SkTRefArray<T>*)sk_malloc_throw(size);
-
- SkNEW_PLACEMENT(obj, SkTRefArray<T>);
- obj->fCount = count;
- return obj;
- }
-
-public:
- /**
- * Return a new array with 'count' elements, initialized to their default
- * value. To change them to some other value, use writableBegin/End or
- * writableAt(), but do that before this array is given to another thread.
- */
- static SkTRefArray<T>* Create(int count) {
- SkTRefArray<T>* obj = Alloc(count);
- T* array = const_cast<T*>(obj->begin());
- for (int i = 0; i < count; ++i) {
- SkNEW_PLACEMENT(&array[i], T);
- }
- return obj;
- }
-
- /**
- * Return a new array with 'count' elements, initialized from the provided
- * src array. To change them to some other value, use writableBegin/End or
- * writableAt(), but do that before this array is given to another thread.
- */
- static SkTRefArray<T>* Create(const T src[], int count) {
- SkTRefArray<T>* obj = Alloc(count);
- T* array = const_cast<T*>(obj->begin());
- for (int i = 0; i < count; ++i) {
- SkNEW_PLACEMENT_ARGS(&array[i], T, (src[i]));
- }
- return obj;
- }
-
- int count() const { return fCount; }
- const T* begin() const { return (const T*)(this + 1); }
- const T* end() const { return this->begin() + fCount; }
- const T& at(int index) const {
- SkASSERT((unsigned)index < (unsigned)fCount);
- return this->begin()[index];
- }
- const T& operator[](int index) const { return this->at(index); }
-
- // For the writable methods, we assert that we are the only owner if we
- // call these, since other owners are not informed if we change an element.
-
- T* writableBegin() {
- SkASSERT(this->unique());
- return (T*)(this + 1);
- }
- T* writableEnd() {
- return this->writableBegin() + fCount;
- }
- T& writableAt(int index) {
- SkASSERT((unsigned)index < (unsigned)fCount);
- return this->writableBegin()[index];
- }
-
-protected:
- virtual void internal_dispose() const SK_OVERRIDE {
- T* array = const_cast<T*>(this->begin());
- int n = fCount;
-
- for (int i = 0; i < n; ++i) {
- array->~T();
- array += 1;
- }
-
- this->internal_dispose_restore_refcnt_to_1();
- this->~SkTRefArray<T>();
- sk_free((void*)this);
- }
-
-private:
- int fCount;
-
- // hide this
- virtual ~SkTRefArray() {}
-
- typedef SkRefCnt INHERITED;
-};
-
-#endif
diff --git a/tests/RefCntTest.cpp b/tests/RefCntTest.cpp
index bd4f348fba..cf6ca3e0f2 100644
--- a/tests/RefCntTest.cpp
+++ b/tests/RefCntTest.cpp
@@ -6,7 +6,6 @@
*/
#include "SkRefCnt.h"
-#include "SkTRefArray.h"
#include "SkThreadUtils.h"
#include "SkTypes.h"
#include "SkWeakRefCnt.h"
@@ -27,47 +26,6 @@ public:
int InstCounterClass::gInstCounter;
-static void test_refarray(skiatest::Reporter* reporter) {
- REPORTER_ASSERT(reporter, 0 == InstCounterClass::gInstCounter);
-
- const int N = 10;
- SkTRefArray<InstCounterClass>* array = SkTRefArray<InstCounterClass>::Create(N);
-
- REPORTER_ASSERT(reporter, 1 == array->getRefCnt());
- REPORTER_ASSERT(reporter, N == array->count());
-
- REPORTER_ASSERT(reporter, N == InstCounterClass::gInstCounter);
- array->unref();
- REPORTER_ASSERT(reporter, 0 == InstCounterClass::gInstCounter);
-
- // Now test the copy factory
-
- int i;
- InstCounterClass* src = new InstCounterClass[N];
- REPORTER_ASSERT(reporter, N == InstCounterClass::gInstCounter);
- for (i = 0; i < N; ++i) {
- REPORTER_ASSERT(reporter, i == src[i].fCount);
- }
-
- array = SkTRefArray<InstCounterClass>::Create(src, N);
- REPORTER_ASSERT(reporter, 1 == array->getRefCnt());
- REPORTER_ASSERT(reporter, N == array->count());
-
- REPORTER_ASSERT(reporter, 2*N == InstCounterClass::gInstCounter);
- for (i = 0; i < N; ++i) {
- REPORTER_ASSERT(reporter, i == (*array)[i].fCount);
- }
-
- delete[] src;
- REPORTER_ASSERT(reporter, N == InstCounterClass::gInstCounter);
-
- for (i = 0; i < N; ++i) {
- REPORTER_ASSERT(reporter, i == (*array)[i].fCount);
- }
- array->unref();
- REPORTER_ASSERT(reporter, 0 == InstCounterClass::gInstCounter);
-}
-
static void bounce_ref(void* data) {
SkRefCnt* ref = static_cast<SkRefCnt*>(data);
for (int i = 0; i < 100000; ++i) {
@@ -143,5 +101,4 @@ static void test_weakRefCnt(skiatest::Reporter* reporter) {
DEF_TEST(RefCnt, reporter) {
test_refCnt(reporter);
test_weakRefCnt(reporter);
- test_refarray(reporter);
}