wrt-plugins-tizen_0.4.23
[framework/web/wrt-plugins-tizen.git] / src / Power / plugin_initializer.cpp
1 //
2 // Tizen Web Device API
3 // Copyright (c) 2012 Samsung Electronics Co., Ltd.
4 //
5 // Licensed under the Apache License, Version 2.0 (the License);
6 // you may not use this file except in compliance with the License.
7 // You may obtain a copy of the License at
8 //
9 // http://www.apache.org/licenses/LICENSE-2.0
10 //
11 // Unless required by applicable law or agreed to in writing, software
12 // distributed under the License is distributed on an "AS IS" BASIS,
13 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 // See the License for the specific language governing permissions and
15 // limitations under the License.
16 //
17
18 #include <Logger.h>
19
20 #include <Commons/plugin_initializer_def.h>
21 #include <Commons/WrtAccess/WrtAccess.h>
22 #include <Commons/Exception.h>
23 #include "JSPowerManager.h"
24 #include <GlobalContextManager.h>
25 #include <TimeTracer.h>
26
27 namespace DeviceAPI {
28 namespace Power {
29
30 using namespace WrtDeviceApis;
31 using namespace WrtDeviceApis::Commons;
32 using namespace DeviceAPI::Common;
33
34 void on_widget_start_callback(int widgetId)
35 {
36     LoggerD("[Tizen\\Power] on_widget_start_callback (" << widgetId << ")");
37         TIME_TRACER_INIT();
38
39         Try {
40         WrtAccessSingleton::Instance().initialize(widgetId);
41         } Catch (Exception) {
42                 LoggerE("WrtAccess initialization failed");
43         }
44 }
45
46 void on_widget_stop_callback(int widgetId)
47 {
48     LoggerD("[Tizen\\Power] on_widget_stop_callback (" << widgetId << ")");
49         TIME_TRACER_EXPORT_REPORT_TO(TIME_TRACER_EXPORT_FILE,"Power");
50         TIME_TRACER_RELEASE();
51
52         Try {
53         WrtAccessSingleton::Instance().deinitialize(widgetId);
54         } Catch (Exception) {
55                 LoggerE("WrtAccess deinitialization failed");
56         }
57 }
58
59 void on_frame_load_callback(const void * context)
60 {
61     LoggerD("[Tizen\\Power] on_frame_load_callback (" << context << ")");
62     GlobalContextManager::getInstance()->addGlobalContext(static_cast<JSContextRef>(context));
63 }
64
65 void on_frame_unload_callback(const void * context)
66 {
67     LoggerD("[Tizen\\Power] on_frame_unload_callback (" << context << ")");
68     GlobalContextManager::getInstance()->removeGlobalContext(static_cast<JSContextRef>(context));
69 }
70
71 PLUGIN_ON_WIDGET_START(on_widget_start_callback)
72 PLUGIN_ON_WIDGET_STOP(on_widget_stop_callback)
73
74 PLUGIN_ON_FRAME_LOAD(on_frame_load_callback)
75 PLUGIN_ON_FRAME_UNLOAD(on_frame_unload_callback)
76
77 PLUGIN_CLASS_MAP_BEGIN
78 PLUGIN_CLASS_MAP_ADD_CLASS(WRT_JS_EXTENSION_OBJECT_TIZEN,
79         "power",
80         (js_class_template_getter)JSPowerManager::getClassRef,
81         NULL)
82 PLUGIN_CLASS_MAP_END
83
84 }
85 }
86