bd6343b1d6
Obviously these are all currently function pointers of type T(*)(P) for various T and P. In bench refactoring, I'm trying to register a function pointer of type T(*)(), which can't be done as is (passing P=void doesn't work). This also lets us register things like primitives, which is conceivable useful. BUG= R=reed@google.com, scroggo@google.com Review URL: https://codereview.chromium.org/23453031 git-svn-id: http://skia.googlecode.com/svn/trunk@11082 2bbb7eff-a529-9590-31e7-b0007b416f81
56 lines
1.3 KiB
C++
56 lines
1.3 KiB
C++
|
|
/*
|
|
* Copyright 2009 The Android Open Source Project
|
|
*
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
* found in the LICENSE file.
|
|
*/
|
|
|
|
|
|
#ifndef SkTRegistry_DEFINED
|
|
#define SkTRegistry_DEFINED
|
|
|
|
#include "SkTypes.h"
|
|
|
|
/** Template class that registers itself (in the constructor) into a linked-list
|
|
and provides a function-pointer. This can be used to auto-register a set of
|
|
services, e.g. a set of image codecs.
|
|
*/
|
|
template <typename T> class SkTRegistry : SkNoncopyable {
|
|
public:
|
|
typedef T Factory;
|
|
|
|
explicit SkTRegistry(T fact) : fFact(fact) {
|
|
#ifdef SK_BUILD_FOR_ANDROID
|
|
// work-around for double-initialization bug
|
|
{
|
|
SkTRegistry* reg = gHead;
|
|
while (reg) {
|
|
if (reg == this) {
|
|
return;
|
|
}
|
|
reg = reg->fChain;
|
|
}
|
|
}
|
|
#endif
|
|
fChain = gHead;
|
|
gHead = this;
|
|
}
|
|
|
|
static const SkTRegistry* Head() { return gHead; }
|
|
|
|
const SkTRegistry* next() const { return fChain; }
|
|
const Factory& factory() const { return fFact; }
|
|
|
|
private:
|
|
Factory fFact;
|
|
SkTRegistry* fChain;
|
|
|
|
static SkTRegistry* gHead;
|
|
};
|
|
|
|
// The caller still needs to declare an instance of this somewhere
|
|
template <typename T> SkTRegistry<T>* SkTRegistry<T>::gHead;
|
|
|
|
#endif
|