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