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 | 5 |
6 /** | 6 /** |
7 * This file defines the <code>PPB_VarArrayBuffer_Dev</code> struct. | 7 * This file defines the <code>PPB_VarArrayBuffer_Dev</code> struct. |
8 */ | 8 */ |
9 | 9 |
10 label Chrome { | 10 label Chrome { |
11 M17 = 0.1 | 11 M18 = 0.2 |
12 }; | 12 }; |
13 | 13 |
14 /** | 14 /** |
15 * PPB_VarArrayBuffer_Dev API. This provides a way to interact with JavaScript | 15 * PPB_VarArrayBuffer_Dev API. This provides a way to interact with JavaScript |
16 * ArrayBuffers, which represent a contiguous sequence of bytes. To manage the | 16 * ArrayBuffers, which represent a contiguous sequence of bytes. To manage the |
17 * reference count for a VarArrayBuffer, please see PPB_Var. Note that | 17 * reference count for a VarArrayBuffer, please see PPB_Var. Note that |
18 * these Vars are not part of the embedding page's DOM, and can only be shared | 18 * these Vars are not part of the embedding page's DOM, and can only be shared |
19 * with JavaScript via pp::Instance's PostMessage and HandleMessage functions. | 19 * with JavaScript via pp::Instance's PostMessage and HandleMessage functions. |
20 */ | 20 */ |
21 [macro="PPB_VAR_ARRAY_BUFFER_DEV_INTERFACE"] | 21 [macro="PPB_VAR_ARRAY_BUFFER_DEV_INTERFACE"] |
22 interface PPB_VarArrayBuffer_Dev { | 22 interface PPB_VarArrayBuffer_Dev { |
23 /** | 23 /** |
24 * Create a zero-initialized VarArrayBuffer. | 24 * Create a zero-initialized VarArrayBuffer. |
25 * | 25 * |
26 * @param[in] size_in_bytes The size of the array buffer that will be created. | 26 * @param[in] size_in_bytes The size of the array buffer that will be created. |
27 * | 27 * |
28 * @return A PP_Var which represents an VarArrayBuffer of the requested size | 28 * @return A PP_Var which represents an VarArrayBuffer of the requested size |
29 * with a reference count of 1. | 29 * with a reference count of 1. |
30 */ | 30 */ |
31 PP_Var Create([in] uint32_t size_in_bytes); | 31 PP_Var Create([in] uint32_t size_in_bytes); |
32 | |
32 /** | 33 /** |
33 * Returns the length of the VarArrayBuffer in bytes. | 34 * Retrieves the length of the VarArrayBuffer in bytes. |
34 * | 35 * |
35 * @return The length of the VarArrayBuffer in bytes. | 36 * @param[in] array The array whose length should be returned. |
37 * | |
38 * @param[out] byte_length The length of the given array. | |
39 * | |
40 * @return PP_TRUE on success, PP_FALSE on failure. | |
36 */ | 41 */ |
37 uint32_t ByteLength([in] PP_Var array); | 42 PP_Bool ByteLength([in] PP_Var array, [out] uint32_t byte_length); |
43 | |
38 /** | 44 /** |
39 * Returns a pointer to the beginning of the buffer for the given array. | 45 * Maps the ArrayBuffer in to the module's address space and returns a pointer |
46 * to the beginning of the buffer for the given ArrayBuffer PP_Var. Note that | |
47 * calling Map() can be a relatively expensive operation. Use care when | |
48 * calling it in performance-critical code. For example, you should call it | |
49 * only once when looping over an ArrayBuffer: | |
50 * | |
51 * <code> | |
52 * char* data = (char*)(array_buffer_if.Map(array_buffer_var)); | |
53 * uint32_t byte_length = 0; | |
54 * PP_Bool ok = array_buffer_if.ByteLength(array_buffer_var, &byte_length); | |
55 * if (!ok) | |
56 * return DoSomethingBecauseMyVarIsNotAnArrayBuffer(); | |
57 * for (uint32_t i = 0; i < byte_length; ++i) | |
58 * data[i] = 'A'; | |
59 * </code> | |
40 * | 60 * |
41 * @param[in] array The array whose buffer should be returned. | 61 * @param[in] array The array whose buffer should be returned. |
bbudge
2012/01/25 22:19:07
Buffer in this case is the physical address?
dmichael (off chromium)
2012/01/25 23:50:11
Yes.
| |
42 * | 62 * |
43 * @return A pointer to the buffer for this array. | 63 * @return A pointer to the buffer for this array. Returns NULL if the given |
64 * PP_Var is not of type PP_VARTYPE_ARRAY_BUFFER. | |
44 */ | 65 */ |
45 mem_t Map([in] PP_Var array); | 66 mem_t Map([in] PP_Var array); |
67 | |
68 /** | |
69 * Unmaps the given ArrayBuffer var from the module address space. Use this if | |
70 * you want to save memory but might want to Map the buffer again later. The | |
71 * PP_Var remains valid and should still be released using PPB_Var when you | |
72 * are done with the ArrayBuffer. | |
73 * | |
74 * @param[in] array The ArrayBuffer which should be released. | |
75 */ | |
76 void Unmap([in] PP_Var array); | |
bbudge
2012/01/25 22:19:07
Kind of confusing mix of Array, ArrayBuffer and Va
dmichael (off chromium)
2012/01/25 23:50:11
Good point, done.
| |
46 }; | 77 }; |
47 | 78 |
OLD | NEW |