| OLD | NEW |
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 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 | 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 #ifndef PPAPI_C_PRIVATE_PROXY_PRIVATE_H_ | 5 #ifndef PPAPI_C_PRIVATE_PROXY_PRIVATE_H_ |
| 6 #define PPAPI_C_PRIVATE_PROXY_PRIVATE_H_ | 6 #define PPAPI_C_PRIVATE_PROXY_PRIVATE_H_ |
| 7 | 7 |
| 8 #include "ppapi/c/pp_bool.h" |
| 8 #include "ppapi/c/pp_instance.h" | 9 #include "ppapi/c/pp_instance.h" |
| 9 #include "ppapi/c/pp_module.h" | 10 #include "ppapi/c/pp_module.h" |
| 10 #include "ppapi/c/pp_resource.h" | 11 #include "ppapi/c/pp_resource.h" |
| 11 | 12 |
| 12 #define PPB_PROXY_PRIVATE_INTERFACE "PPB_Proxy_Private;2" | 13 #define PPB_PROXY_PRIVATE_INTERFACE "PPB_Proxy_Private;3" |
| 13 | 14 |
| 14 // Exposes functions needed by the out-of-process proxy to call into the | 15 // Exposes functions needed by the out-of-process proxy to call into the |
| 15 // renderer PPAPI implementation. | 16 // renderer PPAPI implementation. |
| 16 struct PPB_Proxy_Private { | 17 struct PPB_Proxy_Private { |
| 17 // Called when the given plugin process has crashed. | 18 // Called when the given plugin process has crashed. |
| 18 void (*PluginCrashed)(PP_Module module); | 19 void (*PluginCrashed)(PP_Module module); |
| 19 | 20 |
| 20 // Returns the instance for the given resource, or 0 on failure. | 21 // Returns the instance for the given resource, or 0 on failure. |
| 21 PP_Instance (*GetInstanceForResource)(PP_Resource resource); | 22 PP_Instance (*GetInstanceForResource)(PP_Resource resource); |
| 23 |
| 24 // Sets a callback that will be used to make sure that PP_Instance IDs |
| 25 // are unique in the plugin. |
| 26 // |
| 27 // Since the plugin may be shared between several browser processes, we need |
| 28 // to do extra work to make sure that an instance ID is globally unqiue. The |
| 29 // given function will be called and will return true if the given |
| 30 // PP_Instance is OK to use in the plugin. It will then be marked as "in use" |
| 31 // On failure (returns false), the host implementation will generate a new |
| 32 // instance ID and try again. |
| 33 void (*SetReserveInstanceIDCallback)( |
| 34 PP_Module module, |
| 35 PP_Bool (*is_seen)(PP_Module, PP_Instance)); |
| 22 }; | 36 }; |
| 23 | 37 |
| 24 #endif // PPAPI_C_PRIVATE_PROXY_PRIVATE_H_ | 38 #endif // PPAPI_C_PRIVATE_PROXY_PRIVATE_H_ |
| OLD | NEW |