diff options
author | robertphillips@google.com <robertphillips@google.com@2bbb7eff-a529-9590-31e7-b0007b416f81> | 2013-12-12 14:24:20 +0000 |
---|---|---|
committer | robertphillips@google.com <robertphillips@google.com@2bbb7eff-a529-9590-31e7-b0007b416f81> | 2013-12-12 14:24:20 +0000 |
commit | 388695146469f09942e21a2d03d8ca0428f9489c (patch) | |
tree | 12adbc546736c683e5d4fe009128df0a77f6a384 | |
parent | 469a9732c5e75c70e73f51a5e4e0657b0129fdc7 (diff) |
Reverting r12635 (Make leak counters thread-safe - https://codereview.chromium.org/99483003) due to compile errors on Mac 10.6 & in Chrome
git-svn-id: http://skia.googlecode.com/svn/trunk@12637 2bbb7eff-a529-9590-31e7-b0007b416f81
-rw-r--r-- | gm/colormatrix.cpp | 6 | ||||
-rw-r--r-- | gm/convexpaths.cpp | 6 | ||||
-rw-r--r-- | include/core/SkInstCnt.h | 28 | ||||
-rw-r--r-- | include/core/SkPostConfig.h | 4 | ||||
-rw-r--r-- | src/core/SkOnce.h (renamed from include/core/SkOnce.h) | 0 |
5 files changed, 18 insertions, 26 deletions
diff --git a/gm/colormatrix.cpp b/gm/colormatrix.cpp index 2f98693da2..9ab6563040 100644 --- a/gm/colormatrix.cpp +++ b/gm/colormatrix.cpp @@ -12,9 +12,9 @@ #define WIDTH 500 #define HEIGHT 500 -class SkDoOnce { +class SkOnce { public: - SkDoOnce() : fOnce(false) {}; + SkOnce() : fOnce(false) {}; bool once() const { if (fOnce) { @@ -39,7 +39,7 @@ static void setArray(SkPaint* paint, const SkScalar array[]) { namespace skiagm { class ColorMatrixGM : public GM { - SkDoOnce fOnce; + SkOnce fOnce; void init() { if (fOnce.once()) { fSolidBitmap = this->createSolidBitmap(64, 64); diff --git a/gm/convexpaths.cpp b/gm/convexpaths.cpp index 91afbfeba3..8eb4cba49d 100644 --- a/gm/convexpaths.cpp +++ b/gm/convexpaths.cpp @@ -9,9 +9,9 @@ #include "SkRandom.h" #include "SkTArray.h" -class SkDoOnce : SkNoncopyable { +class SkOnce : SkNoncopyable { public: - SkDoOnce() { fDidOnce = false; } + SkOnce() { fDidOnce = false; } bool needToDo() const { return !fDidOnce; } bool alreadyDone() const { return fDidOnce; } @@ -27,7 +27,7 @@ private: namespace skiagm { class ConvexPathsGM : public GM { - SkDoOnce fOnce; + SkOnce fOnce; public: ConvexPathsGM() { this->setBGColor(0xFF000000); diff --git a/include/core/SkInstCnt.h b/include/core/SkInstCnt.h index db0ec31274..e38c42d917 100644 --- a/include/core/SkInstCnt.h +++ b/include/core/SkInstCnt.h @@ -20,7 +20,6 @@ #include "SkTypes.h" #if SK_ENABLE_INST_COUNT -#include "SkOnce.h" #include "SkTArray.h" #include "SkThread_platform.h" @@ -41,15 +40,15 @@ extern bool gPrintInstCount; public: \ typedef int (*PFCheckInstCnt)(int level, bool cleanUp); \ SkInstanceCountHelper() { \ - SK_DECLARE_STATIC_ONCE(once); \ - SkOnce(&once, init, 0); \ + static bool gInited; \ + if (!gInited) { \ + initStep \ + GetChildren() = new SkTArray<PFCheckInstCnt>; \ + gInited = true; \ + } \ sk_atomic_inc(GetInstanceCountPtr()); \ } \ \ - static void init(int) { \ - initStep \ - } \ - \ SkInstanceCountHelper(const SkInstanceCountHelper&) { \ sk_atomic_inc(GetInstanceCountPtr()); \ } \ @@ -68,11 +67,6 @@ extern bool gPrintInstCount; return gChildren; \ } \ \ - static SkBaseMutex& GetChildrenMutex() { \ - SK_DECLARE_STATIC_MUTEX(childrenMutex); \ - return childrenMutex; \ - } \ - \ } fInstanceCountHelper; \ \ static int32_t GetInstanceCount() { \ @@ -92,7 +86,7 @@ extern bool gPrintInstCount; if (NULL == SkInstanceCountHelper::GetChildren()) { \ return GetInstanceCount(); \ } \ - SkTArray<typename SkInstanceCountHelper::PFCheckInstCnt>* children = \ + SkTArray<int (*)(int, bool)>* children = \ SkInstanceCountHelper::GetChildren(); \ int childCount = children->count(); \ int count = GetInstanceCount(); \ @@ -111,12 +105,8 @@ extern bool gPrintInstCount; } \ \ static void AddInstChild(int (*childCheckInstCnt)(int, bool)) { \ - if (CheckInstanceCount != childCheckInstCnt) { \ - SkAutoMutexAcquire ama(SkInstanceCountHelper::GetChildrenMutex()); \ - if (NULL == SkInstanceCountHelper::GetChildren()) { \ - SkInstanceCountHelper::GetChildren() = \ - new SkTArray<typename SkInstanceCountHelper::PFCheckInstCnt>; \ - } \ + if (CheckInstanceCount != childCheckInstCnt && \ + NULL != SkInstanceCountHelper::GetChildren()) { \ SkInstanceCountHelper::GetChildren()->push_back(childCheckInstCnt); \ } \ } diff --git a/include/core/SkPostConfig.h b/include/core/SkPostConfig.h index d0d7d26e58..efb119fe4b 100644 --- a/include/core/SkPostConfig.h +++ b/include/core/SkPostConfig.h @@ -126,10 +126,12 @@ * SK_ENABLE_INST_COUNT controlls printing how many reference counted objects * are still held on exit. * Defaults to 1 in DEBUG and 0 in RELEASE. + * FIXME: currently always 0, since it fails if multiple threads run at once + * (see skbug.com/1219 ). */ #ifndef SK_ENABLE_INST_COUNT # ifdef SK_DEBUG -# define SK_ENABLE_INST_COUNT 1 +# define SK_ENABLE_INST_COUNT 0 # else # define SK_ENABLE_INST_COUNT 0 # endif diff --git a/include/core/SkOnce.h b/src/core/SkOnce.h index 89de112442..89de112442 100644 --- a/include/core/SkOnce.h +++ b/src/core/SkOnce.h |