1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef PPAPI_CPP_DIRECTORY_ENTRY_H_
6 #define PPAPI_CPP_DIRECTORY_ENTRY_H_
10 #include "ppapi/c/pp_array_output.h"
11 #include "ppapi/c/pp_directory_entry.h"
12 #include "ppapi/cpp/array_output.h"
13 #include "ppapi/cpp/file_ref.h"
14 #include "ppapi/cpp/output_traits.h"
15 #include "ppapi/cpp/pass_ref.h"
18 /// This file defines the API used to handle a directory entry.
22 /// The <code>DirectoryEntry</code> class represents information about
23 /// a directory entry.
24 class DirectoryEntry
{
26 /// Default constructor for creating an is_null() <code>DirectoryEntry</code>
30 /// A constructor used when you have a <code>PP_DirectoryEntry</code> which
31 /// contains a <code>FileRef</code> that has already been reference counted
32 /// as a return value.
34 /// @param[in] data A <code>PP_DirectoryEntry</code> to be copied.
35 DirectoryEntry(PassRef
, const PP_DirectoryEntry
& data
);
37 /// A copy constructor for <code>DirectoryEntry</code>. This constructor
38 /// increments a reference count of the <code>FileRef</code> held by this
41 /// @param[in] other A pointer to a <code>DirectoryEntry</code>.
42 DirectoryEntry(const DirectoryEntry
& other
);
44 /// A destructor that decrements a reference count of the <code>FileRef</code>
45 /// held by this <code>DirectoryEntry</code>.
48 /// This function assigns one <code>DirectoryEntry</code> object to this
49 /// <code>DirectoryEntry</code> object. This function increases the reference
50 /// count of the <code>FileRef</code> of the other DirectoryEntry while
51 /// decrementing the reference count of the FileRef of this DirectoryEntry.
53 /// @param[in] other A pointer to a <code>DirectoryEntry</code>.
55 /// @return A new <code>DirectoryEntry</code> object.
56 DirectoryEntry
& operator=(const DirectoryEntry
& other
);
58 /// This function determines if this <code>DirectoryEntry</code> is a null
61 /// @return true if this <code>DirectoryEntry</code> is null, otherwise false.
62 bool is_null() const { return !data_
.file_ref
; }
64 /// This function returns the <code>FileRef</code> held by this
65 /// <code>DirectoryEntry</code>.
67 /// @return A <code>FileRef</code> of the file.
68 FileRef
file_ref() const { return FileRef(data_
.file_ref
); }
70 /// This function returns the <code>PP_FileType</code> of the file referenced
71 /// by this <code>DirectoryEntry</code>.
73 /// @return A <code>PP_FileType</code> of the file.
74 PP_FileType
file_type() const { return data_
.file_type
; }
77 PP_DirectoryEntry data_
;
82 class DirectoryEntryArrayOutputAdapterWithStorage
83 : public ArrayOutputAdapter
<PP_DirectoryEntry
> {
85 DirectoryEntryArrayOutputAdapterWithStorage();
86 virtual ~DirectoryEntryArrayOutputAdapterWithStorage();
88 // Returns the final array of resource objects, converting the
89 // PP_DirectoryEntry written by the browser to pp::DirectoryEntry
92 // This function should only be called once or we would end up converting
93 // the array more than once, which would mess up the refcounting.
94 std::vector
<DirectoryEntry
>& output();
97 // The browser will write the PP_DirectoryEntrys into this array.
98 std::vector
<PP_DirectoryEntry
> temp_storage_
;
100 // When asked for the output, the PP_DirectoryEntrys above will be
101 // converted to the pp::DirectoryEntrys in this array for passing to the
103 std::vector
<DirectoryEntry
> output_storage_
;
106 // A specialization of CallbackOutputTraits to provide the callback system the
107 // information on how to handle vectors of pp::DirectoryEntry. This converts
108 // PP_DirectoryEntry to pp::DirectoryEntry when passing to the plugin.
110 struct CallbackOutputTraits
< std::vector
<DirectoryEntry
> > {
111 typedef PP_ArrayOutput APIArgType
;
112 typedef DirectoryEntryArrayOutputAdapterWithStorage StorageType
;
114 static inline APIArgType
StorageToAPIArg(StorageType
& t
) {
115 return t
.pp_array_output();
118 static inline std::vector
<DirectoryEntry
>& StorageToPluginArg(
123 static inline void Initialize(StorageType
* /* t */) {}
126 } // namespace internal
129 #endif // PPAPI_CPP_DIRECTORY_ENTRY_H_