Index: ppapi/proxy/directory_reader_resource.h |
diff --git a/ppapi/proxy/directory_reader_resource.h b/ppapi/proxy/directory_reader_resource.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..2da83b857fa19c7a48950413b8039d08e5875c54 |
--- /dev/null |
+++ b/ppapi/proxy/directory_reader_resource.h |
@@ -0,0 +1,66 @@ |
+// Copyright (c) 2013 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#ifndef PPAPI_PROXY_DIRECTORY_READER_RESOURCE_H_ |
+#define PPAPI_PROXY_DIRECTORY_READER_RESOURCE_H_ |
+ |
+#include <queue> |
+#include <vector> |
+ |
+#include "base/basictypes.h" |
+#include "ppapi/proxy/plugin_resource.h" |
+#include "ppapi/proxy/ppapi_proxy_export.h" |
+#include "ppapi/shared_impl/ppb_file_ref_shared.h" |
+#include "ppapi/shared_impl/resource.h" |
+#include "ppapi/thunk/ppb_directory_reader_api.h" |
+ |
+namespace ppapi { |
+ |
+class TrackedCallback; |
+ |
+namespace proxy { |
+ |
+class PPAPI_PROXY_EXPORT DirectoryReaderResource |
+ : public PluginResource, |
+ public NON_EXPORTED_BASE(thunk::PPB_DirectoryReader_API) { |
+ public: |
+ DirectoryReaderResource(Connection connection, |
+ PP_Instance instance, |
+ PP_Resource directory_ref); |
+ virtual ~DirectoryReaderResource(); |
+ |
+ // Resource overrides. |
+ virtual thunk::PPB_DirectoryReader_API* AsPPB_DirectoryReader_API() OVERRIDE; |
+ |
+ // PPB_DirectoryReader_API. |
+ virtual int32_t GetNextEntry( |
+ PP_DirectoryEntry_Dev* entry, |
+ scoped_refptr<TrackedCallback> callback) OVERRIDE; |
+ |
+ private: |
+ void OnPluginMsgGetEntriesReply( |
+ const ResourceMessageReplyParams& params, |
+ const std::vector<ppapi::PPB_FileRef_CreateInfo>& infos, |
+ const std::vector<PP_FileType>& file_types, |
+ bool has_more); |
+ bool FillUpEntry(); |
+ |
+ // Owning a reference to the directory to be read. |
+ PP_Resource directory_ref_; |
dmichael (off chromium)
2013/01/29 21:22:42
Probably should be a scoped_refptr instead?
dmichael (off chromium)
2013/01/29 21:25:31
Let me clarify a bit... you should just hold a sc
nhiroki
2013/01/30 09:24:51
I see, thanks for your clear explanation! Done.
|
+ |
+ // Owning references to files and directories. |
+ std::queue<PP_DirectoryEntry_Dev> entries_; |
dmichael (off chromium)
2013/01/29 21:22:42
ditto, scoped_refptr
nhiroki
2013/01/30 09:24:51
Done.
|
+ |
+ PP_DirectoryEntry_Dev* output_; |
+ bool has_more_; |
+ |
+ scoped_refptr<TrackedCallback> callback_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(DirectoryReaderResource); |
+}; |
+ |
+} // namespace proxy |
+} // namespace ppapi |
+ |
+#endif // PPAPI_PROXY_DIRECTORY_READER_RESOURCE_H_ |