| /* Copyright (c) 2012 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. |
| */ |
| |
| /** |
| * This file defines the API for handling the passing of data types between |
| * your module and the page. |
| */ |
| |
| /** |
| * The <code>PP_VarType</code> is an enumeration of the different types that |
| * can be contained within a <code>PP_Var</code> structure. |
| */ |
| [assert_size(4)] |
| enum PP_VarType { |
| /** |
| * An undefined value. |
| */ |
| PP_VARTYPE_UNDEFINED = 0, |
| |
| /** |
| * A NULL value. This is similar to undefined, but JavaScript differentiates |
| * the two so it is exposed here as well. |
| */ |
| PP_VARTYPE_NULL = 1, |
| |
| /** |
| * A boolean value, use the <code>as_bool</code> member of the var. |
| */ |
| PP_VARTYPE_BOOL = 2, |
| |
| /** |
| * A 32-bit integer value. Use the <code>as_int</code> member of the var. |
| */ |
| PP_VARTYPE_INT32 = 3, |
| |
| /** |
| * A double-precision floating point value. Use the <code>as_double</code> |
| * member of the var. |
| */ |
| PP_VARTYPE_DOUBLE = 4, |
| |
| /** |
| * The Var represents a string. The <code>as_id</code> field is used to |
| * identify the string, which may be created and retrieved from the |
| * <code>PPB_Var</code> interface. These objects are reference counted, so |
| * AddRef() and Release() must be used properly to avoid memory leaks. |
| */ |
| PP_VARTYPE_STRING = 5, |
| |
| /** |
| * Represents a JavaScript object. This vartype is not currently usable |
| * from modules, although it is used internally for some tasks. These objects |
| * are reference counted, so AddRef() and Release() must be used properly to |
| * avoid memory leaks. |
| */ |
| PP_VARTYPE_OBJECT = 6, |
| |
| /** |
| * Represents an array of Vars. The <code>as_id</code> field is used to |
| * identify the array, which may be created and manipulated from the |
| * <code>PPB_VarArray</code> interface. These objects are reference counted, |
| * so AddRef() and Release() must be used properly to avoid memory leaks. |
| */ |
| PP_VARTYPE_ARRAY = 7, |
| |
| /** |
| * Represents a mapping from strings to Vars. The <code>as_id</code> field is |
| * used to identify the dictionary, which may be created and manipulated from |
| * the <code>PPB_VarDictionary</code> interface. These objects are reference |
| * counted, so AddRef() and Release() must be used properly to avoid memory |
| * leaks. |
| */ |
| PP_VARTYPE_DICTIONARY = 8, |
| |
| /** |
| * ArrayBuffer represents a JavaScript ArrayBuffer. This is the type which |
| * represents Typed Arrays in JavaScript. Unlike JavaScript 'Array', it is |
| * only meant to contain basic numeric types, and is always stored |
| * contiguously. See PPB_VarArrayBuffer_Dev for functions special to |
| * ArrayBuffer vars. These objects are reference counted, so AddRef() and |
| * Release() must be used properly to avoid memory leaks. |
| */ |
| PP_VARTYPE_ARRAY_BUFFER = 9, |
| |
| /** |
| * This type allows the <code>PP_Var</code> to wrap a <code>PP_Resource |
| * </code>. This can be useful for sending or receiving some types of |
| * <code>PP_Resource</code> using <code>PPB_Messaging</code> or |
| * <code>PPP_Messaging</code>. |
| * |
| * These objects are reference counted, so AddRef() and Release() must be used |
| * properly to avoid memory leaks. Under normal circumstances, the |
| * <code>PP_Var</code> will implicitly hold a reference count on the |
| * <code>PP_Resource</code> on your behalf. For example, if you call |
| * VarFromResource(), it implicitly calls PPB_Core::AddRefResource() on the |
| * <code>PP_Resource</code>. Likewise, PPB_Var::Release() on a Resource |
| * <code>PP_Var</code> will invoke PPB_Core::ReleaseResource() when the Var |
| * reference count goes to zero. |
| */ |
| PP_VARTYPE_RESOURCE = 10 |
| }; |
| |
| |
| /** |
| * The PP_VarValue union stores the data for any one of the types listed |
| * in the PP_VarType enum. |
| */ |
| [union] struct PP_VarValue { |
| /** |
| * If <code>type</code> is <code>PP_VARTYPE_BOOL</code>, |
| * <code>as_bool</code> represents the value of this <code>PP_Var</code> as |
| * <code>PP_Bool</code>. |
| */ |
| PP_Bool as_bool; |
| |
| /** |
| * If <code>type</code> is <code>PP_VARTYPE_INT32</code>, |
| * <code>as_int</code> represents the value of this <code>PP_Var</code> as |
| * <code>int32_t</code>. |
| */ |
| int32_t as_int; |
| |
| /** |
| * If <code>type</code> is <code>PP_VARTYPE_DOUBLE</code>, |
| * <code>as_double</code> represents the value of this <code>PP_Var</code> |
| * as <code>double</code>. |
| */ |
| double_t as_double; |
| |
| /** |
| * If <code>type</code> is <code>PP_VARTYPE_STRING</code>, |
| * <code>PP_VARTYPE_OBJECT</code>, <code>PP_VARTYPE_ARRAY</code>, |
| * <code>PP_VARTYPE_DICTIONARY</code>, <code>PP_VARTYPE_ARRAY_BUFFER</code>, |
| * or <code>PP_VARTYPE_RESOURCE</code>, <code>as_id</code> represents the |
| * value of this <code>PP_Var</code> as an opaque handle assigned by the |
| * browser. This handle is guaranteed never to be 0, so a module can |
| * initialize this ID to 0 to indicate a "NULL handle." |
| */ |
| int64_t as_id; |
| }; |
| |
| /** |
| * The <code>PP_VAR</code> struct is a variant data type and can contain any |
| * value of one of the types named in the <code>PP_VarType</code> enum. This |
| * structure is for passing data between native code which can be strongly |
| * typed and the browser (JavaScript) which isn't strongly typed. |
| * |
| * JavaScript has a "number" type for holding a number, and does not |
| * differentiate between floating point and integer numbers. The |
| * JavaScript operations will try to optimize operations by using |
| * integers when possible, but could end up with doubles. Therefore, |
| * you can't assume a numeric <code>PP_Var</code> will be the type you expect. |
| * Your code should be capable of handling either int32_t or double for numeric |
| * PP_Vars sent from JavaScript. |
| */ |
| [passByValue, returnByValue, assert_size(16)] |
| struct PP_Var { |
| PP_VarType type; |
| |
| /** |
| * The <code>padding</code> ensures <code>value</code> is aligned on an |
| * 8-byte boundary relative to the start of the struct. Some compilers |
| * align doubles on 8-byte boundaries for 32-bit x86, and some align on |
| * 4-byte boundaries. |
| */ |
| int32_t padding; |
| |
| /** |
| * This <code>value</code> represents the contents of the PP_Var. Only one of |
| * the fields of <code>value</code> is valid at a time based upon |
| * <code>type</code>. |
| */ |
| PP_VarValue value; |
| }; |
| |
| |
| #inline c |
| /** |
| * @addtogroup Functions |
| * @{ |
| */ |
| |
| /** |
| * PP_MakeUndefined() is used to wrap an undefined value into a |
| * <code>PP_Var</code> struct for passing to the browser. |
| * |
| * @return A <code>PP_Var</code> structure. |
| */ |
| PP_INLINE struct PP_Var PP_MakeUndefined(void) { |
| struct PP_Var result = { PP_VARTYPE_UNDEFINED, 0, {PP_FALSE} }; |
| return result; |
| } |
| |
| /** |
| * PP_MakeNull() is used to wrap a null value into a |
| * <code>PP_Var</code> struct for passing to the browser. |
| * |
| * @return A <code>PP_Var</code> structure, |
| */ |
| PP_INLINE struct PP_Var PP_MakeNull(void) { |
| struct PP_Var result = { PP_VARTYPE_NULL, 0, {PP_FALSE} }; |
| return result; |
| } |
| |
| /** |
| * PP_MakeBool() is used to wrap a boolean value into a |
| * <code>PP_Var</code> struct for passing to the browser. |
| * |
| * @param[in] value A <code>PP_Bool</code> enumeration to |
| * wrap. |
| * |
| * @return A <code>PP_Var</code> structure. |
| */ |
| PP_INLINE struct PP_Var PP_MakeBool(PP_Bool value) { |
| struct PP_Var result = { PP_VARTYPE_BOOL, 0, {PP_FALSE} }; |
| result.value.as_bool = value; |
| return result; |
| } |
| |
| /** |
| * PP_MakeInt32() is used to wrap a 32 bit integer value |
| * into a <code>PP_Var</code> struct for passing to the browser. |
| * |
| * @param[in] value An int32 to wrap. |
| * |
| * @return A <code>PP_Var</code> structure. |
| */ |
| PP_INLINE struct PP_Var PP_MakeInt32(int32_t value) { |
| struct PP_Var result = { PP_VARTYPE_INT32, 0, {PP_FALSE} }; |
| result.value.as_int = value; |
| return result; |
| } |
| |
| /** |
| * PP_MakeDouble() is used to wrap a double value into a |
| * <code>PP_Var</code> struct for passing to the browser. |
| * |
| * @param[in] value A double to wrap. |
| * |
| * @return A <code>PP_Var</code> structure. |
| */ |
| PP_INLINE struct PP_Var PP_MakeDouble(double value) { |
| struct PP_Var result = { PP_VARTYPE_DOUBLE, 0, {PP_FALSE} }; |
| result.value.as_double = value; |
| return result; |
| } |
| /** |
| * @} |
| */ |
| |
| #endinl |
| |