Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(617)

Unified Diff: ppapi/proxy/directory_reader_resource.h

Issue 11958033: Implement Pepper proxy for PPB_DirectoryReader (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: fix test failure Created 7 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
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..f12fb1f2837117f415f0d6add6a2ed5e122b2f0f
--- /dev/null
+++ b/ppapi/proxy/directory_reader_resource.h
@@ -0,0 +1,67 @@
+// 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:
+ struct DirectoryEntry {
+ scoped_refptr<Resource> file_resource;
yzshen1 2013/01/31 08:50:54 nit: please include what you use. (ref_counted.h)
nhiroki 2013/02/01 08:19:47 Done.
+ PP_FileType file_type;
+ };
+
+ void OnPluginMsgGetEntriesReply(
+ const ResourceMessageReplyParams& params,
+ const std::vector<ppapi::PPB_FileRef_CreateInfo>& infos,
+ const std::vector<PP_FileType>& file_types);
+ bool FillUpEntry();
+
+ scoped_refptr<Resource> directory_resource_;
+ std::queue<DirectoryEntry> entries_;
+
+ 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_

Powered by Google App Engine
This is Rietveld 408576698