15821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)/* Copyright (c) 2012 The Chromium Authors. All rights reserved.
25821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * Use of this source code is governed by a BSD-style license that can be
35821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * found in the LICENSE file.
45821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) */
55821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
65821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)/**
75821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * This file defines the <code>PP_Resource</code> type which represents data
85821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * associated with the module.
95821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) */
105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)/**
12c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) * This typedef represents an opaque handle assigned by the browser to the
135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * resource. The handle is guaranteed never to be 0 for a valid resource, so a
145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * module can initialize it to 0 to indicate a "NULL handle." Some interfaces
155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * may return a NULL resource to indicate failure.
165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) *
175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * While a Var represents something callable to JS or from the module to
185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * the DOM, a resource has no meaning or visibility outside of the module
195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * interface.
205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) *
215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * Resources are reference counted. Use <code>AddRefResource()</code>
225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * and <code>ReleaseResource()</code> in <code>ppb_core.h</code> to manage the
235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * reference count of a resource. The data will be automatically destroyed when
245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * the internal reference count reaches 0.
255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) */
265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)[assert_size(4)] typedef int32_t PP_Resource;
275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
28