| // Copyright (c) 2011 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. | 
 |  | 
 | #ifndef PPAPI_CPP_MODULE_EMBEDDER_H_ | 
 | #define PPAPI_CPP_MODULE_EMBEDDER_H_ | 
 |  | 
 | #include "ppapi/c/ppp.h" | 
 |  | 
 | /// @file | 
 | /// This file defines the APIs for creating a Module object. | 
 | namespace pp { | 
 |  | 
 | class Module; | 
 |  | 
 | /// This function creates the <code>pp::Module</code> object associated with | 
 | /// this module. | 
 | /// | 
 | /// <strong>Note: </strong>NaCl module developers must implement this function. | 
 | /// | 
 | /// @return Returns the module if it was successfully created, or NULL on | 
 | /// failure. Upon failure, the module will be unloaded. | 
 | pp::Module* CreateModule(); | 
 |  | 
 | /// Sets the get interface function in the broker process. | 
 | /// | 
 | /// This function is only relevant when you're using the PPB_Broker interface | 
 | /// in a trusted native plugin. In this case, you may need to implement | 
 | /// PPP_GetInterface when the plugin is loaded in the unsandboxed process. | 
 | /// Normally the C++ wrappers implement PPP_GetInterface for you but this | 
 | /// doesn't work in the context of the broker process. | 
 | // | 
 | /// So if you need to implement PPP_* interfaces in the broker process, call | 
 | /// this function in your PPP_InitializeBroker implementation which will set | 
 | /// up the given function as implementing PPP_GetInterface. | 
 | void SetBrokerGetInterfaceFunc(PP_GetInterface_Func broker_get_interface); | 
 |  | 
 | }  // namespace pp | 
 |  | 
 | #endif  // PPAPI_CPP_MODULE_EMBEDDER_H_ |