Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(57)

Side by Side Diff: chrome/browser/hang_monitor/hung_plugin_action.cc

Issue 19844003: Remove webkit/plugins/npapi. (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: remove GetDefaultWindowParent Created 7 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 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 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 #include <windows.h> 5 #include <windows.h>
6 6
7 #include "chrome/browser/hang_monitor/hung_plugin_action.h" 7 #include "chrome/browser/hang_monitor/hung_plugin_action.h"
8 8
9 #include "base/metrics/histogram.h" 9 #include "base/metrics/histogram.h"
10 #include "base/version.h" 10 #include "base/version.h"
11 #include "chrome/browser/ui/simple_message_box.h" 11 #include "chrome/browser/ui/simple_message_box.h"
12 #include "chrome/common/logging_chrome.h" 12 #include "chrome/common/logging_chrome.h"
13 #include "content/public/browser/plugin_service.h"
13 #include "grit/generated_resources.h" 14 #include "grit/generated_resources.h"
14 #include "ui/base/l10n/l10n_util.h" 15 #include "ui/base/l10n/l10n_util.h"
15 #include "ui/base/win/hwnd_util.h" 16 #include "ui/base/win/hwnd_util.h"
16 #include "webkit/plugins/npapi/plugin_utils.h" 17 #include "webkit/plugins/webplugininfo.h"
17 18
18 namespace { 19 namespace {
19 20
20 const wchar_t kGTalkPluginName[] = L"Google Talk Plugin"; 21 const wchar_t kGTalkPluginName[] = L"Google Talk Plugin";
21 const int kGTalkPluginLogMinVersion = 26; // For version 2.6 and below. 22 const int kGTalkPluginLogMinVersion = 26; // For version 2.6 and below.
22 23
23 enum GTalkPluginLogVersion { 24 enum GTalkPluginLogVersion {
24 GTALK_PLUGIN_VERSION_MIN = 0, 25 GTALK_PLUGIN_VERSION_MIN = 0,
25 GTALK_PLUGIN_VERSION_27, 26 GTALK_PLUGIN_VERSION_27,
26 GTALK_PLUGIN_VERSION_28, 27 GTALK_PLUGIN_VERSION_28,
27 GTALK_PLUGIN_VERSION_29, 28 GTALK_PLUGIN_VERSION_29,
28 GTALK_PLUGIN_VERSION_30, 29 GTALK_PLUGIN_VERSION_30,
29 GTALK_PLUGIN_VERSION_31, 30 GTALK_PLUGIN_VERSION_31,
30 GTALK_PLUGIN_VERSION_32, 31 GTALK_PLUGIN_VERSION_32,
31 GTALK_PLUGIN_VERSION_33, 32 GTALK_PLUGIN_VERSION_33,
32 GTALK_PLUGIN_VERSION_34, 33 GTALK_PLUGIN_VERSION_34,
33 GTALK_PLUGIN_VERSION_MAX 34 GTALK_PLUGIN_VERSION_MAX
34 }; 35 };
35 36
36 // Converts the version string of Google Talk Plugin to a version enum. The 37 // Converts the version string of Google Talk Plugin to a version enum. The
37 // version format is "major(1 digit).minor(1 digit).sub(1 or 2 digits)", 38 // version format is "major(1 digit).minor(1 digit).sub(1 or 2 digits)",
38 // for example, "2.7.10" and "2.8.1". Converts the string to a number as 39 // for example, "2.7.10" and "2.8.1". Converts the string to a number as
39 // 10 * major + minor - kGTalkPluginLogMinVersion. 40 // 10 * major + minor - kGTalkPluginLogMinVersion.
40 GTalkPluginLogVersion GetGTalkPluginVersion(const string16& version) { 41 GTalkPluginLogVersion GetGTalkPluginVersion(const string16& version) {
41 int gtalk_plugin_version = GTALK_PLUGIN_VERSION_MIN; 42 int gtalk_plugin_version = GTALK_PLUGIN_VERSION_MIN;
42 Version plugin_version; 43 Version plugin_version;
43 webkit::npapi::CreateVersionFromString(version, &plugin_version); 44 webkit::WebPluginInfo::CreateVersionFromString(version, &plugin_version);
44 if (plugin_version.IsValid() && plugin_version.components().size() >= 2) { 45 if (plugin_version.IsValid() && plugin_version.components().size() >= 2) {
45 gtalk_plugin_version = 10 * plugin_version.components()[0] + 46 gtalk_plugin_version = 10 * plugin_version.components()[0] +
46 plugin_version.components()[1] - kGTalkPluginLogMinVersion; 47 plugin_version.components()[1] - kGTalkPluginLogMinVersion;
47 } 48 }
48 49
49 if (gtalk_plugin_version < GTALK_PLUGIN_VERSION_MIN) 50 if (gtalk_plugin_version < GTALK_PLUGIN_VERSION_MIN)
50 return GTALK_PLUGIN_VERSION_MIN; 51 return GTALK_PLUGIN_VERSION_MIN;
51 if (gtalk_plugin_version > GTALK_PLUGIN_VERSION_MAX) 52 if (gtalk_plugin_version > GTALK_PLUGIN_VERSION_MAX)
52 return GTALK_PLUGIN_VERSION_MAX; 53 return GTALK_PLUGIN_VERSION_MAX;
53 return static_cast<GTalkPluginLogVersion>(gtalk_plugin_version); 54 return static_cast<GTalkPluginLogVersion>(gtalk_plugin_version);
(...skipping 113 matching lines...) Expand 10 before | Expand all | Expand 10 after
167 DCHECK(plugin_version); 168 DCHECK(plugin_version);
168 HWND window_to_check = plugin_window; 169 HWND window_to_check = plugin_window;
169 while (NULL != window_to_check) { 170 while (NULL != window_to_check) {
170 DWORD process_id = 0; 171 DWORD process_id = 0;
171 GetWindowThreadProcessId(window_to_check, &process_id); 172 GetWindowThreadProcessId(window_to_check, &process_id);
172 if (process_id == browser_process_id) { 173 if (process_id == browser_process_id) {
173 // If we have reached a window the that belongs to the browser process 174 // If we have reached a window the that belongs to the browser process
174 // we have gone too far. 175 // we have gone too far.
175 return false; 176 return false;
176 } 177 }
177 if (webkit::npapi::GetPluginNameFromWindow(window_to_check, plugin_name)) { 178 if (content::PluginService::GetInstance()->GetPluginInfoFromWindow(
178 webkit::npapi::GetPluginVersionFromWindow( 179 window_to_check, plugin_name, plugin_version)) {
179 window_to_check, plugin_version);
180 return true; 180 return true;
181 } 181 }
182 window_to_check = GetParent(window_to_check); 182 window_to_check = GetParent(window_to_check);
183 } 183 }
184 return false; 184 return false;
185 } 185 }
186 186
187 // static 187 // static
188 BOOL CALLBACK HungPluginAction::DismissMessageBox(HWND window, LPARAM ignore) { 188 BOOL CALLBACK HungPluginAction::DismissMessageBox(HWND window, LPARAM ignore) {
189 string16 class_name = ui::GetClassName(window); 189 string16 class_name = ui::GetClassName(window);
(...skipping 10 matching lines...) Expand all
200 void CALLBACK HungPluginAction::HungWindowResponseCallback(HWND target_window, 200 void CALLBACK HungPluginAction::HungWindowResponseCallback(HWND target_window,
201 UINT message, 201 UINT message,
202 ULONG_PTR data, 202 ULONG_PTR data,
203 LRESULT result) { 203 LRESULT result) {
204 HungPluginAction* instance = reinterpret_cast<HungPluginAction*>(data); 204 HungPluginAction* instance = reinterpret_cast<HungPluginAction*>(data);
205 DCHECK(NULL != instance); 205 DCHECK(NULL != instance);
206 if (NULL != instance) { 206 if (NULL != instance) {
207 instance->OnWindowResponsive(target_window); 207 instance->OnWindowResponsive(target_window);
208 } 208 }
209 } 209 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698