forked from mirrors/gecko-dev
		
	 e1bbbb144c
			
		
	
	
		e1bbbb144c
		
	
	
	
	
		
			
			As per the comments it isn't supported with cache-the-world on, it's barely documented if at all, and a test for it seems to be failing without me being able to reproduce it at least (tried on both windows and Linux). I don't think it's worth digging too much more into it. My guess is a reentrant / differently timed a11y event caused by my scheduling changes, or so, which would override sEventTargetNode or the other static bool. The test has ~always failed on macOS too... Differential Revision: https://phabricator.services.mozilla.com/D210872
		
			
				
	
	
		
			58 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			58 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
 | |
| /* This Source Code Form is subject to the terms of the Mozilla Public
 | |
|  * License, v. 2.0. If a copy of the MPL was not distributed with this
 | |
|  * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
 | |
| 
 | |
| #include "nsEventShell.h"
 | |
| 
 | |
| #include "nsAccessibilityService.h"
 | |
| #include "Logging.h"
 | |
| 
 | |
| #include "mozilla/dom/DOMStringList.h"
 | |
| 
 | |
| using namespace mozilla;
 | |
| using namespace mozilla::a11y;
 | |
| 
 | |
| ////////////////////////////////////////////////////////////////////////////////
 | |
| // nsEventShell
 | |
| ////////////////////////////////////////////////////////////////////////////////
 | |
| 
 | |
| void nsEventShell::FireEvent(AccEvent* aEvent) {
 | |
|   if (!aEvent || aEvent->mEventRule == AccEvent::eDoNotEmit) return;
 | |
| 
 | |
|   LocalAccessible* accessible = aEvent->GetAccessible();
 | |
|   NS_ENSURE_TRUE_VOID(accessible);
 | |
| 
 | |
| #ifdef A11Y_LOG
 | |
|   if (logging::IsEnabled(logging::eEvents)) {
 | |
|     logging::MsgBegin("EVENTS", "events fired");
 | |
|     nsAutoString type;
 | |
|     GetAccService()->GetStringEventType(aEvent->GetEventType(), type);
 | |
|     logging::MsgEntry("type: %s", NS_ConvertUTF16toUTF8(type).get());
 | |
|     if (aEvent->GetEventType() == nsIAccessibleEvent::EVENT_STATE_CHANGE) {
 | |
|       AccStateChangeEvent* event = downcast_accEvent(aEvent);
 | |
|       RefPtr<dom::DOMStringList> stringStates =
 | |
|           GetAccService()->GetStringStates(event->GetState());
 | |
|       nsAutoString state;
 | |
|       stringStates->Item(0, state);
 | |
|       logging::MsgEntry("state: %s = %s", NS_ConvertUTF16toUTF8(state).get(),
 | |
|                         event->IsStateEnabled() ? "true" : "false");
 | |
|     }
 | |
|     logging::AccessibleInfo("target", aEvent->GetAccessible());
 | |
|     logging::MsgEnd();
 | |
|   }
 | |
| #endif
 | |
| 
 | |
|   accessible->HandleAccEvent(aEvent);
 | |
|   aEvent->mEventRule = AccEvent::eDoNotEmit;
 | |
| }
 | |
| 
 | |
| void nsEventShell::FireEvent(uint32_t aEventType, LocalAccessible* aAccessible,
 | |
|                              EIsFromUserInput aIsFromUserInput) {
 | |
|   NS_ENSURE_TRUE_VOID(aAccessible);
 | |
| 
 | |
|   RefPtr<AccEvent> event =
 | |
|       new AccEvent(aEventType, aAccessible, aIsFromUserInput);
 | |
| 
 | |
|   FireEvent(event);
 | |
| }
 |