![electron-roller[bot]](/assets/img/avatar_default.png) 035879357e
			
		
	
	
	
	
	035879357e* chore: bump chromium in DEPS to 139.0.7242.0 * chore: update render_widget_host_view_mac.patch no code changes; just updating patch context Do a cleanup pass on the history swiper code | https://chromium-review.googlesource.com/c/chromium/src/+/6604367 * chore: update mas_avoid_private_macos_api_usage.patch.patch no code changes; just updating patch context [tracing] Delete base/trace_event/base_tracing.h | https://chromium-review.googlesource.com/c/chromium/src/+/6624012 * chore: update chore_provide_iswebcontentscreationoverridden_with_full_params.patch no manual changes; just updating patch context [ActorFramework] Refactor Actor Task Management | https://chromium-review.googlesource.com/c/chromium/src/+/6618684 * chore: update fix_move_autopipsettingshelper_behind_branding_buildflag.patch [pip] Tuck picture-in-picture windows when a file dialog is open | https://chromium-review.googlesource.com/c/chromium/src/+/6449682 Reland "[document pip] Restrict the size that a website can request" | https://chromium-review.googlesource.com/c/chromium/src/+/6372104 * chore: update feat_corner_smoothing_css_rule_and_blink_painting.patch Xref: corner-shape: constraint radii based on opposite corner overlap | https://chromium-review.googlesource.com/c/chromium/src/+/6592572 * chore: update revert_code_health_clean_up_stale_macwebcontentsocclusion.patch no manual changes; just updating patch context * chore: update fix_rename_sqlite_win32_exports_to_avoid_conflicts_with_node_js.patch no code changes; just updating patch context * chore: e patches all * Plumb Verify2QwacBinding and hook it up in QwacWebContentsObserver https://chromium-review.googlesource.com/c/chromium/src/+/6624719 * [Extensions] Remove host delegate OnMainFrameCreatedForBackgroundPage https://chromium-review.googlesource.com/c/chromium/src/+/6631123 * Extensions: Rename GetResourceURL to ResolveExtensionURL https://chromium-review.googlesource.com/c/chromium/src/+/6625053 * [NonClientFrameView] Consolidate NativeFrameViewMac https://chromium-review.googlesource.com/c/chromium/src/+/6614239 * ICWYU * [views-ax] Remove dead code WidgetAXTreeIDMap https://chromium-review.googlesource.com/c/chromium/src/+/6619701 * Reland "extensions: Add `WillPrepareForEvaluation` to setup MojoJS" https://chromium-review.googlesource.com/c/chromium/src/+/6630056 * NavigationThrottleRunner2: Remove MaybeAddThrottle https://chromium-review.googlesource.com/c/chromium/src/+/6628079 * [pip] Tuck picture-in-picture windows when a file dialog is open https://chromium-review.googlesource.com/c/chromium/src/+/6449682 * build: fix snapshot_blob.bin build error xref: https://issues.chromium.org/issues/416540976 * chore: e patches all * build: freeup disk space on macos * chore: bump chromium in DEPS to 139.0.7244.0 * chore: update printing.patch no manual changes; just updating patch context * chore: remove upstreamed ignore_parse_errors_for_resolveshortcutproperties.patch Prevent Windows crash on unexpected shortcut type | https://chromium-review.googlesource.com/c/chromium/src/+/6633298 * chore: e patches all * Revert "Reland "extensions: Add `WillPrepareForEvaluation` to setup MojoJS"" This reverts commit 77c4f967a637f7e8970114f91311f9fddede0f7c. Revert CL for the high confidence crash culprit for http://crash/28f897bb9743dfe0 | https://chromium-review.googlesource.com/c/chromium/src/+/6641819 * Fix spec's expected base64-encoded PNG strings to match upstream changes. [rust png] Enable by default. | https://chromium-review.googlesource.com/c/chromium/src/+/6085801 * chore: bump chromium in DEPS to 139.0.7246.0 * chore: e patches all * chore: bump chromium in DEPS to 139.0.7248.0 * chore: update patches * siso: Enable Siso by default for non-Google builds https://chromium-review.googlesource.com/c/chromium/src/+/6638830 Disabling for now until we are ready to build siso on all platforms. * Revert "revert Don't use static variable for UseExternalPopupMenus" This reverts commit e91e3894e6c34cc0ffe69ed45417c0ebec882fb1. * Update mac_sdk_min to match minimum required SDK version https://chromium-review.googlesource.com/c/chromium/src/+/6493969 (cherry picked from commit 3e7cbe912d8fe1062d68ed06968aaee22013985f) * [video pip] Use default window styling on Mac https://chromium-review.googlesource.com/c/chromium/src/+/6648665 * Reland "Force the unintentional renderer process creation check by default" https://chromium-review.googlesource.com/c/chromium/src/+/6626905 * fixup: Reland "Force the unintentional renderer process creation check by default https://chromium-review.googlesource.com/c/chromium/src/+/6626905 * chore: bump chromium in DEPS to 139.0.7249.0 * fixup: Reland "Force the unintentional renderer process creation check by default https://chromium-review.googlesource.com/c/chromium/src/+/6626905 * chore: update patches * chore: bump chromium in DEPS to 139.0.7250.0 * chore: bump chromium in DEPS to 139.0.7252.0 * chore: bump chromium in DEPS to 139.0.7254.0 * 6638187: browser level TOCTOU check for coordinate target https://chromium-review.googlesource.com/c/chromium/src/+/6638187 * chore: fixup patch indices * chore: add missing base/notimplemented includes * 6652910: [Frame Cleanup] Push down/hide implementation-specific API https://chromium-review.googlesource.com/c/chromium/src/+/6652910 * chore: bump chromium in DEPS to 139.0.7256.0 * chore: fix lint * fixup! 6652910: [Frame Cleanup] Push down/hide implementation-specific API * fix: move HandleScope location * chore: bump chromium in DEPS to 139.0.7258.0 * fixup! [NonClientFrameView] Consolidate NativeFrameViewMac * Revert "chore: bump chromium in DEPS to 139.0.7258.0" This reverts commit 264b2e934f4b2705c47d9761010052b95d9dd5de. --------- Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> Co-authored-by: Charles Kerr <charles@charleskerr.com> Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> Co-authored-by: deepak1556 <hop2deep@gmail.com>
		
			
				
	
	
		
			151 lines
		
	
	
	
		
			6.9 KiB
			
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			151 lines
		
	
	
	
		
			6.9 KiB
			
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
 | |
| From: Shelley Vohr <shelley.vohr@gmail.com>
 | |
| Date: Mon, 6 Jul 2020 13:46:06 -0700
 | |
| Subject: Adjust accessibility_ui for Electron
 | |
| 
 | |
| This tweaks Chrome's Accessibility support at chrome://accessibility
 | |
| to make it usable from Electron by replacing use of the Profile PrefService
 | |
| with Electron's own PrefService in ElectronBrowserContext. It also removes
 | |
| usage of BrowserList and Browser as we subclass related methods and use our
 | |
| WindowList.
 | |
| 
 | |
| diff --git a/chrome/browser/ui/webui/accessibility/accessibility_ui.cc b/chrome/browser/ui/webui/accessibility/accessibility_ui.cc
 | |
| index 20ba6b8fa6a7d5edf8ebab80ec15ece93d750000..6c42d825e520982c7fcac52cf3aa8aabbba621cb 100644
 | |
| --- a/chrome/browser/ui/webui/accessibility/accessibility_ui.cc
 | |
| +++ b/chrome/browser/ui/webui/accessibility/accessibility_ui.cc
 | |
| @@ -48,6 +48,7 @@
 | |
|  #include "content/public/browser/web_contents_observer.h"
 | |
|  #include "content/public/browser/web_contents_user_data.h"
 | |
|  #include "content/public/browser/web_ui_data_source.h"
 | |
| +#include "electron/shell/browser/electron_browser_context.h"
 | |
|  #include "ui/accessibility/accessibility_features.h"
 | |
|  #include "ui/accessibility/ax_updates_and_events.h"
 | |
|  #include "ui/accessibility/platform/ax_platform.h"
 | |
| @@ -173,7 +174,7 @@ base::Value::Dict BuildTargetDescriptor(content::RenderViewHost* rvh) {
 | |
|                                 rvh->GetRoutingID(), accessibility_mode);
 | |
|  }
 | |
|  
 | |
| -#if !BUILDFLAG(IS_ANDROID)
 | |
| +#if 0
 | |
|  base::Value::Dict BuildTargetDescriptor(Browser* browser) {
 | |
|    base::Value::Dict target_data;
 | |
|    target_data.Set(kSessionIdField, browser->session_id().id());
 | |
| @@ -197,7 +198,7 @@ void HandleAccessibilityRequestCallback(
 | |
|    auto& browser_accessibility_state =
 | |
|        *content::BrowserAccessibilityState::GetInstance();
 | |
|    base::Value::Dict data;
 | |
| -  PrefService* pref = Profile::FromBrowserContext(current_context)->GetPrefs();
 | |
| +  PrefService* pref = static_cast<electron::ElectronBrowserContext*>(current_context)->prefs();
 | |
|    ui::AXMode mode = browser_accessibility_state.GetAccessibilityMode();
 | |
|    bool native = mode.has_mode(ui::AXMode::kNativeAPIs);
 | |
|    bool web = mode.has_mode(ui::AXMode::kWebContents);
 | |
| @@ -258,7 +259,7 @@ void HandleAccessibilityRequestCallback(
 | |
|    data.Set(kIsScreenReaderActive, is_screen_reader_active);
 | |
|  
 | |
|    std::string pref_api_type =
 | |
| -      pref->GetString(prefs::kShownAccessibilityApiType);
 | |
| +      std::string(pref->GetString(prefs::kShownAccessibilityApiType));
 | |
|    bool pref_api_type_supported = false;
 | |
|  
 | |
|    std::vector<ui::AXApiType::Type> supported_api_types =
 | |
| @@ -326,11 +327,11 @@ void HandleAccessibilityRequestCallback(
 | |
|    data.Set(kPagesField, std::move(page_list));
 | |
|  
 | |
|    base::Value::List browser_list;
 | |
| -#if !BUILDFLAG(IS_ANDROID)
 | |
| +#if 0
 | |
|    for (Browser* browser : *BrowserList::GetInstance()) {
 | |
|      browser_list.Append(BuildTargetDescriptor(browser));
 | |
|    }
 | |
| -#endif  // !BUILDFLAG(IS_ANDROID)
 | |
| +#endif
 | |
|    data.Set(kBrowsersField, std::move(browser_list));
 | |
|  
 | |
|    std::string json_string;
 | |
| @@ -804,7 +805,8 @@ void AccessibilityUIMessageHandler::SetGlobalString(
 | |
|    const std::string value = CheckJSValue(data.FindString(kValueField));
 | |
|  
 | |
|    if (string_name == kApiTypeField) {
 | |
| -    PrefService* pref = Profile::FromWebUI(web_ui())->GetPrefs();
 | |
| +    PrefService* pref = static_cast<electron::ElectronBrowserContext*>(
 | |
| +            web_ui()->GetWebContents()->GetBrowserContext())->prefs();
 | |
|      pref->SetString(prefs::kShownAccessibilityApiType, value);
 | |
|    }
 | |
|  }
 | |
| @@ -858,7 +860,8 @@ void AccessibilityUIMessageHandler::RequestWebContentsTree(
 | |
|                       AXPropertyFilter::ALLOW_EMPTY);
 | |
|    AddPropertyFilters(property_filters, deny, AXPropertyFilter::DENY);
 | |
|  
 | |
| -  PrefService* pref = Profile::FromWebUI(web_ui())->GetPrefs();
 | |
| +  PrefService* pref = static_cast<electron::ElectronBrowserContext*>(
 | |
| +              web_contents->GetBrowserContext())->prefs();
 | |
|    ui::AXApiType::Type api_type =
 | |
|        ui::AXApiType::From(pref->GetString(prefs::kShownAccessibilityApiType));
 | |
|    std::string accessibility_contents =
 | |
| @@ -885,6 +888,7 @@ void AccessibilityUIMessageHandler::RequestNativeUITree(
 | |
|                       AXPropertyFilter::ALLOW_EMPTY);
 | |
|    AddPropertyFilters(property_filters, deny, AXPropertyFilter::DENY);
 | |
|  
 | |
| +#if 0
 | |
|    for (Browser* browser : *BrowserList::GetInstance()) {
 | |
|      if (browser->session_id().id() == session_id) {
 | |
|        base::Value::Dict result = BuildTargetDescriptor(browser);
 | |
| @@ -897,6 +901,7 @@ void AccessibilityUIMessageHandler::RequestNativeUITree(
 | |
|        return;
 | |
|      }
 | |
|    }
 | |
| +#endif
 | |
|  #endif  // !BUILDFLAG(IS_ANDROID)
 | |
|    // No browser with the specified |session_id| was found.
 | |
|    base::Value::Dict result;
 | |
| @@ -940,11 +945,13 @@ void AccessibilityUIMessageHandler::StopRecording(
 | |
|  }
 | |
|  
 | |
|  ui::AXApiType::Type AccessibilityUIMessageHandler::GetRecordingApiType() {
 | |
| -  PrefService* pref = Profile::FromWebUI(web_ui())->GetPrefs();
 | |
| -  const std::vector<ui::AXApiType::Type> supported_types =
 | |
| -      content::AXInspectFactory::SupportedApis();
 | |
| +  PrefService* pref = static_cast<electron::ElectronBrowserContext*>(
 | |
| +            web_ui()->GetWebContents()->GetBrowserContext())->prefs();
 | |
|    ui::AXApiType::Type api_type =
 | |
|        ui::AXApiType::From(pref->GetString(prefs::kShownAccessibilityApiType));
 | |
| +
 | |
| +  const std::vector<ui::AXApiType::Type> supported_types =
 | |
| +      content::AXInspectFactory::SupportedApis();
 | |
|    // Check to see if it is in the supported types list.
 | |
|    if (std::find(supported_types.begin(), supported_types.end(), api_type) ==
 | |
|        supported_types.end()) {
 | |
| @@ -1014,8 +1021,11 @@ void AccessibilityUIMessageHandler::RequestAccessibilityEvents(
 | |
|  // static
 | |
|  void AccessibilityUIMessageHandler::RegisterProfilePrefs(
 | |
|      user_prefs::PrefRegistrySyncable* registry) {
 | |
| +#if 0
 | |
|    const std::string_view default_api_type =
 | |
|        std::string_view(ui::AXApiType::Type(ui::AXApiType::kBlink));
 | |
|    registry->RegisterStringPref(prefs::kShownAccessibilityApiType,
 | |
|                                 std::string(default_api_type));
 | |
| +  registry->RegisterBooleanPref(prefs::kShowInternalAccessibilityTree, false);
 | |
| +#endif
 | |
|  }
 | |
| diff --git a/chrome/browser/ui/webui/accessibility/accessibility_ui.h b/chrome/browser/ui/webui/accessibility/accessibility_ui.h
 | |
| index b171afc941b2b3ef4aeba04a2b1c6eef2774d442..8f431aae69365bc8756e515c603332a7f1648148 100644
 | |
| --- a/chrome/browser/ui/webui/accessibility/accessibility_ui.h
 | |
| +++ b/chrome/browser/ui/webui/accessibility/accessibility_ui.h
 | |
| @@ -27,6 +27,8 @@ namespace content {
 | |
|  class WebContents;
 | |
|  }  // namespace content
 | |
|  
 | |
| +class ElectronAccessibilityUIMessageHandler;
 | |
| +
 | |
|  namespace user_prefs {
 | |
|  class PrefRegistrySyncable;
 | |
|  }  // namespace user_prefs
 | |
| @@ -77,6 +79,8 @@ class AccessibilityUIMessageHandler : public content::WebUIMessageHandler {
 | |
|    static void RegisterProfilePrefs(user_prefs::PrefRegistrySyncable* registry);
 | |
|  
 | |
|   private:
 | |
| +  friend class ElectronAccessibilityUIMessageHandler;
 | |
| +
 | |
|    void ToggleAccessibilityForWebContents(const base::Value::List& args);
 | |
|    void SetGlobalFlag(const base::Value::List& args);
 | |
|    void SetGlobalString(const base::Value::List& args);
 |