2 * Copyright (c) 2018 Samsung Electronics Co., Ltd.
\r
4 * Licensed under the Apache License, Version 2.0 (the "License");
\r
5 * you may not use this file except in compliance with the License.
\r
6 * You may obtain a copy of the License at
\r
8 * http://www.apache.org/licenses/LICENSE-2.0
\r
10 * Unless required by applicable law or agreed to in writing, software
\r
11 * distributed under the License is distributed on an "AS IS" BASIS,
\r
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
\r
13 * See the License for the specific language governing permissions and
\r
14 * limitations under the License.
\r
19 #include <dali/internal/adaptor/common/framework.h>
\r
21 // EXTERNAL INCLUDES
\r
22 #include <dali/integration-api/debug.h>
\r
23 #include <windows.h>
\r
25 // INTERNAL INCLUDES
\r
26 #include <dali/internal/window-system/windows/platform-implement-win.h>
\r
27 #include <dali/internal/system/common/callback-manager.h>
\r
41 /// Application Status Enum
\r
49 APP_LANGUAGE_CHANGE,
\r
52 } // Unnamed namespace
\r
54 * Impl to hide WindowsSystem data members
\r
56 struct Framework::Impl
\r
61 : mAbortCallBack( NULL ),
\r
62 mCallbackManager( CallbackManager::New() ),
\r
63 mLanguage( "NOT_SUPPORTED" ),
\r
64 mRegion( "NOT_SUPPORTED" )
\r
70 delete mAbortCallBack;
\r
72 // we're quiting the main loop so
\r
73 // mCallbackManager->RemoveAllCallBacks() does not need to be called
\r
74 // to delete our abort handler
\r
75 delete mCallbackManager;
\r
78 std::string GetLanguage() const
\r
83 std::string GetRegion() const
\r
91 * Called by AppCore on application creation.
\r
93 static bool AppCreate(void *data)
\r
95 return static_cast<Framework*>(data)->AppStatusHandler(APP_CREATE, NULL);
\r
99 * Called by AppCore when the application should terminate.
\r
101 static void AppTerminate(void *data)
\r
103 static_cast<Framework*>(data)->AppStatusHandler(APP_TERMINATE, NULL);
\r
107 * Called by AppCore when the application is paused.
\r
109 static void AppPause(void *data)
\r
111 static_cast<Framework*>(data)->AppStatusHandler(APP_PAUSE, NULL);
\r
115 * Called by AppCore when the application is resumed.
\r
117 static void AppResume(void *data)
\r
119 static_cast<Framework*>(data)->AppStatusHandler(APP_RESUME, NULL);
\r
123 * Called by AppCore when the language changes on the device.
\r
125 static void AppLanguageChange(void* data)
\r
127 static_cast<Framework*>(data)->AppStatusHandler(APP_LANGUAGE_CHANGE, NULL);
\r
134 while (GetMessage(&nMsg, 0, NULL, NULL))
\r
136 if (WIN_CALLBACK_EVENT == nMsg.message)
\r
138 Dali::CallbackBase *callback = (Dali::CallbackBase*)nMsg.wParam;
\r
139 Dali::CallbackBase::Execute(*callback);
\r
142 TranslateMessage(&nMsg);
\r
143 DispatchMessage(&nMsg);
\r
145 mCallbackManager->ClearIdleCallbacks();
\r
147 if (WM_CLOSE == nMsg.message)
\r
158 void SetCallbackBase( CallbackBase *base )
\r
160 mAbortCallBack = base;
\r
163 bool ExcuteCallback()
\r
165 if( NULL != mAbortCallBack )
\r
167 CallbackBase::Execute( *mAbortCallBack );
\r
178 Impl( const Impl& impl ) = delete;
\r
181 Impl& operator=( const Impl& impl ) = delete;
\r
185 CallbackBase* mAbortCallBack;
\r
186 CallbackManager *mCallbackManager;
\r
187 std::string mLanguage;
\r
188 std::string mRegion;
\r
191 Framework::Framework( Framework::Observer& observer, int *argc, char ***argv, Type type )
\r
192 : mObserver(observer),
\r
193 mInitialised(false),
\r
200 mAbortHandler( MakeCallback( this, &Framework::AbortCallback ) ),
\r
204 mImpl = new Impl(this);
\r
207 Framework::~Framework()
\r
217 void Framework::Run()
\r
221 Impl::AppCreate(this);
\r
226 void Framework::Quit()
\r
228 Impl::AppTerminate(this);
\r
231 bool Framework::IsMainLoopRunning()
\r
236 void Framework::AddAbortCallback( CallbackBase* callback )
\r
238 mImpl->SetCallbackBase( callback );
\r
241 std::string Framework::GetBundleName() const
\r
243 return mBundleName;
\r
246 void Framework::SetBundleName(const std::string& name)
\r
248 mBundleName = name;
\r
251 std::string Framework::GetBundleId() const
\r
256 std::string Framework::GetResourcePath()
\r
258 // "DALI_APPLICATION_PACKAGE" is used by Windows specifically to get the already configured Application package path.
\r
259 const char* winEnvironmentVariable = "DALI_APPLICATION_PACKAGE";
\r
260 char* value = getenv( winEnvironmentVariable );
\r
262 std::string resourcePath;
\r
263 if ( value != NULL )
\r
265 resourcePath = value;
\r
268 if( resourcePath.back() != '/' )
\r
273 return resourcePath;
\r
276 std::string Framework::GetDataPath()
\r
278 std::string result = app_get_data_path();
\r
282 void Framework::SetBundleId(const std::string& id)
\r
287 void Framework::AbortCallback( )
\r
289 // if an abort call back has been installed run it.
\r
290 if( false == mImpl->ExcuteCallback() )
\r
296 bool Framework::AppStatusHandler(int type, void *bundleData)
\r
302 mInitialised = true;
\r
304 mObserver.OnInit();
\r
309 mObserver.OnReset();
\r
314 mObserver.OnResume();
\r
317 case APP_TERMINATE:
\r
319 mObserver.OnTerminate();
\r
324 mObserver.OnPause();
\r
327 case APP_LANGUAGE_CHANGE:
\r
329 mObserver.OnLanguageChanged();
\r
341 void Framework::InitThreads()
\r
345 std::string Framework::GetLanguage() const
\r
347 return mImpl->GetLanguage();
\r
350 std::string Framework::GetRegion() const
\r
352 return mImpl->GetRegion();
\r
355 } // namespace Adaptor
\r
357 } // namespace Internal
\r
359 } // namespace Dali
\r