// 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. #ifndef PPAPI_PROXY_PLUGIN_GLOBALS_H_ #define PPAPI_PROXY_PLUGIN_GLOBALS_H_ #include <string> #include "base/compiler_specific.h" #include "base/memory/scoped_ptr.h" #include "base/threading/thread_local_storage.h" #include "ppapi/proxy/connection.h" #include "ppapi/proxy/plugin_resource_tracker.h" #include "ppapi/proxy/plugin_var_tracker.h" #include "ppapi/proxy/ppapi_proxy_export.h" #include "ppapi/shared_impl/callback_tracker.h" #include "ppapi/shared_impl/ppapi_globals.h" namespace base { class Thread; } namespace IPC { class Sender; } struct PP_BrowserFont_Trusted_Description; namespace ppapi { struct Preferences; namespace proxy { class MessageLoopResource; class PluginProxyDelegate; class ResourceReplyThreadRegistrar; class PPAPI_PROXY_EXPORT PluginGlobals : public PpapiGlobals { public: PluginGlobals(); explicit PluginGlobals(PpapiGlobals::PerThreadForTest); virtual ~PluginGlobals(); // Getter for the global singleton. Generally, you should use // PpapiGlobals::Get() when possible. Use this only when you need some // plugin-specific functionality. inline static PluginGlobals* Get() { // Explicitly crash if this is the wrong process type, we want to get // crash reports. CHECK(PpapiGlobals::Get()->IsPluginGlobals()); return static_cast<PluginGlobals*>(PpapiGlobals::Get()); } // PpapiGlobals implementation. virtual ResourceTracker* GetResourceTracker() OVERRIDE; virtual VarTracker* GetVarTracker() OVERRIDE; virtual CallbackTracker* GetCallbackTrackerForInstance( PP_Instance instance) OVERRIDE; virtual thunk::PPB_Instance_API* GetInstanceAPI( PP_Instance instance) OVERRIDE; virtual thunk::ResourceCreationAPI* GetResourceCreationAPI( PP_Instance instance) OVERRIDE; virtual PP_Module GetModuleForInstance(PP_Instance instance) OVERRIDE; virtual std::string GetCmdLine() OVERRIDE; virtual void PreCacheFontForFlash(const void* logfontw) OVERRIDE; virtual void LogWithSource(PP_Instance instance, PP_LogLevel level, const std::string& source, const std::string& value) OVERRIDE; virtual void BroadcastLogWithSource(PP_Module module, PP_LogLevel level, const std::string& source, const std::string& value) OVERRIDE; virtual MessageLoopShared* GetCurrentMessageLoop() OVERRIDE; base::TaskRunner* GetFileTaskRunner() OVERRIDE; // Returns the channel for sending to the browser. IPC::Sender* GetBrowserSender(); // Returns the language code of the current UI language. std::string GetUILanguage(); // Sets the active url which is reported by breakpad. void SetActiveURL(const std::string& url); PP_Resource CreateBrowserFont( Connection connection, PP_Instance instance, const PP_BrowserFont_Trusted_Description& desc, const Preferences& prefs); // Getters for the plugin-specific versions. PluginResourceTracker* plugin_resource_tracker() { return &plugin_resource_tracker_; } PluginVarTracker* plugin_var_tracker() { return &plugin_var_tracker_; } // The embedder should call set_proxy_delegate during startup. void set_plugin_proxy_delegate(PluginProxyDelegate* d) { plugin_proxy_delegate_ = d; } // Returns the TLS slot that holds the message loop TLS. // // If we end up needing more TLS storage for more stuff, we should probably // have a struct in here for the different items. base::ThreadLocalStorage::Slot* msg_loop_slot() { return msg_loop_slot_.get(); } // Sets the message loop slot, takes ownership of the given heap-alloated // pointer. void set_msg_loop_slot(base::ThreadLocalStorage::Slot* slot) { msg_loop_slot_.reset(slot); } // Return the special Resource that represents the MessageLoop for the main // thread. This Resource is not associated with any instance, and lives as // long as the plugin. MessageLoopResource* loop_for_main_thread(); // The embedder should call this function when the name of the plugin module // is known. This will be used for error logging. void set_plugin_name(const std::string& name) { plugin_name_ = name; } // The embedder should call this function when the command line is known. void set_command_line(const std::string& c) { command_line_ = c; } ResourceReplyThreadRegistrar* resource_reply_thread_registrar() { return resource_reply_thread_registrar_.get(); } private: class BrowserSender; // PpapiGlobals overrides. virtual bool IsPluginGlobals() const OVERRIDE; static PluginGlobals* plugin_globals_; PluginProxyDelegate* plugin_proxy_delegate_; PluginResourceTracker plugin_resource_tracker_; PluginVarTracker plugin_var_tracker_; scoped_refptr<CallbackTracker> callback_tracker_; scoped_ptr<base::ThreadLocalStorage::Slot> msg_loop_slot_; // Note that loop_for_main_thread's constructor sets msg_loop_slot_, so it // must be initialized after msg_loop_slot_ (hence the order here). scoped_refptr<MessageLoopResource> loop_for_main_thread_; // Name of the plugin used for error logging. This will be empty until // set_plugin_name is called. std::string plugin_name_; // Command line for the plugin. This will be empty until set_command_line is // called. std::string command_line_; scoped_ptr<BrowserSender> browser_sender_; // Thread for performing potentially blocking file operations. It's created // lazily, since it might not be needed. scoped_ptr<base::Thread> file_thread_; scoped_refptr<ResourceReplyThreadRegistrar> resource_reply_thread_registrar_; DISALLOW_COPY_AND_ASSIGN(PluginGlobals); }; } // namespace proxy } // namespace ppapi #endif // PPAPI_PROXY_PLUGIN_GLOBALS_H_