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

Side by Side Diff: chrome/browser/plugins/plugin_finder.cc

Issue 2405013002: Move some global feature defines to buildflags (Closed)
Patch Set: Comment Created 4 years, 2 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
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 "chrome/browser/plugins/plugin_finder.h" 5 #include "chrome/browser/plugins/plugin_finder.h"
6 6
7 #include <stddef.h> 7 #include <stddef.h>
8 8
9 #include "base/bind.h" 9 #include "base/bind.h"
10 #include "base/json/json_reader.h" 10 #include "base/json/json_reader.h"
11 #include "base/message_loop/message_loop.h" 11 #include "base/message_loop/message_loop.h"
12 #include "base/metrics/histogram_macros.h" 12 #include "base/metrics/histogram_macros.h"
13 #include "base/stl_util.h" 13 #include "base/stl_util.h"
14 #include "base/strings/sys_string_conversions.h" 14 #include "base/strings/sys_string_conversions.h"
15 #include "base/strings/utf_string_conversions.h" 15 #include "base/strings/utf_string_conversions.h"
16 #include "base/values.h" 16 #include "base/values.h"
17 #include "chrome/browser/browser_process.h" 17 #include "chrome/browser/browser_process.h"
18 #include "chrome/browser/plugins/plugin_metadata.h" 18 #include "chrome/browser/plugins/plugin_metadata.h"
19 #include "chrome/common/features.h"
19 #include "chrome/common/pref_names.h" 20 #include "chrome/common/pref_names.h"
20 #include "chrome/grit/browser_resources.h" 21 #include "chrome/grit/browser_resources.h"
21 #include "components/prefs/pref_registry_simple.h" 22 #include "components/prefs/pref_registry_simple.h"
22 #include "components/prefs/pref_service.h" 23 #include "components/prefs/pref_service.h"
23 #include "content/public/browser/browser_thread.h" 24 #include "content/public/browser/browser_thread.h"
24 #include "content/public/browser/plugin_service.h" 25 #include "content/public/browser/plugin_service.h"
25 #include "ui/base/resource/resource_bundle.h" 26 #include "ui/base/resource/resource_bundle.h"
26 #include "url/gurl.h" 27 #include "url/gurl.h"
27 28
28 #if defined(ENABLE_PLUGIN_INSTALLATION) 29 #if BUILDFLAG(ENABLE_PLUGIN_INSTALLATION)
29 #include "chrome/browser/plugins/plugin_installer.h" 30 #include "chrome/browser/plugins/plugin_installer.h"
30 #endif 31 #endif
31 32
32 using base::DictionaryValue; 33 using base::DictionaryValue;
33 using content::PluginService; 34 using content::PluginService;
34 35
35 namespace { 36 namespace {
36 37
37 typedef std::map<std::string, PluginMetadata*> PluginMap; 38 typedef std::map<std::string, PluginMetadata*> PluginMap;
38 39
(...skipping 200 matching lines...) Expand 10 before | Expand all | Expand 10 after
239 RecordBuiltInPluginListError(PluginListError::SCHEMA_ERROR); 240 RecordBuiltInPluginListError(PluginListError::SCHEMA_ERROR);
240 return nullptr; 241 return nullptr;
241 } 242 }
242 243
243 DCHECK_EQ(base::JSONReader::JSON_NO_ERROR, error_code); 244 DCHECK_EQ(base::JSONReader::JSON_NO_ERROR, error_code);
244 RecordBuiltInPluginListError(PluginListError::PLUGIN_LIST_NO_ERROR); 245 RecordBuiltInPluginListError(PluginListError::PLUGIN_LIST_NO_ERROR);
245 return static_cast<base::DictionaryValue*>(value.release()); 246 return static_cast<base::DictionaryValue*>(value.release());
246 } 247 }
247 248
248 PluginFinder::~PluginFinder() { 249 PluginFinder::~PluginFinder() {
249 #if defined(ENABLE_PLUGIN_INSTALLATION) 250 #if BUILDFLAG(ENABLE_PLUGIN_INSTALLATION)
250 base::STLDeleteValues(&installers_); 251 base::STLDeleteValues(&installers_);
251 #endif 252 #endif
252 base::STLDeleteValues(&identifier_plugin_); 253 base::STLDeleteValues(&identifier_plugin_);
253 } 254 }
254 255
255 #if defined(ENABLE_PLUGIN_INSTALLATION) 256 #if BUILDFLAG(ENABLE_PLUGIN_INSTALLATION)
256 bool PluginFinder::FindPlugin( 257 bool PluginFinder::FindPlugin(
257 const std::string& mime_type, 258 const std::string& mime_type,
258 const std::string& language, 259 const std::string& language,
259 PluginInstaller** installer, 260 PluginInstaller** installer,
260 std::unique_ptr<PluginMetadata>* plugin_metadata) { 261 std::unique_ptr<PluginMetadata>* plugin_metadata) {
261 if (g_browser_process->local_state()->GetBoolean(prefs::kDisablePluginFinder)) 262 if (g_browser_process->local_state()->GetBoolean(prefs::kDisablePluginFinder))
262 return false; 263 return false;
263 264
264 base::AutoLock lock(mutex_); 265 base::AutoLock lock(mutex_);
265 PluginMap::const_iterator metadata_it = identifier_plugin_.begin(); 266 PluginMap::const_iterator metadata_it = identifier_plugin_.begin();
(...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after
313 base::STLDeleteValues(&identifier_plugin_); 314 base::STLDeleteValues(&identifier_plugin_);
314 315
315 for (base::DictionaryValue::Iterator plugin_it(*plugin_list); 316 for (base::DictionaryValue::Iterator plugin_it(*plugin_list);
316 !plugin_it.IsAtEnd(); plugin_it.Advance()) { 317 !plugin_it.IsAtEnd(); plugin_it.Advance()) {
317 const base::DictionaryValue* plugin = NULL; 318 const base::DictionaryValue* plugin = NULL;
318 const std::string& identifier = plugin_it.key(); 319 const std::string& identifier = plugin_it.key();
319 if (plugin_list->GetDictionaryWithoutPathExpansion(identifier, &plugin)) { 320 if (plugin_list->GetDictionaryWithoutPathExpansion(identifier, &plugin)) {
320 DCHECK(!identifier_plugin_[identifier]); 321 DCHECK(!identifier_plugin_[identifier]);
321 identifier_plugin_[identifier] = CreatePluginMetadata(identifier, plugin); 322 identifier_plugin_[identifier] = CreatePluginMetadata(identifier, plugin);
322 323
323 #if defined(ENABLE_PLUGIN_INSTALLATION) 324 #if BUILDFLAG(ENABLE_PLUGIN_INSTALLATION)
324 if (installers_.find(identifier) == installers_.end()) 325 if (installers_.find(identifier) == installers_.end())
325 installers_[identifier] = new PluginInstaller(); 326 installers_[identifier] = new PluginInstaller();
326 #endif 327 #endif
327 } 328 }
328 } 329 }
329 } 330 }
330 331
331 std::unique_ptr<PluginMetadata> PluginFinder::GetPluginMetadata( 332 std::unique_ptr<PluginMetadata> PluginFinder::GetPluginMetadata(
332 const content::WebPluginInfo& plugin) { 333 const content::WebPluginInfo& plugin) {
333 base::AutoLock lock(mutex_); 334 base::AutoLock lock(mutex_);
(...skipping 19 matching lines...) Expand all
353 metadata->AddMatchingMimeType(plugin.mime_types[i].mime_type); 354 metadata->AddMatchingMimeType(plugin.mime_types[i].mime_type);
354 355
355 DCHECK(metadata->MatchesPlugin(plugin)); 356 DCHECK(metadata->MatchesPlugin(plugin));
356 if (identifier_plugin_.find(identifier) != identifier_plugin_.end()) 357 if (identifier_plugin_.find(identifier) != identifier_plugin_.end())
357 identifier = GetLongIdentifier(plugin); 358 identifier = GetLongIdentifier(plugin);
358 359
359 DCHECK(identifier_plugin_.find(identifier) == identifier_plugin_.end()); 360 DCHECK(identifier_plugin_.find(identifier) == identifier_plugin_.end());
360 identifier_plugin_[identifier] = metadata; 361 identifier_plugin_[identifier] = metadata;
361 return metadata->Clone(); 362 return metadata->Clone();
362 } 363 }
OLDNEW
« no previous file with comments | « chrome/browser/plugins/plugin_finder.h ('k') | chrome/browser/plugins/plugin_info_message_filter.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698