/*
- * Copyright (c) 2014 Samsung Electronics Co., Ltd.
+ * Copyright (c) 2019 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.
// INTERNAL INCLUDES
#include <dali/internal/common/core-impl.h>
#include <dali/public-api/common/dali-common.h>
+#include <dali/internal/event/common/event-thread-services.h>
namespace Dali
{
namespace
{
-__thread ThreadLocalStorage* threadLocal = NULL;
+thread_local ThreadLocalStorage* threadLocal = nullptr;
}
ThreadLocalStorage::ThreadLocalStorage(Core* core)
-: mCore(core)
+: mCore( core )
{
- DALI_ASSERT_ALWAYS( threadLocal == NULL && "Cannot create more than one ThreadLocalStorage object" );
+ DALI_ASSERT_ALWAYS( threadLocal == nullptr && "Cannot create more than one ThreadLocalStorage object" );
- // reset is used to store a new value associated with this thread
threadLocal = this;
}
void ThreadLocalStorage::Remove()
{
- threadLocal = NULL;
+ threadLocal = nullptr;
}
ThreadLocalStorage& ThreadLocalStorage::Get()
bool ThreadLocalStorage::Created()
{
// see if the TLS has been set yet
- return (threadLocal != NULL);
+ return (threadLocal != nullptr);
}
ThreadLocalStorage* ThreadLocalStorage::GetInternal()
return mCore->GetNotificationManager();
}
-ResourceManager& ThreadLocalStorage::GetResourceManager()
+ShaderFactory& ThreadLocalStorage::GetShaderFactory()
{
- return mCore->GetResourceManager();
+ return mCore->GetShaderFactory();
}
-ResourceClient& ThreadLocalStorage::GetResourceClient()
+StagePtr ThreadLocalStorage::GetCurrentStage()
{
- return mCore->GetResourceClient();
+ return mCore->GetCurrentStage();
}
-ImageFactory& ThreadLocalStorage::GetImageFactory()
+GestureEventProcessor& ThreadLocalStorage::GetGestureEventProcessor()
{
- return mCore->GetImageFactory();
+ return mCore->GetGestureEventProcessor();
}
-FontFactory& ThreadLocalStorage::GetFontFactory()
+RelayoutController& ThreadLocalStorage::GetRelayoutController()
{
- return mCore->GetFontFactory();
+ return mCore->GetRelayoutController();
}
-ShaderFactory& ThreadLocalStorage::GetShaderFactory()
+ObjectRegistry& ThreadLocalStorage::GetObjectRegistry()
{
- return mCore->GetShaderFactory();
+ return mCore->GetObjectRegistry();
}
-StagePtr ThreadLocalStorage::GetCurrentStage()
+EventThreadServices& ThreadLocalStorage::GetEventThreadServices()
{
- return mCore->GetCurrentStage();
+ return mCore->GetEventThreadServices();
}
-GestureEventProcessor& ThreadLocalStorage::GetGestureEventProcessor()
+PropertyNotificationManager& ThreadLocalStorage::GetPropertyNotificationManager()
{
- return mCore->GetGestureEventProcessor();
+ return mCore->GetPropertyNotificationManager();
}
-EmojiFactory& ThreadLocalStorage::GetEmojiFactory()
+AnimationPlaylist& ThreadLocalStorage::GetAnimationPlaylist()
{
- return mCore->GetEmojiFactory();
+ return mCore->GetAnimationPlaylist();
}
-RelayoutController& ThreadLocalStorage::GetRelayoutController()
+void ThreadLocalStorage::AddScene( Scene* scene )
{
- return mCore->GetRelayoutController();
+ mCore->AddScene( scene );
+}
+
+void ThreadLocalStorage::RemoveScene( Scene* scene )
+{
+ mCore->RemoveScene( scene );
}
} // namespace Internal