Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit dafd6876 authored by Colin Cross's avatar Colin Cross Committed by android-build-merger
Browse files

Merge "Fix multiton issue" am: 78b285b3

am: 6d7751a1

Change-Id: Ie09b193b7f6fce5bfa9998193bc050d9469064c9
parents d93e0505 6d7751a1
Loading
Loading
Loading
Loading
+13 −5
Original line number Diff line number Diff line
@@ -26,6 +26,16 @@
namespace android {
// ---------------------------------------------------------------------------

// Singleton<TYPE> may be used in multiple libraries, only one of which should
// define the static member variables using ANDROID_SINGLETON_STATIC_INSTANCE.
// Turn off -Wundefined-var-template so other users don't get:
// instantiation of variable 'android::Singleton<TYPE>::sLock' required here,
// but no definition is available
#if defined(__clang__)
#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Wundefined-var-template"
#endif

template <typename TYPE>
class ANDROID_API Singleton
{
@@ -56,11 +66,9 @@ private:
    static TYPE* sInstance;
};

template <typename TYPE>
Mutex Singleton<TYPE>::sLock;

template <typename TYPE>
TYPE* Singleton<TYPE>::sInstance;
#if defined(__clang__)
#pragma clang diagnostic pop
#endif

/*
 * use ANDROID_SINGLETON_STATIC_INSTANCE(TYPE) in your implementation file