X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=dali%2Finternal%2Fupdate%2Frender-tasks%2Fscene-graph-render-task-list.h;h=b005b6737699ca6fade914ddf0056249849f2389;hb=0b3c34fac06b29c53c88d3f843a3f63f8c446acc;hp=854903404085e92f0340dabe6480176fb21c4d51;hpb=232bcb0bbb0f60ae98f1a96da9615dab35b06074;p=platform%2Fcore%2Fuifw%2Fdali-core.git diff --git a/dali/internal/update/render-tasks/scene-graph-render-task-list.h b/dali/internal/update/render-tasks/scene-graph-render-task-list.h index 8549034..b005b67 100644 --- a/dali/internal/update/render-tasks/scene-graph-render-task-list.h +++ b/dali/internal/update/render-tasks/scene-graph-render-task-list.h @@ -1,8 +1,8 @@ -#ifndef __DALI_INTERNAL_SCENE_GRAPH_RENDER_TASK_LIST_H__ -#define __DALI_INTERNAL_SCENE_GRAPH_RENDER_TASK_LIST_H__ +#ifndef DALI_INTERNAL_SCENE_GRAPH_RENDER_TASK_LIST_H +#define DALI_INTERNAL_SCENE_GRAPH_RENDER_TASK_LIST_H /* - * 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. @@ -22,18 +22,19 @@ #include #include #include +#include namespace Dali { namespace Internal { -class CompleteStatusManager; + class CompleteNotificationInterface; namespace SceneGraph { - +class RenderMessageDispatcher; class RenderTask; /** @@ -46,9 +47,10 @@ public: typedef OwnerContainer< RenderTask* > RenderTaskContainer; /** - * Constructor + * Construct a new RenderTaskList. + * @return A new RenderTaskList */ - RenderTaskList( CompleteStatusManager& completeStatusManager ); + static RenderTaskList* New(); /** * Destructor @@ -56,10 +58,22 @@ public: ~RenderTaskList(); /** + * Overriden delete operator + * Deletes the RenderTaskList from its global memory pool + */ + void operator delete( void* ptr ); + + /** + * Set the renderMessageDispatcher to send message. + * @param[in] renderMessageDispatcher The renderMessageDispatcher to send messages. + */ + void SetRenderMessageDispatcher( RenderMessageDispatcher* renderMessageDispatcher ); + + /** * Add a new RenderTask to the list. * @param[in] newTask The RenderTaskList takes ownership of this task. */ - void AddTask( RenderTask* newTask ); + void AddTask( OwnerPointer< RenderTask >& newTask ); /** * Remove a RenderTask from the list. @@ -68,6 +82,12 @@ public: void RemoveTask( RenderTask* task ); /** + * Retrieve the count of RenderTasks. + * @return The count. + */ + uint32_t GetTaskCount(); + + /** * Retrieve the container of RenderTasks. * @return The container. */ @@ -90,6 +110,13 @@ public: */ CompleteNotificationInterface* GetCompleteNotificationInterface(); +protected: + + /** + * Protected constructor. See New() + */ + RenderTaskList(); + private: // Undefined @@ -101,25 +128,26 @@ private: private: CompleteNotificationInterface* mNotificationObject; ///< object to pass in to the complete notification + RenderMessageDispatcher* mRenderMessageDispatcher; ///< for sending messages to render thread RenderTaskContainer mRenderTasks; ///< A container of owned RenderTasks - CompleteStatusManager& mCompleteStatusManager; ///< The complete status tracker (render tasks need this) }; // Messages for RenderTaskList -inline void AddTaskMessage( EventThreadServices& eventThreadServices, RenderTaskList& list, RenderTask& task ) +inline void AddTaskMessage( EventThreadServices& eventThreadServices, const RenderTaskList& list, OwnerPointer< RenderTask >& task ) { - typedef MessageValue1< RenderTaskList, RenderTask* > LocalType; + // Message has ownership of the RenderTask while in transit from event -> update + typedef MessageValue1< RenderTaskList, OwnerPointer< RenderTask > > LocalType; // Reserve some memory inside the message queue - unsigned int* slot = eventThreadServices.ReserveMessageSlot( sizeof( LocalType ) ); + uint32_t* slot = eventThreadServices.ReserveMessageSlot( sizeof( LocalType ) ); // Construct message in the message queue memory; note that delete should not be called on the return value - new (slot) LocalType( &list, &RenderTaskList::AddTask, &task ); + new (slot) LocalType( &list, &RenderTaskList::AddTask, task ); } -inline void RemoveTaskMessage( EventThreadServices& eventThreadServices, RenderTaskList& list, const RenderTask& constTask ) +inline void RemoveTaskMessage( EventThreadServices& eventThreadServices, const RenderTaskList& list, const RenderTask& constTask ) { // Scene graph thread can destroy this object. RenderTask& task = const_cast< RenderTask& >( constTask ); @@ -127,7 +155,7 @@ inline void RemoveTaskMessage( EventThreadServices& eventThreadServices, RenderT typedef MessageValue1< RenderTaskList, RenderTask* > LocalType; // Reserve some memory inside the message queue - unsigned int* slot = eventThreadServices.ReserveMessageSlot( sizeof( LocalType ) ); + uint32_t* slot = eventThreadServices.ReserveMessageSlot( sizeof( LocalType ) ); // Construct message in the message queue memory; note that delete should not be called on the return value new (slot) LocalType( &list, &RenderTaskList::RemoveTask, &task ); @@ -139,4 +167,4 @@ inline void RemoveTaskMessage( EventThreadServices& eventThreadServices, RenderT } // namespace Dali -#endif // __DALI_INTERNAL_SCENE_GRAPH_RENDER_TASK_LIST_H__ +#endif // DALI_INTERNAL_SCENE_GRAPH_RENDER_TASK_LIST_H