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