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