/*
- * Copyright (c) 2014 Samsung Electronics Co., Ltd.
+ * Copyright (c) 2017 Samsung Electronics Co., Ltd.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
// CLASS HEADER
#include <dali/internal/event/common/thread-local-storage.h>
-// EXTERNAL INCLUDES
-#include <boost/thread/tss.hpp>
-#include <memory>
-
// INTERNAL INCLUDES
#include <dali/internal/common/core-impl.h>
-#include <dali/internal/update/manager/update-manager.h>
-#include <dali/internal/render/common/render-manager.h>
-#include <dali/integration-api/platform-abstraction.h>
#include <dali/public-api/common/dali-common.h>
-#include <dali/public-api/math/vector2.h>
namespace Dali
{
namespace
{
-#ifdef EMSCRIPTEN
- std::auto_ptr<ThreadLocalStorage> threadLocal;
+#if defined(EMSCRIPTEN)
+ThreadLocalStorage* threadLocal = NULL;
#else
- boost::thread_specific_ptr<ThreadLocalStorage> threadLocal;
+__thread ThreadLocalStorage* threadLocal = NULL;
#endif
}
ThreadLocalStorage::ThreadLocalStorage(Core* core)
-: mCore(core)
+: mCore( core )
{
- DALI_ASSERT_ALWAYS( threadLocal.get() == NULL && "Cannot create more than one ThreadLocalStorage object" );
-
- // reset is used to store a new value associated with this thread
- threadLocal.reset(this);
+ DALI_ASSERT_ALWAYS( threadLocal == NULL && "Cannot create more than one ThreadLocalStorage object" );
+ threadLocal = this;
}
ThreadLocalStorage::~ThreadLocalStorage()
void ThreadLocalStorage::Remove()
{
- threadLocal.reset();
+ threadLocal = NULL;
}
ThreadLocalStorage& ThreadLocalStorage::Get()
{
- ThreadLocalStorage* tls = threadLocal.get();
+ DALI_ASSERT_ALWAYS(threadLocal);
- DALI_ASSERT_ALWAYS(tls);
-
- return *tls;
+ return *threadLocal;
}
bool ThreadLocalStorage::Created()
{
// see if the TLS has been set yet
- return (threadLocal.get() != NULL);
+ return (threadLocal != NULL);
+}
+
+ThreadLocalStorage* ThreadLocalStorage::GetInternal()
+{
+ return threadLocal;
}
Dali::Integration::PlatformAbstraction& ThreadLocalStorage::GetPlatformAbstraction()
return mCore->GetResourceClient();
}
-ImageFactory& ThreadLocalStorage::GetImageFactory()
-{
- return mCore->GetImageFactory();
-}
-
-ModelFactory& ThreadLocalStorage::GetModelFactory()
-{
- return mCore->GetModelFactory();
-}
-
ShaderFactory& ThreadLocalStorage::GetShaderFactory()
{
return mCore->GetShaderFactory();
return mCore->GetCurrentStage();
}
-EventToUpdate& ThreadLocalStorage::GetEventToUpdate()
+GestureEventProcessor& ThreadLocalStorage::GetGestureEventProcessor()
{
- return GetUpdateManager().GetEventToUpdate();
+ return mCore->GetGestureEventProcessor();
}
-GestureEventProcessor& ThreadLocalStorage::GetGestureEventProcessor()
+RelayoutController& ThreadLocalStorage::GetRelayoutController()
{
- return mCore->GetGestureEventProcessor();
+ return mCore->GetRelayoutController();
}
} // namespace Internal