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

Unified Diff: chrome/browser/chromeos/accessibility_util.cc

Issue 8618013: Move accessibility_util.* from chrome/browser/chromeos to chrome/browser/chromeos/accessibility (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Rebased on ToT Created 9 years, 1 month 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « chrome/browser/chromeos/accessibility_util.h ('k') | chrome/browser/chromeos/login/webui_login_view.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/chromeos/accessibility_util.cc
diff --git a/chrome/browser/chromeos/accessibility_util.cc b/chrome/browser/chromeos/accessibility_util.cc
deleted file mode 100644
index 7eb49e193b5b51a727aef7c72f71aaa6dde4f79a..0000000000000000000000000000000000000000
--- a/chrome/browser/chromeos/accessibility_util.cc
+++ /dev/null
@@ -1,171 +0,0 @@
-// Copyright (c) 2011 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.
-
-#include "chrome/browser/chromeos/accessibility_util.h"
-
-#include "base/bind.h"
-#include "base/bind_helpers.h"
-#include "base/logging.h"
-#include "chrome/browser/browser_process.h"
-#include "chrome/browser/extensions/extension_accessibility_api.h"
-#include "chrome/browser/extensions/extension_tts_api_platform.h"
-#include "chrome/browser/extensions/component_loader.h"
-#include "chrome/browser/extensions/extension_service.h"
-#include "chrome/browser/extensions/file_reader.h"
-#include "chrome/browser/profiles/profile.h"
-#include "chrome/browser/profiles/profile_manager.h"
-#include "chrome/common/extensions/extension_messages.h"
-#include "chrome/common/extensions/extension_resource.h"
-#include "chrome/common/pref_names.h"
-#include "content/browser/accessibility/browser_accessibility_state.h"
-#include "content/browser/renderer_host/render_view_host.h"
-#include "content/browser/tab_contents/tab_contents.h"
-#include "content/browser/webui/web_ui.h"
-#include "grit/browser_resources.h"
-#include "grit/generated_resources.h"
-#include "ui/base/l10n/l10n_util.h"
-#include "ui/base/resource/resource_bundle.h"
-
-namespace chromeos {
-namespace accessibility {
-
-// Helper class that directly loads an extension's content scripts into
-// all of the frames corresponding to a given RenderViewHost.
-class ContentScriptLoader {
- public:
- // Initialize the ContentScriptLoader with the ID of the extension
- // and the RenderViewHost where the scripts should be loaded.
- ContentScriptLoader(const std::string& extension_id,
- RenderViewHost* render_view_host)
- : extension_id_(extension_id),
- render_view_host_(render_view_host) {}
-
- // Call this once with the ExtensionResource corresponding to each
- // content script to be loaded.
- void AppendScript(ExtensionResource resource) {
- resources_.push(resource);
- }
-
- // Fianlly, call this method once to fetch all of the resources and
- // load them. This method will delete this object when done.
- void Run() {
- if (resources_.empty()) {
- delete this;
- return;
- }
-
- ExtensionResource resource = resources_.front();
- resources_.pop();
- scoped_refptr<FileReader> reader(new FileReader(resource, base::Bind(
- &ContentScriptLoader::OnFileLoaded, base::Unretained(this))));
- reader->Start();
- }
-
- private:
- void OnFileLoaded(bool success, const std::string& data) {
- if (success) {
- ExtensionMsg_ExecuteCode_Params params;
- params.request_id = 0;
- params.extension_id = extension_id_;
- params.is_javascript = true;
- params.code = data;
- params.all_frames = true;
- params.in_main_world = false;
- render_view_host_->Send(new ExtensionMsg_ExecuteCode(
- render_view_host_->routing_id(), params));
- }
- Run();
- }
-
- std::string extension_id_;
- RenderViewHost* render_view_host_;
- std::queue<ExtensionResource> resources_;
-};
-
-void EnableAccessibility(bool enabled, WebUI* login_web_ui) {
- bool accessibility_enabled = g_browser_process &&
- g_browser_process->local_state()->GetBoolean(
- prefs::kAccessibilityEnabled);
- if (accessibility_enabled == enabled) {
- LOG(INFO) << "Accessibility is already " <<
- (enabled ? "enabled" : "disabled") << ". Going to do nothing.";
- return;
- }
-
- g_browser_process->local_state()->SetBoolean(
- prefs::kAccessibilityEnabled, enabled);
- g_browser_process->local_state()->ScheduleSavePersistentPrefs();
- ExtensionAccessibilityEventRouter::GetInstance()->
- SetAccessibilityEnabled(enabled);
- BrowserAccessibilityState::GetInstance()->OnAccessibilityEnabledManually();
-
- Speak(enabled ?
- l10n_util::GetStringUTF8(IDS_CHROMEOS_ACC_ACCESS_ENABLED).c_str() :
- l10n_util::GetStringUTF8(IDS_CHROMEOS_ACC_ACCESS_DISABLED).c_str());
-
- // Load/Unload ChromeVox
- Profile* profile = ProfileManager::GetDefaultProfile();
- ExtensionService* extension_service =
- profile->GetExtensionService();
- FilePath path = FilePath(extension_misc::kAccessExtensionPath)
- .AppendASCII(extension_misc::kChromeVoxDirectoryName);
- if (enabled) { // Load ChromeVox
- const Extension* extension =
- extension_service->component_loader()->Add(IDR_CHROMEVOX_MANIFEST,
- path);
-
- if (login_web_ui) {
- RenderViewHost* render_view_host =
- login_web_ui->tab_contents()->render_view_host();
- ContentScriptLoader* loader = new ContentScriptLoader(
- extension->id(), render_view_host);
-
- for (size_t i = 0; i < extension->content_scripts().size(); i++) {
- const UserScript& script = extension->content_scripts()[i];
- for (size_t j = 0; j < script.js_scripts().size(); ++j) {
- const UserScript::File &file = script.js_scripts()[j];
- ExtensionResource resource = extension->GetResource(
- file.relative_path());
- loader->AppendScript(resource);
- }
- }
- loader->Run(); // It cleans itself up when done.
- }
-
- LOG(INFO) << "ChromeVox was Loaded.";
- } else { // Unload ChromeVox
- extension_service->component_loader()->Remove(path);
- LOG(INFO) << "ChromeVox was Unloaded.";
- }
-}
-
-void ToggleAccessibility(WebUI* login_web_ui) {
- bool accessibility_enabled = g_browser_process &&
- g_browser_process->local_state()->GetBoolean(
- prefs::kAccessibilityEnabled);
- accessibility_enabled = !accessibility_enabled;
- EnableAccessibility(accessibility_enabled, login_web_ui);
-};
-
-void Speak(const char* utterance) {
- UtteranceContinuousParameters params;
- ExtensionTtsPlatformImpl::GetInstance()->Speak(
- -1, // No utterance ID because we don't need a callback when it finishes.
- utterance,
- g_browser_process->GetApplicationLocale(),
- params);
-}
-
-bool IsAccessibilityEnabled() {
- if (!g_browser_process) {
- return false;
- }
- PrefService* prefs = g_browser_process->local_state();
- bool accessibility_enabled = prefs &&
- prefs->GetBoolean(prefs::kAccessibilityEnabled);
- return accessibility_enabled;
-}
-
-} // namespace accessibility
-} // namespace chromeos
« no previous file with comments | « chrome/browser/chromeos/accessibility_util.h ('k') | chrome/browser/chromeos/login/webui_login_view.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698