2013-01-29 10:00:58 +00:00
|
|
|
/* -*- 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/. */
|
|
|
|
|
|
|
|
#ifndef mozilla_a11y_EventQueue_h_
|
|
|
|
#define mozilla_a11y_EventQueue_h_
|
|
|
|
|
|
|
|
#include "AccEvent.h"
|
2023-12-01 17:18:23 +00:00
|
|
|
#include "mozilla/Assertions.h"
|
2013-01-29 10:00:58 +00:00
|
|
|
|
|
|
|
namespace mozilla {
|
|
|
|
namespace a11y {
|
|
|
|
|
|
|
|
class DocAccessible;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Used to organize and coalesce pending events.
|
|
|
|
*/
|
|
|
|
class EventQueue {
|
|
|
|
protected:
|
2023-12-01 17:18:23 +00:00
|
|
|
explicit EventQueue(DocAccessible* aDocument) : mDocument(aDocument) {
|
|
|
|
MOZ_ASSERT(mDocument,
|
|
|
|
"There's no point creating an event queue for a null document");
|
|
|
|
}
|
2013-01-29 10:00:58 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Put an accessible event into the queue to process it later.
|
|
|
|
*/
|
|
|
|
bool PushEvent(AccEvent* aEvent);
|
|
|
|
|
2016-04-07 13:30:22 +00:00
|
|
|
/**
|
2021-01-27 00:39:08 +00:00
|
|
|
* Puts name and/or description change events into the queue, if needed.
|
2016-04-07 13:30:22 +00:00
|
|
|
*/
|
2023-03-24 00:37:34 +00:00
|
|
|
bool PushNameOrDescriptionChange(AccEvent* aOrigEvent);
|
2016-04-07 13:30:22 +00:00
|
|
|
|
2013-01-29 10:00:58 +00:00
|
|
|
/**
|
|
|
|
* Process events from the queue and fires events.
|
|
|
|
*/
|
|
|
|
void ProcessEventQueue();
|
|
|
|
|
|
|
|
private:
|
2015-01-06 23:35:02 +00:00
|
|
|
EventQueue(const EventQueue&) = delete;
|
|
|
|
EventQueue& operator=(const EventQueue&) = delete;
|
2013-01-29 10:00:58 +00:00
|
|
|
|
|
|
|
// Event queue processing
|
|
|
|
/**
|
|
|
|
* Coalesce redundant events from the queue.
|
|
|
|
*/
|
|
|
|
void CoalesceEvents();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Coalesce events from the same subtree.
|
|
|
|
*/
|
|
|
|
void CoalesceReorderEvents(AccEvent* aTailEvent);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Coalesce two selection change events within the same select control.
|
|
|
|
*/
|
|
|
|
void CoalesceSelChangeEvents(AccSelChangeEvent* aTailEvent,
|
|
|
|
AccSelChangeEvent* aThisEvent,
|
|
|
|
uint32_t aThisIndex);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
/**
|
|
|
|
* The document accessible reference owning this queue.
|
|
|
|
*/
|
2013-02-23 12:33:11 +00:00
|
|
|
DocAccessible* mDocument;
|
2013-01-29 10:00:58 +00:00
|
|
|
|
|
|
|
/**
|
2016-02-02 15:36:30 +00:00
|
|
|
* Pending events array. Don't make this an AutoTArray; we use
|
2013-01-29 10:00:58 +00:00
|
|
|
* SwapElements() on it.
|
|
|
|
*/
|
2016-04-07 13:30:22 +00:00
|
|
|
nsTArray<RefPtr<AccEvent>> mEvents;
|
2022-05-06 23:59:43 +00:00
|
|
|
|
|
|
|
// Pending focus event.
|
|
|
|
RefPtr<AccEvent> mFocusEvent;
|
2013-01-29 10:00:58 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace a11y
|
|
|
|
} // namespace mozilla
|
|
|
|
|
|
|
|
#endif // mozilla_a11y_EventQueue_h_
|