Update change log and spec for wrt-plugins-tizen_0.4.46
[platform/framework/web/wrt-plugins-tizen.git] / src / Systeminfo / 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 <Commons/plugin_initializer_def.h>
19 #include <Commons/WrtAccess/WrtAccess.h>
20 #include <TimeTracer.h>
21 #include "SysteminfoAsyncCallbackManager.h"
22 #include "SysteminfoListenerManager.h"
23 #include "JSSysteminfo.h"
24 #include <Logger.h>
25
26 namespace DeviceAPI {
27 namespace Systeminfo {
28
29 using namespace WrtDeviceApis;
30 using namespace WrtDeviceApis::Commons;
31
32 #define WRT_JS_EXTENSION_OBJECT_TIZEN "tizen"
33
34 void on_widget_start_callback(int widgetId)
35 {
36     LoggerD("[Tizen\\Systeminfo ] on_widget_start_callback (" << widgetId << ")");
37         TIME_TRACER_INIT();
38     Try
39     {
40         WrtAccessSingleton::Instance().initialize(widgetId);
41     }
42     Catch(Commons::Exception)
43     {
44         LoggerE("WrtAccess initialization failed");
45     }    
46 }
47
48 void on_widget_stop_callback(int widgetId)
49 {
50     LoggerD("[Tizen\\Systeminfo ] on_widget_stop_callback (" << widgetId << ")");
51         TIME_TRACER_EXPORT_REPORT_TO(TIME_TRACER_EXPORT_FILE,"SystemInfo");
52         TIME_TRACER_RELEASE();
53     Try
54     {
55         WrtAccessSingleton::Instance().deinitialize(widgetId);
56     }
57     Catch(Commons::Exception)
58     {
59         LoggerE("WrtAccess deinitialization failed");
60     }
61 }
62
63 void on_frame_load_callback(const void * context)
64 {
65     LoggerD("[Tizen\\systeminfo] on_frame_load_callback (" << context << ")");
66 }
67
68 void on_frame_unload_callback(const void * context)
69 {
70     LoggerD("[Tizen\\systeminfo] on_frame_unload_callback (" << context << ")");
71
72     DeviceAPI::Systeminfo::SysteminfoAsyncCallbackManagerSingleton::Instance().unregisterContext(static_cast<JSContextRef>(context));
73     DeviceAPI::Systeminfo::SysteminfoListenerManagerSingleton::Instance().unregisterContext(static_cast<JSContextRef>(context));
74 }
75
76 PLUGIN_ON_WIDGET_START(on_widget_start_callback)
77 PLUGIN_ON_WIDGET_STOP(on_widget_stop_callback)
78 PLUGIN_ON_FRAME_LOAD(on_frame_load_callback)
79 PLUGIN_ON_FRAME_UNLOAD(on_frame_unload_callback)
80
81 PLUGIN_CLASS_MAP_BEGIN
82 PLUGIN_CLASS_MAP_ADD_CLASS(WRT_JS_EXTENSION_OBJECT_TIZEN, "systeminfo", (js_class_template_getter)DeviceAPI::Systeminfo::JSSysteminfo::getClassRef, NULL)
83 PLUGIN_CLASS_MAP_END
84
85 } // Systeminfo
86 } // DeviceAPI
87