OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "ppapi/c/pp_file_info.h" | 5 #include "ppapi/c/pp_file_info.h" |
6 #include "ppapi/c/ppb_file_ref.h" | 6 #include "ppapi/c/ppb_file_ref.h" |
7 #include "ppapi/c/pp_completion_callback.h" | 7 #include "ppapi/c/pp_completion_callback.h" |
8 #include "ppapi/c/pp_errors.h" | 8 #include "ppapi/c/pp_errors.h" |
9 #include "ppapi/c/private/ppb_file_ref_private.h" | 9 #include "ppapi/c/private/ppb_file_ref_private.h" |
10 #include "ppapi/shared_impl/file_ref_create_info.h" | |
10 #include "ppapi/shared_impl/proxy_lock.h" | 11 #include "ppapi/shared_impl/proxy_lock.h" |
11 #include "ppapi/shared_impl/tracked_callback.h" | 12 #include "ppapi/shared_impl/tracked_callback.h" |
12 #include "ppapi/thunk/enter.h" | 13 #include "ppapi/thunk/enter.h" |
13 #include "ppapi/thunk/thunk.h" | 14 #include "ppapi/thunk/thunk.h" |
14 #include "ppapi/thunk/ppb_file_ref_api.h" | 15 #include "ppapi/thunk/ppb_file_ref_api.h" |
15 #include "ppapi/thunk/ppb_file_system_api.h" | 16 #include "ppapi/thunk/ppb_file_system_api.h" |
16 #include "ppapi/thunk/resource_creation_api.h" | 17 #include "ppapi/thunk/resource_creation_api.h" |
17 | 18 |
18 namespace ppapi { | 19 namespace ppapi { |
19 namespace thunk { | 20 namespace thunk { |
20 | 21 |
21 namespace { | 22 namespace { |
22 | 23 |
23 typedef EnterResource<PPB_FileRef_API> EnterFileRef; | 24 typedef EnterResource<PPB_FileRef_API> EnterFileRef; |
24 | 25 |
25 PP_Resource Create(PP_Resource file_system, const char* path) { | 26 PP_Resource Create(PP_Resource file_system, const char* path) { |
26 VLOG(4) << "PPB_FileRef::Create()"; | 27 VLOG(4) << "PPB_FileRef::Create()"; |
27 ppapi::ProxyAutoLock lock; | 28 ppapi::ProxyAutoLock lock; |
28 EnterResourceNoLock<PPB_FileSystem_API> enter_file_system(file_system, true); | 29 EnterResourceNoLock<PPB_FileSystem_API> enter_file_system(file_system, true); |
29 if (enter_file_system.failed()) | 30 if (enter_file_system.failed()) |
30 return 0; | 31 return 0; |
31 PP_Instance instance = enter_file_system.resource()->pp_instance(); | 32 PP_Instance instance = enter_file_system.resource()->pp_instance(); |
32 EnterResourceCreationNoLock enter(instance); | 33 EnterResourceCreationNoLock enter(instance); |
33 if (enter.failed()) | 34 if (enter.failed()) |
34 return 0; | 35 return 0; |
35 return enter.functions()->CreateFileRef(instance, file_system, path); | 36 FileRef_CreateInfo info; |
37 info.file_system_type = enter_file_system.object()->GetType(); | |
38 info.internal_path = std::string(path); | |
39 info.pending_host_resource_id = 0; | |
40 info.file_system_plugin_resource = file_system; | |
dmichael (off chromium)
2013/08/07 22:19:13
seems like a FileRefCreateInfo constructor would b
teravest
2013/08/08 00:50:06
This is the only place where we have to mess with
| |
41 return enter.functions()->CreateFileRef(instance, info); | |
36 } | 42 } |
37 | 43 |
38 PP_Bool IsFileRef(PP_Resource resource) { | 44 PP_Bool IsFileRef(PP_Resource resource) { |
39 VLOG(4) << "PPB_FileRef::IsFileRef()"; | 45 VLOG(4) << "PPB_FileRef::IsFileRef()"; |
40 EnterFileRef enter(resource, false); | 46 EnterFileRef enter(resource, false); |
41 return PP_FromBool(enter.succeeded()); | 47 return PP_FromBool(enter.succeeded()); |
42 } | 48 } |
43 | 49 |
44 PP_FileSystemType GetFileSystemType(PP_Resource file_ref) { | 50 PP_FileSystemType GetFileSystemType(PP_Resource file_ref) { |
45 VLOG(4) << "PPB_FileRef::GetFileSystemType()"; | 51 VLOG(4) << "PPB_FileRef::GetFileSystemType()"; |
(...skipping 140 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
186 const PPB_FileRef_1_1* GetPPB_FileRef_1_1_Thunk() { | 192 const PPB_FileRef_1_1* GetPPB_FileRef_1_1_Thunk() { |
187 return &g_ppb_file_ref_thunk_1_1; | 193 return &g_ppb_file_ref_thunk_1_1; |
188 } | 194 } |
189 | 195 |
190 const PPB_FileRefPrivate_0_1* GetPPB_FileRefPrivate_0_1_Thunk() { | 196 const PPB_FileRefPrivate_0_1* GetPPB_FileRefPrivate_0_1_Thunk() { |
191 return &g_ppb_file_ref_private_thunk; | 197 return &g_ppb_file_ref_private_thunk; |
192 } | 198 } |
193 | 199 |
194 } // namespace thunk | 200 } // namespace thunk |
195 } // namespace ppapi | 201 } // namespace ppapi |
OLD | NEW |