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