2 * Copyright (c) 2015 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.
19 #include "framework.h"
26 #include <system_info.h>
27 #include <app_control_internal.h>
28 #include <bundle_internal.h>
30 // CONDITIONAL INCLUDES
31 #ifdef APPCORE_WATCH_AVAILABLE
32 #include <appcore-watch/watch_app.h>
34 #ifdef DALI_ELDBUS_AVAILABLE
36 #endif // DALI_ELDBUS_AVAILABLE
38 #include <dali/integration-api/debug.h>
41 #include <callback-manager.h>
52 #if defined(DEBUG_ENABLED)
55 Integration::Log::Filter* gDBusLogging = Integration::Log::Filter::New( Debug::NoLogging, false, "LOG_ADAPTOR_EVENTS_DBUS" );
56 } // anonymous namespace
60 * Impl to hide EFL data members
62 struct Framework::Impl
65 Impl(void* data, Type type )
66 : mAbortCallBack( NULL ),
67 mCallbackManager( NULL ),
70 mFramework = static_cast<Framework*>(data);
72 #ifndef APPCORE_WATCH_AVAILABLE
75 throw Dali::DaliException( "", "Watch Application is not supported." );
78 mApplicationType = type;
79 mCallbackManager = CallbackManager::New();
84 delete mAbortCallBack;
86 // we're quiting the main loop so
87 // mCallbackManager->RemoveAllCallBacks() does not need to be called
88 // to delete our abort handler
89 delete mCallbackManager;
96 if (mApplicationType == NORMAL)
98 ret = AppNormalMain();
102 ret = AppWatchMain();
109 if (mApplicationType == NORMAL)
121 Type mApplicationType;
122 CallbackBase* mAbortCallBack;
123 CallbackManager *mCallbackManager;
125 Framework* mFramework;
126 app_event_handler_h handlers[5];
127 ui_app_lifecycle_callback_s mEventCallback;
128 #ifdef APPCORE_WATCH_AVAILABLE
129 watch_app_lifecycle_callback_s mWatchCallback;
132 static bool AppCreate(void *data)
134 return static_cast<Framework*>(data)->Create();
137 static void AppTerminate(void *data)
139 Observer *observer = &static_cast<Framework*>(data)->mObserver;
141 observer->OnTerminate();
144 static void AppPause(void *data)
146 Observer *observer = &static_cast<Framework*>(data)->mObserver;
151 static void AppResume(void *data)
153 Observer *observer = &static_cast<Framework*>(data)->mObserver;
155 observer->OnResume();
158 static void ProcessBundle(Framework* framework, bundle *bundleData)
160 if(bundleData == NULL)
166 char* bundleName = const_cast<char*>(bundle_get_val(bundleData, "name"));
167 if(bundleName != NULL)
169 framework->SetBundleName(bundleName);
173 char* bundleId = const_cast<char*>(bundle_get_val(bundleData, "id"));
176 framework->SetBundleId(bundleId);
181 * Called by AppCore when the application is launched from another module (e.g. homescreen).
182 * @param[in] b the bundle data which the launcher module sent
184 static void AppControl(app_control_h app_control, void *data)
186 Framework* framework = static_cast<Framework*>(data);
187 Observer *observer = &framework->mObserver;
188 bundle *bundleData = NULL;
190 app_control_to_bundle(app_control, &bundleData);
191 ProcessBundle(framework, bundleData);
194 observer->OnAppControl(app_control);
201 mEventCallback.create = AppCreate;
202 mEventCallback.terminate = AppTerminate;
203 mEventCallback.pause = AppPause;
204 mEventCallback.resume = AppResume;
205 mEventCallback.app_control = AppControl;
207 ui_app_add_event_handler(&handlers[APP_EVENT_LOW_BATTERY], APP_EVENT_LOW_BATTERY, AppBatteryLow, mFramework);
208 ui_app_add_event_handler(&handlers[APP_EVENT_LOW_MEMORY], APP_EVENT_LOW_MEMORY, AppMemoryLow, mFramework);
209 ui_app_add_event_handler(&handlers[APP_EVENT_DEVICE_ORIENTATION_CHANGED], APP_EVENT_DEVICE_ORIENTATION_CHANGED, AppDeviceRotated, mFramework);
210 ui_app_add_event_handler(&handlers[APP_EVENT_LANGUAGE_CHANGED], APP_EVENT_LANGUAGE_CHANGED, AppLanguageChanged, mFramework);
211 ui_app_add_event_handler(&handlers[APP_EVENT_REGION_FORMAT_CHANGED], APP_EVENT_REGION_FORMAT_CHANGED, AppRegionChanged, mFramework);
213 ret = ui_app_main(*mFramework->mArgc, *mFramework->mArgv, &mEventCallback, mFramework);
223 #ifdef APPCORE_WATCH_AVAILABLE
224 static bool AppCreateWatch(int width, int height, void *data)
226 return static_cast<Framework*>(data)->Create();
229 static void AppTimeTick(watch_time_h time, void *data)
231 Observer *observer = &static_cast<Framework*>(data)->mObserver;
232 WatchTime curTime(time);
234 observer->OnTimeTick(curTime);
237 static void AppAmbientTick(watch_time_h time, void *data)
239 Observer *observer = &static_cast<Framework*>(data)->mObserver;
240 WatchTime curTime(time);
242 observer->OnAmbientTick(curTime);
245 static void AppAmbientChanged(bool ambient, void *data)
247 Observer *observer = &static_cast<Framework*>(data)->mObserver;
249 observer->OnAmbientChanged(ambient);
257 #ifdef APPCORE_WATCH_AVAILABLE
258 mWatchCallback.create = AppCreateWatch;
259 mWatchCallback.app_control = AppControl;
260 mWatchCallback.terminate = AppTerminate;
261 mWatchCallback.pause = AppPause;
262 mWatchCallback.resume = AppResume;
263 mWatchCallback.time_tick = AppTimeTick;
264 mWatchCallback.ambient_tick = AppAmbientTick;
265 mWatchCallback.ambient_changed = AppAmbientChanged;
267 watch_app_add_event_handler(&handlers[APP_EVENT_LOW_BATTERY], APP_EVENT_LOW_BATTERY, AppBatteryLow, mFramework);
268 watch_app_add_event_handler(&handlers[APP_EVENT_LOW_MEMORY], APP_EVENT_LOW_MEMORY, AppMemoryLow, mFramework);
269 watch_app_add_event_handler(&handlers[APP_EVENT_LANGUAGE_CHANGED], APP_EVENT_LANGUAGE_CHANGED, AppLanguageChanged, mFramework);
270 watch_app_add_event_handler(&handlers[APP_EVENT_REGION_FORMAT_CHANGED], APP_EVENT_REGION_FORMAT_CHANGED, AppRegionChanged, mFramework);
272 ret = watch_app_main(*mFramework->mArgc, *mFramework->mArgv, &mWatchCallback, mFramework);
279 #ifdef APPCORE_WATCH_AVAILABLE
284 static void AppLanguageChanged(app_event_info_h event, void *data)
286 Observer *observer = &static_cast<Framework*>(data)->mObserver;
288 observer->OnLanguageChanged();
291 static void AppDeviceRotated(app_event_info_h event_info, void *data)
295 static void AppRegionChanged(app_event_info_h event, void *data)
297 Observer *observer = &static_cast<Framework*>(data)->mObserver;
299 observer->OnRegionChanged();
302 static void AppBatteryLow(app_event_info_h event, void *data)
304 Observer *observer = &static_cast<Framework*>(data)->mObserver;
306 observer->OnBatteryLow();
309 static void AppMemoryLow(app_event_info_h event, void *data)
311 Observer *observer = &static_cast<Framework*>(data)->mObserver;
313 observer->OnMemoryLow();
318 Impl( const Impl& impl );
321 Impl& operator=( const Impl& impl );
324 Framework::Framework( Framework::Observer& observer, int *argc, char ***argv, Type type )
325 : mObserver(observer),
332 mAbortHandler( MakeCallback( this, &Framework::AbortCallback ) ),
335 bool featureFlag = true;
336 system_info_get_platform_bool( "tizen.org/feature/opengles.version.2_0", &featureFlag );
338 if( featureFlag == false )
340 set_last_result( TIZEN_ERROR_NOT_SUPPORTED );
342 #ifdef DALI_ELDBUS_AVAILABLE
343 // Initialize ElDBus.
344 DALI_LOG_INFO( gDBusLogging, Debug::General, "Starting DBus Initialization\n" );
349 mImpl = new Impl(this, type);
352 Framework::~Framework()
359 #ifdef DALI_ELDBUS_AVAILABLE
361 DALI_LOG_INFO( gDBusLogging, Debug::General, "Shutting down DBus\n" );
368 bool Framework::Create()
375 void Framework::Run()
380 ret = mImpl->AppMain();
381 if (ret != APP_ERROR_NONE)
383 DALI_LOG_ERROR("Framework::Run(), ui_app_main() is failed. err = %d\n", ret);
388 void Framework::Quit()
393 bool Framework::IsMainLoopRunning()
398 void Framework::AddAbortCallback( CallbackBase* callback )
400 mImpl->mAbortCallBack = callback;
403 std::string Framework::GetBundleName() const
408 void Framework::SetBundleName(const std::string& name)
413 std::string Framework::GetBundleId() const
418 void Framework::SetBundleId(const std::string& id)
423 void Framework::AbortCallback( )
425 // if an abort call back has been installed run it.
426 if (mImpl->mAbortCallBack)
428 CallbackBase::Execute( *mImpl->mAbortCallBack );
436 } // namespace Adaptor
438 } // namespace Internal