- add sources.
[platform/framework/web/crosswalk.git] / src / content / renderer / browser_plugin / browser_plugin_manager.h
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #ifndef CONTENT_RENDERER_BROWSER_PLUGIN_BROWSER_PLUGIN_MANAGER_H_
6 #define CONTENT_RENDERER_BROWSER_PLUGIN_BROWSER_PLUGIN_MANAGER_H_
7
8 #include "base/id_map.h"
9 #include "base/memory/ref_counted.h"
10 #include "base/memory/weak_ptr.h"
11 #include "base/observer_list.h"
12 #include "content/public/renderer/render_view_observer.h"
13 #include "ipc/ipc_sender.h"
14
15 namespace WebKit {
16 class WebFrame;
17 struct WebPluginParams;
18 }
19
20 namespace content {
21
22 class BrowserPlugin;
23 class BrowserPluginManagerFactory;
24 class RenderViewImpl;
25
26 // BrowserPluginManager manages the routing of messages to the appropriate
27 // BrowserPlugin object based on its instance ID.
28 class CONTENT_EXPORT BrowserPluginManager
29     : public RenderViewObserver,
30       public base::RefCounted<BrowserPluginManager> {
31  public:
32   // Returns the one BrowserPluginManager for this process.
33   static BrowserPluginManager* Create(RenderViewImpl* render_view);
34
35   // Overrides factory for testing. Default (NULL) value indicates regular
36   // (non-test) environment.
37   static void set_factory_for_testing(BrowserPluginManagerFactory* factory) {
38     BrowserPluginManager::factory_ = factory;
39   }
40
41   explicit BrowserPluginManager(RenderViewImpl* render_view);
42
43   // Creates a new BrowserPlugin object.
44   // BrowserPlugin is responsible for associating itself with the
45   // BrowserPluginManager via AddBrowserPlugin. When it is destroyed, it is
46   // responsible for removing its association via RemoveBrowserPlugin.
47   virtual BrowserPlugin* CreateBrowserPlugin(
48       RenderViewImpl* render_view,
49       WebKit::WebFrame* frame,
50       const WebKit::WebPluginParams& params) = 0;
51
52   // Asynchronously requests a new browser-process-allocated instance ID.
53   // After the browser process allocates an ID, it calls back into the
54   // |browser_plugin| if it's still alive.
55   virtual void AllocateInstanceID(
56       const base::WeakPtr<BrowserPlugin>& browser_plugin) = 0;
57
58   void AddBrowserPlugin(int guest_instance_id, BrowserPlugin* browser_plugin);
59   void RemoveBrowserPlugin(int guest_instance_id);
60   BrowserPlugin* GetBrowserPlugin(int guest_instance_id) const;
61   void UpdateDeviceScaleFactor(float device_scale_factor);
62   void UpdateFocusState();
63   RenderViewImpl* render_view() const { return render_view_.get(); }
64
65   // RenderViewObserver implementation.
66
67   // BrowserPluginManager must override the default Send behavior.
68   virtual bool Send(IPC::Message* msg) OVERRIDE = 0;
69
70   // Don't destroy the BrowserPluginManager when the RenderViewImpl goes away.
71   // BrowserPluginManager's lifetime is managed by a reference count. Once
72   // the host RenderViewImpl and all BrowserPlugins release their references,
73   // then the BrowserPluginManager will be destroyed.
74   virtual void OnDestruct() OVERRIDE {}
75
76  protected:
77   // Friend RefCounted so that the dtor can be non-public.
78   friend class base::RefCounted<BrowserPluginManager>;
79
80   // Static factory instance (always NULL for non-test).
81   static BrowserPluginManagerFactory* factory_;
82
83   virtual ~BrowserPluginManager();
84   // This map is keyed by guest instance IDs.
85   IDMap<BrowserPlugin> instances_;
86   base::WeakPtr<RenderViewImpl> render_view_;
87
88   DISALLOW_COPY_AND_ASSIGN(BrowserPluginManager);
89 };
90
91 }  // namespace content
92
93 #endif //  CONTENT_RENDERER_BROWSER_PLUGIN_BROWSER_PLUGIN_MANAGER_H_