2 * Copyright (c) 2014 Samsung Electronics Co., Ltd.
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
18 #include "test-graphics-sync-impl.h"
22 TestSyncObject::TestSyncObject(Dali::TraceCallStack& trace)
27 mTrace.PushCall("TestSyncObject cons", ""); // Trace the method
30 TestSyncObject::~TestSyncObject()
32 mTrace.PushCall("TestSyncObject dstr", ""); // Trace the method
35 bool TestSyncObject::IsSynced()
37 mTrace.PushCall("SyncObject::IsSynced", ""); // Trace the method
41 TestGraphicsSyncImplementation::TestGraphicsSyncImplementation()
49 TestGraphicsSyncImplementation::~TestGraphicsSyncImplementation()
51 for(SyncIter iter = mSyncObjects.begin(), end = mSyncObjects.end(); iter != end; ++iter)
58 * Initialize the sync objects
60 void TestGraphicsSyncImplementation::Initialize()
65 Integration::GraphicsSyncAbstraction::SyncObject* TestGraphicsSyncImplementation::CreateSyncObject()
67 mTrace.PushCall("CreateSyncObject", ""); // Trace the method
69 TestSyncObject* syncObject = new TestSyncObject(mTrace);
70 mSyncObjects.push_back(syncObject);
75 * Destroy a sync object
76 * @param[in] syncObject The object to destroy
78 void TestGraphicsSyncImplementation::DestroySyncObject(Integration::GraphicsSyncAbstraction::SyncObject* syncObject)
80 std::stringstream out;
82 mTrace.PushCall("DestroySyncObject", out.str()); // Trace the method
84 for(SyncIter iter = mSyncObjects.begin(), end = mSyncObjects.end(); iter != end; ++iter)
86 if(*iter == syncObject)
89 mSyncObjects.erase(iter);
95 Integration::GraphicsSyncAbstraction::SyncObject* TestGraphicsSyncImplementation::GetLastSyncObject()
97 if(!mSyncObjects.empty())
99 return mSyncObjects.back();
105 * Test method to trigger the object sync behaviour.
107 * @param[in] sync The sync value to set
109 void TestGraphicsSyncImplementation::SetObjectSynced(Integration::GraphicsSyncAbstraction::SyncObject* syncObject, bool sync)
111 TestSyncObject* testSyncObject = static_cast<TestSyncObject*>(syncObject);
112 testSyncObject->synced = sync;
118 void TestGraphicsSyncImplementation::EnableTrace(bool enable)
120 mTrace.Enable(enable);
124 * Reset the trace callstack
126 void TestGraphicsSyncImplementation::ResetTrace()
132 * Get the trace object (allows test case to find methods on it)
134 TraceCallStack& TestGraphicsSyncImplementation::GetTrace()
139 int32_t TestGraphicsSyncImplementation::GetNumberOfSyncObjects()
141 return static_cast<int32_t>(mSyncObjects.size());