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