blob: 5027cfcbeb7f1871c161e0f558ffab12444ea65f (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
|
// Copyright (c) 2010 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 CHROME_COMMON_CHROME_PLUGIN_LIB_H_
#define CHROME_COMMON_CHROME_PLUGIN_LIB_H_
#include <string>
#include "base/basictypes.h"
#include "base/file_path.h"
#include "base/ref_counted.h"
#include "chrome/common/chrome_plugin_api.h"
class MessageLoop;
// A ChromePluginLib is a single Chrome Plugin Library.
// This class is used in the browser process (IO thread), and the plugin process
// (plugin thread). It should not be accessed on other threads, because it
// issues a NOTIFY_CHROME_PLUGIN_UNLOADED notification.
class ChromePluginLib : public base::RefCounted<ChromePluginLib> {
public:
static bool IsInitialized();
static ChromePluginLib* Create(const FilePath& filename,
const CPBrowserFuncs* bfuncs);
static ChromePluginLib* Find(const FilePath& filename);
static void Destroy(const FilePath& filename);
static bool IsPluginThread();
static MessageLoop* GetPluginThreadLoop();
static ChromePluginLib* FromCPID(CPID id) {
return reinterpret_cast<ChromePluginLib*>(id);
}
// Adds Chrome plugins to the NPAPI plugin list.
static void RegisterPluginsWithNPAPI();
// Loads all the plugins that are marked as "LoadOnStartup" in the
// registry. This should only be called in the browser process.
static void LoadChromePlugins(const CPBrowserFuncs* bfuncs);
// Unloads all the loaded plugins and cleans up the plugin map.
static void UnloadAllPlugins();
// Returns true if the plugin is currently loaded.
bool is_loaded() const { return initialized_; }
// Get the Plugin's function pointer table.
const CPPluginFuncs& functions() const;
CPID cpid() { return reinterpret_cast<CPID>(this); }
const FilePath& filename() { return filename_; }
// Plugin API functions
// Method to call a test function in the plugin, used for unit tests.
int CP_Test(void* param);
#if defined(OS_WIN)
// The registry path to search for Chrome Plugins/
static const TCHAR kRegistryChromePlugins[];
#endif // defined(OS_WIN)
private:
friend class base::RefCounted<ChromePluginLib>;
explicit ChromePluginLib(const FilePath& filename);
~ChromePluginLib();
// Method to initialize a Plugin.
// Initialize can be safely called multiple times.
bool CP_Initialize(const CPBrowserFuncs* bfuncs);
// Method to shutdown a Plugin.
void CP_Shutdown();
// Attempts to load the plugin.
// Returns true if it is a legitimate plugin, false otherwise
bool Load();
// Unloads the plugin.
void Unload();
FilePath filename_; // the path to the plugin
#if defined(OS_WIN)
// TODO(port): Remove ifdefs when we have portable replacement for HMODULE.
HMODULE module_; // the opened plugin handle
#endif // defined(OS_WIN)
bool initialized_; // is the plugin initialized
// Exported symbols from the plugin, looked up by name.
CP_VersionNegotiateFunc CP_VersionNegotiate_;
CP_InitializeFunc CP_Initialize_;
// Additional function pointers provided by the plugin.
CPPluginFuncs plugin_funcs_;
// Used for unit tests.
typedef int (STDCALL *CP_TestFunc)(void*);
CP_TestFunc CP_Test_;
DISALLOW_COPY_AND_ASSIGN(ChromePluginLib);
};
#endif // CHROME_COMMON_CHROME_PLUGIN_LIB_H_
|