Pepper_42_C++_interfaces
var_array_buffer.h
Go to the documentation of this file.
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
3 // found in the LICENSE file.
4 
5 #ifndef PPAPI_CPP_VAR_ARRAY_BUFFER_H_
6 #define PPAPI_CPP_VAR_ARRAY_BUFFER_H_
7 
8 #include "ppapi/cpp/var.h"
9 
10 /// @file
11 /// This file defines the API for interacting with a JavaScript ArrayBuffer.
12 
13 namespace pp {
14 
15 /// <code>VarArrayBuffer</code> provides a way to interact with JavaScript
16 /// ArrayBuffers, which represent a contiguous sequence of bytes. Note that
17 /// these vars are not part of the embedding page's DOM, and can only be
18 /// shared with JavaScript using the <code>PostMessage</code> and
19 /// <code>HandleMessage</code> functions of <code>Instance</code>.
20 class VarArrayBuffer : public Var {
21  public:
22  /// The default constructor constructs a <code>VarArrayBuffer</code> which is
23  /// 0 byte long.
25 
26  /// Construct a <code>VarArrayBuffer</code> given a var for which
27  /// is_array_buffer() is true. This will refer to the same
28  /// <code>ArrayBuffer</code> as var, but allows you to access methods
29  /// specific to <code>VarArrayBuffer</code>.
30  ///
31  /// @param[in] var An <code>ArrayBuffer</code> var.
32  explicit VarArrayBuffer(const Var& var);
33 
34  /// Construct a new <code>VarArrayBuffer</code> which is
35  /// <code>size_in_bytes</code> bytes long and initialized to zero.
36  ///
37  /// @param[in] size_in_bytes The size of the constructed
38  /// <code>ArrayBuffer</code> in bytes.
39  explicit VarArrayBuffer(uint32_t size_in_bytes);
40 
41  /// Copy constructor.
42  VarArrayBuffer(const VarArrayBuffer& buffer) : Var(buffer) {}
43 
44  virtual ~VarArrayBuffer() {}
45 
46  /// This function assigns one <code>VarArrayBuffer</code> to another
47  /// <code>VarArrayBuffer</code>.
48  ///
49  /// @param[in] other The <code>VarArrayBuffer</code> to be assigned.
50  ///
51  /// @return The resulting <code>VarArrayBuffer</code>.
53 
54  /// This function assigns one <code>VarArrayBuffer</code> to another
55  /// <code>VarArrayBuffer</code>. A Var's assignment operator is overloaded
56  /// here so that we can check for assigning a non-ArrayBuffer var to a
57  /// <code>VarArrayBuffer</code>.
58  ///
59  /// @param[in] other The <code>VarArrayBuffer</code> to be assigned.
60  ///
61  /// @return The resulting <code>VarArrayBuffer</code> (as a Var&).
62  virtual Var& operator=(const Var& other);
63 
64  /// ByteLength() retrieves the length of the <code>VarArrayBuffer</code> in
65  /// bytes.
66  ///
67  /// @return The length of the <code>VarArrayBuffer</code> in bytes.
68  uint32_t ByteLength() const;
69 
70  /// Map() maps the <code>ArrayBuffer</code> in to the module's address space
71  /// and returns a pointer to the beginning of the internal buffer for
72  /// this <code>ArrayBuffer</code>. ArrayBuffers are copied when transmitted,
73  /// so changes to the underlying memory are not automatically available to
74  /// the embedding page.
75  ///
76  /// Note that calling Map() can be a relatively expensive operation. Use care
77  /// when calling it in performance-critical code. For example, you should call
78  /// it only once when looping over an <code>ArrayBuffer</code>.
79  ///
80  /// <strong>Example:</strong>
81  ///
82  /// @code
83  /// char* data = static_cast<char*>(array_buffer_var.Map());
84  /// uint32_t byte_length = array_buffer_var.ByteLength();
85  /// for (uint32_t i = 0; i < byte_length; ++i)
86  /// data[i] = 'A';
87  /// @endcode
88  ///
89  /// @return A pointer to the internal buffer for this
90  /// <code>ArrayBuffer</code>.
91  void* Map();
92 
93  /// Unmap() unmaps this <code>ArrayBuffer</code> var from the module address
94  /// space. Use this if you want to save memory but might want to call Map()
95  /// to map the buffer again later.
96  void Unmap();
97 
98  private:
99  void ConstructWithSize(uint32_t size_in_bytes);
100 };
101 
102 } // namespace pp
103 
104 #endif // PPAPI_CPP_VAR_ARRAY_BUFFER_H_
uint32_t ByteLength() const
VarArrayBuffer & operator=(const VarArrayBuffer &other)
A generic type used for passing data types between the module and the page.
Definition: var.h:21
VarArrayBuffer(const VarArrayBuffer &buffer)
Copy constructor.